forked from rotki/rotki
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpackage.sh
executable file
·267 lines (223 loc) · 8.49 KB
/
package.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
#!/usr/bin/env bash
: "${PYINSTALLER_VERSION:=4.8}"
WORKDIR=$PWD
BACKEND_DIST_DIR="rotkehlchen_py_dist"
# cleanup before starting to package stuff
make clean
source tools/scripts/check_unmerged.sh noforce
if [[ -n "${CI-}" ]]; then
echo "::group::Pip install"
fi
if [[ -z "${CI+x}" ]] && [[ -z "${VIRTUAL_ENV}" ]]; then
echo 'The script should not run outside a virtual environment if not on CI'
exit 1
fi
# Perform sanity checks before pip install
pip install packaging # required for the following script
# We use npm ci. That needs npm >= 5.7.0
npm --version | python -c "import sys;npm_version=sys.stdin.readlines()[0].rstrip('\n');from packaging import version;supported=version.parse(npm_version) >= version.parse('7.6.2');sys.exit(1) if not supported else sys.exit(0);"
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: The system's npm version is not >= 7.6.2 which is required for npm ci"
exit 1
fi
# Install the rotki package and pyinstaller. Needed by the pyinstaller
pip install -e .
pip install pyinstaller==${PYINSTALLER_VERSION}
if [[ -n "${CI-}" ]]; then
echo "::endgroup::"
fi
# Perform sanity checks that need pip install
python -c "import sys;from rotkehlchen.db.dbhandler import detect_sqlcipher_version; version = detect_sqlcipher_version();sys.exit(0) if version == 4 else sys.exit(1)"
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: The packaging system's sqlcipher version is not >= v4"
exit 1
fi
# Get the arch
ARCH=$(uname -m)
if [[ "$ARCH" == 'x86_64' ]]; then
ARCH='x64'
else
echo "package.sh - ERROR: Unsupported architecture '${ARCH}'"
exit 1
fi
# Get the platform
if [[ "$OSTYPE" == "linux-gnu" ]]; then
PLATFORM='linux'
elif [[ "$OSTYPE" == "darwin"* ]]; then
PLATFORM='darwin'
export ONEFILE=0
elif [[ "$OSTYPE" == "win32" ]]; then
PLATFORM='win32'
elif [[ "$OSTYPE" == "freebsd"* ]]; then
PLATFORM='freebsd'
else
echo "package.sh - ERROR: Unsupported platform '${OSTYPE}'"
exit 1
fi
if [[ -n "${CI-}" ]]; then
echo "::group::PyInstaller"
fi
# Use pyinstaller to package the python app
rm -rf build "${BACKEND_DIST_DIR}"
pyinstaller --noconfirm --clean --distpath "${BACKEND_DIST_DIR}" rotkehlchen.spec
if [[ -n "${CI-}" ]]; then
echo "::endgroup::"
fi
ROTKEHLCHEN_VERSION=$(python setup.py --version)
export ROTKEHLCHEN_VERSION
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: pyinstaller step failed"
exit 1
fi
echo 'Checking binary'
if [[ "$PLATFORM" == "darwin" ]]; then
PYINSTALLER_GENERATED_EXECUTABLE=$(find ./${BACKEND_DIST_DIR}/rotkehlchen -name "rotkehlchen-*-macos")
./${BACKEND_DIST_DIR}/rotkehlchen/"${PYINSTALLER_GENERATED_EXECUTABLE##*/}" version
else
# Sanity check that the generated python executable works
PYINSTALLER_GENERATED_EXECUTABLE=$(find ./${BACKEND_DIST_DIR} -name "rotkehlchen-*-linux")
./${BACKEND_DIST_DIR}/"${PYINSTALLER_GENERATED_EXECUTABLE##*/}" version
fi
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: The generated python executable does not work properly"
exit 1
fi
if [[ -n "${CI-}" ]] && [[ "$PLATFORM" == "darwin" ]] && [[ -n "${CERTIFICATE_OSX_APPLICATION-}" ]]; then
echo "Preparing to sign backend binary for macos"
KEY_CHAIN=rotki-build.keychain
CSC_LINK=/tmp/certificate.p12
export CSC_LINK
# Recreate the certificate from the secure environment variable
echo $CERTIFICATE_OSX_APPLICATION | base64 --decode > $CSC_LINK
#create a keychain
security create-keychain -p actions $KEY_CHAIN
# Make the keychain the default so identities are found
security default-keychain -s $KEY_CHAIN
# Unlock the keychains
security unlock-keychain -p actions $KEY_CHAIN
security import $CSC_LINK -k $KEY_CHAIN -P $CSC_KEY_PASSWORD -T /usr/bin/codesign;
security set-key-partition-list -S apple-tool:,apple: -s -k actions $KEY_CHAIN
echo "::group::Preparing to sign"
files=(`find ./${BACKEND_DIST_DIR} -type f -exec ls -dl \{\} \; | awk '{ print $9 }'`)
for i in "${files[@]}"
do
echo "Signing $i"
codesign --force --options runtime --entitlements ./packaging/entitlements.plist --sign $IDENTITY $i --timestamp || exit 1
codesign --verify --verbose $i || exit 1
done
echo "::endgroup::"
fi
if [[ "$PLATFORM" == "darwin" ]]; then
cd ${BACKEND_DIST_DIR} || exit 1
zip -vr "rotkehlchen-backend-${ROTKEHLCHEN_VERSION}-macos.zip" rotkehlchen/ -x "*.DS_Store"
cd "$WORKDIR" || exit 1
fi
# From here and on we go into the frontend/app directory
cd frontend || exit 1
if [[ -n "${CI-}" ]]; then
echo "::group::npm ci"
fi
# Let's make sure all npm dependencies are installed.
echo "Installing node dependencies"
npm ci
if [[ $? -ne 0 ]]; then
echo "Verifying npm cache"
npm cache verify
echo "Attempting node installation again"
npm ci
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: npm ci step failed"
exit 1
fi
fi
if [[ -n "${CI-}" ]]; then
echo "::endgroup::"
fi
if [[ -n "${CI-}" ]]; then
echo "::group::electron:build"
fi
# Finally run the packaging
echo "Packaging rotki ${ROTKEHLCHEN_VERSION}"
npm run electron:build
if [[ $? -ne 0 ]]; then
echo "package.sh - ERROR: electron builder step failed"
exit 1
fi
if [[ -n "${CI-}" ]]; then
echo "::endgroup::"
fi
if [[ -n "${CI-}" ]] && [[ "$OSTYPE" == "darwin"* ]]; then
# remove certs
rm -fr /tmp/*.p12
fi
echo "Packaging finished for rotki ${ROTKEHLCHEN_VERSION}"
# Go back to root directory
cd "$WORKDIR" || exit 1
function generate_checksum() {
local platform
local filter
local file
local checksum_file
platform=$1
filter=$2
file=$(find ./ -name "$filter" | sed 's|^./||' | sed 's|^/||');
checksum_file="$file.sha512"
echo "Generating sha512 sum for $file"
if [[ "$platform" == "linux" ]]; then
sha512sum "$file" > "$checksum_file"
elif [[ "$platform" == "darwin" ]]; then
shasum -a 512 "$file" > "$checksum_file"
else
echo "$platform not supported"
exit 1;
fi
eval "$3='$(pwd)/$checksum_file'"
}
cd frontend/app/dist || exit 1
if [[ "$PLATFORM" == "linux" ]]; then
GENERATED_APPIMAGE=$(find "$(pwd)" -name "rotki-linux*.AppImage" | head -n 1)
generate_checksum "$PLATFORM" "rotki-linux*.AppImage" APPIMAGE_CHECKSUM
generate_checksum "$PLATFORM" "rotki-linux*.tar.xz" TAR_CHECKSUM
generate_checksum "$PLATFORM" "rotki-linux*.deb" DEB_CHECKSUM
cd "$WORKDIR/${BACKEND_DIST_DIR}" || exit 1
BACKEND_BINARY=$(find "$(pwd)" -name "rotkehlchen-*-linux" | head -n 1)
generate_checksum "$PLATFORM" "rotkehlchen-*-linux" BACKEND_CHECKSUM
if [[ -n "${CI-}" ]]; then
echo "::set-output name=binary::$GENERATED_APPIMAGE"
echo "::set-output name=binary_name::${GENERATED_APPIMAGE##*/}"
echo "::set-output name=binary_checksum::$APPIMAGE_CHECKSUM"
echo "::set-output name=binary_checksum_name::${APPIMAGE_CHECKSUM##*/}"
echo "::set-output name=archive_checksum::$TAR_CHECKSUM"
echo "::set-output name=archive_checksum_name::${TAR_CHECKSUM##*/}"
echo "::set-output name=deb_checksum::$DEB_CHECKSUM"
echo "::set-output name=deb_checksum_name::${DEB_CHECKSUM##*/}"
echo "::set-output name=backend_binary::${BACKEND_BINARY}"
echo "::set-output name=backend_binary_name::${BACKEND_BINARY##*/}"
echo "::set-output name=backend_binary_checksum::${BACKEND_CHECKSUM}"
echo "::set-output name=backend_binary_checksum_name::${BACKEND_CHECKSUM##*/}"
fi
export APPIMAGE_CHECKSUM
export TAR_CHECKSUM
elif [[ "$PLATFORM" == "darwin" ]]; then
DMG=$(find "$(pwd)" -name "rotki-darwin*.dmg" | head -n 1)
generate_checksum "$PLATFORM" "rotki-darwin*.dmg" DMG_CHECKSUM
generate_checksum "$PLATFORM" "rotki-darwin*.zip" ZIP_CHECKSUM
# Creates checksum for the backend archive
cd "$WORKDIR/${BACKEND_DIST_DIR}" || exit 1
BACKEND=$(find "$(pwd)" -name "rotkehlchen-backend*-macos.zip" | head -n 1)
generate_checksum "$PLATFORM" "rotkehlchen-backend-*-macos.zip" BACKEND_CHECKSUM
if [[ -n "${CI-}" ]]; then
echo "::set-output name=binary::$DMG"
echo "::set-output name=binary_name::${DMG##*/}"
echo "::set-output name=binary_checksum::$DMG_CHECKSUM"
echo "::set-output name=binary_checksum_name::${DMG_CHECKSUM##*/}"
echo "::set-output name=archive_checksum::$ZIP_CHECKSUM"
echo "::set-output name=archive_checksum_name::${ZIP_CHECKSUM##*/}"
echo "::set-output name=backend_binary::${BACKEND}"
echo "::set-output name=backend_binary_name::${BACKEND##*/}"
echo "::set-output name=backend_binary_checksum::${BACKEND_CHECKSUM}"
echo "::set-output name=backend_binary_checksum_name::${BACKEND_CHECKSUM##*/}"
fi
export DMG_CHECKSUM
export ZIP_CHECKSUM
fi