Browse Source

build: extend release.sh so that all builders can use it

patch-4
SomberNight 4 years ago
parent
commit
e54e6e4e09
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 10
      contrib/android/apkdiff.py
  2. 5
      contrib/build-wine/unsign.sh
  3. 231
      contrib/release.sh
  4. 8
      contrib/sign_packages
  5. 26
      contrib/upload

10
contrib/android/apkdiff.py

@ -7,14 +7,16 @@ from zipfile import ZipFile
class ApkDiff: class ApkDiff:
IGNORE_FILES = ["META-INF/MANIFEST.MF", "META-INF/CERT.RSA", "META-INF/CERT.SF"] IGNORE_FILES = ["META-INF/MANIFEST.MF", "META-INF/CERT.RSA", "META-INF/CERT.SF"]
def compare(self, sourceApk, destinationApk): def compare(self, sourceApk, destinationApk) -> bool:
sourceZip = ZipFile(sourceApk, 'r') sourceZip = ZipFile(sourceApk, 'r')
destinationZip = ZipFile(destinationApk, 'r') destinationZip = ZipFile(destinationApk, 'r')
if self.compareManifests(sourceZip, destinationZip) and self.compareEntries(sourceZip, destinationZip) == True: if self.compareManifests(sourceZip, destinationZip) and self.compareEntries(sourceZip, destinationZip) == True:
print("APKs match!") print("APKs match!")
return True
else: else:
print("APKs don't match!") print("APKs don't match!")
return False
def compareManifests(self, sourceZip, destinationZip): def compareManifests(self, sourceZip, destinationZip):
sourceEntrySortedList = sorted(sourceZip.namelist()) sourceEntrySortedList = sorted(sourceZip.namelist())
@ -75,4 +77,8 @@ if __name__ == '__main__':
print("Usage: apkdiff <pathToFirstApk> <pathToSecondApk>") print("Usage: apkdiff <pathToFirstApk> <pathToSecondApk>")
sys.exit(1) sys.exit(1)
ApkDiff().compare(sys.argv[1], sys.argv[2]) match = ApkDiff().compare(sys.argv[1], sys.argv[2])
if match:
sys.exit(0)
else:
sys.exit(1)

5
contrib/build-wine/unsign.sh

@ -33,8 +33,11 @@ for mine in $(ls dist/*.exe); do
chmod +x $out chmod +x $out
if cmp -s $out $mine; then if cmp -s $out $mine; then
echo "Success: $f" echo "Success: $f"
gpg --sign --armor --detach signed/$f #gpg --sign --armor --detach signed/$f
else else
echo "Failure: $f" echo "Failure: $f"
exit 1
fi fi
done done
exit 0

231
contrib/release.sh

@ -1,102 +1,149 @@
#!/bin/bash #!/bin/bash
# Note: steps before doing a new release:
# #
# This script, for the RELEASEMANAGER:
# - builds and uploads all binaries,
# - note: the .dmg should be built separately beforehand and copied into dist/
# (as it is built on a separate machine)
# - assumes all keys are available, and signs everything
# This script, for other builders:
# - builds reproducible binaries only,
# - downloads binaries built by the release manager, compares and signs them,
# - and then uploads sigs
#
# env vars:
# - ELECBUILD_NOCACHE: if set, forces rebuild of docker images
# - WWW_DIR: path to "electrum-web" git clone
#
# additional env vars for the RELEASEMANAGER:
# - for signing the version announcement file:
# - ELECTRUM_SIGNING_ADDRESS (required)
# - ELECTRUM_SIGNING_WALLET (required)
#
# "uploadserver" is set in /etc/hosts
#
# Note: steps before doing a new release:
# - update locale: # - update locale:
# 1. cd /opt/electrum-locale && ./update && push # 1. cd /opt/electrum-locale && ./update && push
# 2. cd to the submodule dir, and git pull # 2. cd to the submodule dir, and git pull
# 3. cd .. && git push # 3. cd .. && git push
# - update RELEASE-NOTES and version.py # - update RELEASE-NOTES and version.py
# - git tag # - git tag
#
set -e
PROJECT_ROOT="$(dirname "$(readlink -e "$0")")/.."
CONTRIB="$PROJECT_ROOT/contrib"
ELECTRUM_DIR=/opt/electrum cd "$PROJECT_ROOT"
WWW_DIR=/opt/electrum-web
. "$CONTRIB"/build_tools_util.sh
cd $ELECTRUM_DIR
# rm -rf dist/* # rm -rf dist/*
# rm -f .buildozer # rm -f .buildozer
if [ -z "$WWW_DIR" ] ; then
WWW_DIR=/opt/electrum-web
fi
GPGUSER=$1
if [ -z "$GPGUSER" ]; then
fail "usage: release.sh gpg_username"
fi
export SSHUSER="$GPGUSER"
RELEASEMANAGER=""
if [ "$GPGUSER" == "ThomasV" ]; then
PUBKEY="--local-user 6694D8DE7BE8EE5631BED9502BD5824B7F9470E6"
export SSHUSER=thomasv
RELEASEMANAGER=1
elif [ "$GPGUSER" == "sombernight_releasekey" ]; then
PUBKEY="--local-user 0EEDCFD5CAFB459067349B23CA9EEEC43DF911DC"
export SSHUSER=sombernight
fi
VERSION=`python3 -c "import electrum; print(electrum.version.ELECTRUM_VERSION)"` VERSION=`python3 -c "import electrum; print(electrum.version.ELECTRUM_VERSION)"`
echo "VERSION: $VERSION" info "VERSION: $VERSION"
REV=`git describe --tags` REV=`git describe --tags`
echo "REV: $REV" info "REV: $REV"
COMMIT=$(git rev-parse HEAD) COMMIT=$(git rev-parse HEAD)
export ELECBUILD_COMMIT="${COMMIT}^{commit}" export ELECBUILD_COMMIT="${COMMIT}^{commit}"
#export ELECBUILD_NOCACHE=1
git_status=$(git status --porcelain) git_status=$(git status --porcelain)
if [ ! -z "$git_status" ]; then if [ ! -z "$git_status" ]; then
echo "$git_status" echo "$git_status"
echo "git repo not clean, aborting" fail "git repo not clean, aborting"
exit 1
fi fi
set -ex set -x
# create tarball # create tarball
target=Electrum-$VERSION.tar.gz tarball="Electrum-$VERSION.tar.gz"
if test -f dist/$target; then if test -f "dist/$tarball"; then
echo "file exists: $target" info "file exists: $tarball"
else else
./contrib/build-linux/sdist/build.sh ./contrib/build-linux/sdist/build.sh
fi fi
# appimage # appimage
if [ $REV != $VERSION ]; then appimage="electrum-$REV-x86_64.AppImage"
target=electrum-${REV:0:-2}-x86_64.AppImage if test -f "dist/$appimage"; then
else info "file exists: $appimage"
target=electrum-$REV-x86_64.AppImage
fi
if test -f dist/$target; then
echo "file exists: $target"
else else
./contrib/build-linux/appimage/build.sh ./contrib/build-linux/appimage/build.sh
fi fi
# windows # windows
target=electrum-$REV.exe win1="electrum-$REV.exe"
if test -f dist/$target; then win2="electrum-$REV-portable.exe"
echo "file exists: $target" win3="electrum-$REV-setup.exe"
if test -f "dist/$win1"; then
info "file exists: $win1"
else else
pushd . pushd .
./contrib/build-wine/build.sh ./contrib/build-wine/build.sh
cd contrib/build-wine/ if [ ! -z "$RELEASEMANAGER" ] ; then
./sign.sh cd contrib/build-wine/
cp ./signed/*.exe /opt/electrum/dist/ ./sign.sh
cp ./signed/*.exe "$PROJECT_ROOT/dist/"
fi
popd popd
fi fi
# android # android
target1=Electrum-$VERSION.0-armeabi-v7a-release.apk apk1="Electrum-$VERSION.0-armeabi-v7a-release.apk"
target2=Electrum-$VERSION.0-arm64-v8a-release.apk apk2="Electrum-$VERSION.0-arm64-v8a-release.apk"
if test -f "dist/$apk1"; then
if test -f dist/$target1; then info "file exists: $apk1"
echo "file exists: $target1"
else else
./contrib/android/build.sh release if [ ! -z "$RELEASEMANAGER" ] ; then
./contrib/android/build.sh release
else
./contrib/android/build.sh release-unsigned
fi
fi fi
# wait for dmg before signing # wait for dmg before signing
if test -f dist/electrum-$VERSION.dmg; then dmg=electrum-$VERSION.dmg
if test -f dist/electrum-$VERSION.dmg.asc; then if [ ! -z "$RELEASEMANAGER" ] ; then
echo "packages are already signed" if test -f "dist/$dmg"; then
if test -f "dist/$dmg.asc"; then
info "packages are already signed"
else
info "signing packages"
./contrib/sign_packages "$GPGUSER"
fi
else else
echo "signing packages" fail "dmg is missing, aborting"
./contrib/sign_packages ThomasV
fi fi
else
echo "dmg is missing, aborting"
exit 1
fi fi
echo "build complete" info "build complete"
sha256sum dist/*.tar.gz sha256sum dist/*.tar.gz
sha256sum dist/*.AppImage sha256sum dist/*.AppImage
sha256sum contrib/build-wine/dist/*.exe sha256sum contrib/build-wine/dist/*.exe
@ -110,32 +157,84 @@ if [ "$answer" != "y" ] ;then
fi fi
echo "updating www repo" if [ -z "$RELEASEMANAGER" ] ; then
./contrib/make_download $WWW_DIR # people OTHER THAN release manager.
echo "signing the version file" # download binaries built by RM
sig=`./run_electrum -o signmessage $ELECTRUM_SIGNING_ADDRESS $VERSION -w $ELECTRUM_SIGNING_WALLET` rm -rf "$PROJECT_ROOT/dist/releasemanager"
echo "{ \"version\":\"$VERSION\", \"signatures\":{ \"$ELECTRUM_SIGNING_ADDRESS\":\"$sig\"}}" > $WWW_DIR/version mkdir --parent "$PROJECT_ROOT/dist/releasemanager"
cd "$PROJECT_ROOT/dist/releasemanager"
# TODO check somehow that RM had finished uploading
sftp -oBatchMode=no -b - "$SSHUSER@uploadserver" << !
cd electrum-downloads-airlock
cd "$VERSION"
mget *
bye
!
# check we have each binary
test -f "$tarball" || fail "tarball not found among sftp downloads"
test -f "$appimage" || fail "appimage not found among sftp downloads"
test -f "$win1" || fail "win1 not found among sftp downloads"
test -f "$win2" || fail "win2 not found among sftp downloads"
test -f "$win3" || fail "win3 not found among sftp downloads"
test -f "$apk1" || fail "apk1 not found among sftp downloads"
test -f "$apk2" || fail "apk2 not found among sftp downloads"
test -f "$PROJECT_ROOT/dist/$tarball" || fail "tarball not found among built files"
test -f "$PROJECT_ROOT/dist/$appimage" || fail "appimage not found among built files"
test -f "$CONTRIB/build-wine/dist/$win1" || fail "win1 not found among built files"
test -f "$CONTRIB/build-wine/dist/$win2" || fail "win2 not found among built files"
test -f "$CONTRIB/build-wine/dist/$win3" || fail "win3 not found among built files"
test -f "$PROJECT_ROOT/dist/$apk1" || fail "apk1 not found among built files"
test -f "$PROJECT_ROOT/dist/$apk2" || fail "apk2 not found among built files"
# compare downloaded binaries against ones we built
cmp --silent "$tarball" "$PROJECT_ROOT/dist/$tarball" || fail "files are different. tarball."
cmp --silent "$appimage" "$PROJECT_ROOT/dist/$appimage" || fail "files are different. appimage."
mkdir --parents "$CONTRIB/build-wine/signed/"
cp -f "$win1" "$win2" "$win3" "$CONTRIB/build-wine/signed/"
"$CONTRIB/build-wine/unsign.sh" || fail "files are different. windows."
"$CONTRIB/android/apkdiff.py" "$apk1" "$PROJECT_ROOT/dist/$apk1" || fail "files are different. android."
"$CONTRIB/android/apkdiff.py" "$apk2" "$PROJECT_ROOT/dist/$apk2" || fail "files are different. android."
# all files matched. sign them.
rm -rf "$PROJECT_ROOT/dist/sigs/"
mkdir --parents "$PROJECT_ROOT/dist/sigs/"
for fname in "$tarball" "$appimage" "$win1" "$win2" "$win3" "$apk1" "$apk2" ; do
signame="$fname.$GPGUSER.asc"
gpg --sign --armor --detach $PUBKEY --output "$PROJECT_ROOT/dist/sigs/$signame" "$fname"
done
# upload sigs
ELECBUILD_UPLOADFROM="$PROJECT_ROOT/dist/sigs/" "$CONTRIB/upload"
else
# ONLY release manager
if [ $REV != $VERSION ]; then cd "$PROJECT_ROOT"
echo "versions differ, not uploading"
exit 1 info "updating www repo"
fi ./contrib/make_download $WWW_DIR
info "signing the version announcement file"
sig=`./run_electrum -o signmessage $ELECTRUM_SIGNING_ADDRESS $VERSION -w $ELECTRUM_SIGNING_WALLET`
info "{ \"version\":\"$VERSION\", \"signatures\":{ \"$ELECTRUM_SIGNING_ADDRESS\":\"$sig\"}}" > $WWW_DIR/version
# upload the files
if test -f dist/uploaded; then
echo "files already uploaded"
else
./contrib/upload
touch dist/uploaded
fi
if [ $REV != $VERSION ]; then
fail "versions differ, not uploading"
fi
# upload the files
if test -f dist/uploaded; then
info "files already uploaded"
else
./contrib/upload
touch dist/uploaded
fi
# push changes to website repo
pushd $WWW_DIR
git diff
git commit -a -m "version $VERSION"
git push
popd
fi
# push changes to website repo
pushd $WWW_DIR
git diff
git commit -a -m "version $VERSION"
git push
popd
echo "run $WWW_DIR/publish.sh to sign the website commit and upload signature" info "release.sh finished successfully."
info "now you should run WWW_DIR/publish.sh to sign the website commit and upload signature"

8
contrib/sign_packages

@ -4,9 +4,9 @@ import os, sys
if __name__ == '__main__': if __name__ == '__main__':
username = sys.argv[1] username = sys.argv[1]
os.chdir("dist") os.chdir("dist")
for name in os.listdir('.'): for fname in os.listdir('.'):
if name.endswith('asc'): if fname.endswith('asc'):
continue continue
sig_name = name + '.' + username + '.asc' sig_name = fname + '.' + username + '.asc'
os.system("gpg --sign --armor --detach --output %s %s"%(sig_name, name)) os.system(f"gpg --sign --armor --detach --output {sig_name} {fname}")
os.chdir("..") os.chdir("..")

26
contrib/upload

@ -1,18 +1,34 @@
#!/bin/bash #!/bin/bash
# uploadserver is set in /etc/hosts # uploadserver is set in /etc/hosts
#
# env vars:
# - ELECBUILD_UPLOADFROM
# - SSHUSER
set -e set -e
PROJECT_ROOT="$(dirname "$(readlink -e "$0")")/.."
if [ -z "$SSHUSER" ]; then
SSHUSER=thomasv
fi
cd "$PROJECT_ROOT"
version=`git describe --tags --abbrev=0` version=`git describe --tags --abbrev=0`
echo $version echo $version
here=$(dirname "$0") if [ -z "$ELECBUILD_UPLOADFROM" ]; then
cd $here/../dist cd "$PROJECT_ROOT/../dist"
else
cd "$ELECBUILD_UPLOADFROM"
fi
sftp -oBatchMode=no -b - thomasv@uploadserver << ! sftp -oBatchMode=no -b - "$SSHUSER@uploadserver" << !
cd electrum-downloads-airlock cd electrum-downloads-airlock
mkdir $version mkdir --parents "$version"
cd $version cd "$version"
mput * mput *
bye bye
! !

Loading…
Cancel
Save