2 changed files with 181 additions and 4 deletions
@ -0,0 +1,181 @@ |
|||||
|
# |
||||
|
# Note: update locale before: |
||||
|
# 1. cd /opt/electrum-locale && ./update && push |
||||
|
# 2. cd to the submodule dir, and git pull |
||||
|
# 3. cd .. && git push |
||||
|
#!/bin/bash |
||||
|
|
||||
|
ELECTRUM_DIR=/opt/electrum |
||||
|
WWW_DIR=/opt/electrum-web |
||||
|
|
||||
|
# Note: |
||||
|
# uploadserver and website are set in /etc/hosts |
||||
|
|
||||
|
cd $ELECTRUM_DIR |
||||
|
# rm -rf dist/* |
||||
|
# rm -f .buildozer |
||||
|
|
||||
|
|
||||
|
VERSION=`python3 -c "import electrum; print(electrum.version.ELECTRUM_VERSION)"` |
||||
|
echo "VERSION: $VERSION" |
||||
|
REV=`git describe --tags` |
||||
|
echo "REV: $REV" |
||||
|
|
||||
|
|
||||
|
git_status=$(git status --porcelain) |
||||
|
if [ ! -z "$git_status" ]; then |
||||
|
echo "$git_status" |
||||
|
echo "git repo not clean, aborting" |
||||
|
exit 1 |
||||
|
fi |
||||
|
|
||||
|
set -ex |
||||
|
|
||||
|
# create tarball |
||||
|
target=Electrum-$VERSION.tar.gz |
||||
|
if test -f dist/$target; then |
||||
|
echo "file exists: $target" |
||||
|
else |
||||
|
pushd . |
||||
|
sudo docker build -t electrum-sdist-builder-img contrib/build-linux/sdist |
||||
|
FRESH_CLONE=contrib/build-linux/sdist/fresh_clone && \ |
||||
|
sudo rm -rf $FRESH_CLONE && \ |
||||
|
umask 0022 && \ |
||||
|
mkdir -p $FRESH_CLONE && \ |
||||
|
cd $FRESH_CLONE && \ |
||||
|
git clone https://github.com/spesmilo/electrum.git &&\ |
||||
|
cd electrum |
||||
|
#git checkout $REV |
||||
|
sudo docker run -it \ |
||||
|
--name electrum-sdist-builder-cont \ |
||||
|
-v $PWD:/opt/electrum \ |
||||
|
--rm \ |
||||
|
--workdir /opt/electrum/contrib/build-linux/sdist \ |
||||
|
electrum-sdist-builder-img \ |
||||
|
./build.sh |
||||
|
popd |
||||
|
cp /opt/electrum/contrib/build-linux/sdist/fresh_clone/electrum/dist/$target dist/ |
||||
|
fi |
||||
|
|
||||
|
# appimage |
||||
|
if [ $REV != $VERSION ]; then |
||||
|
target=electrum-${REV:0:-2}-x86_64.AppImage |
||||
|
else |
||||
|
target=electrum-$REV-x86_64.AppImage |
||||
|
fi |
||||
|
|
||||
|
if test -f dist/$target; then |
||||
|
echo "file exists: $target" |
||||
|
else |
||||
|
sudo docker build -t electrum-appimage-builder-img contrib/build-linux/appimage |
||||
|
sudo docker run -it \ |
||||
|
--name electrum-appimage-builder-cont \ |
||||
|
-v $PWD:/opt/electrum \ |
||||
|
--rm \ |
||||
|
--workdir /opt/electrum/contrib/build-linux/appimage \ |
||||
|
electrum-appimage-builder-img \ |
||||
|
./build.sh |
||||
|
fi |
||||
|
|
||||
|
|
||||
|
# windows |
||||
|
target=electrum-$REV.exe |
||||
|
if test -f dist/$target; then |
||||
|
echo "file exists: $target" |
||||
|
else |
||||
|
pushd . |
||||
|
FRESH_CLONE=contrib/build-wine/fresh_clone && \ |
||||
|
sudo rm -rf $FRESH_CLONE && \ |
||||
|
mkdir -p $FRESH_CLONE && \ |
||||
|
cd $FRESH_CLONE && \ |
||||
|
git clone https://github.com/spesmilo/electrum.git && \ |
||||
|
cd electrum |
||||
|
#git checkout $REV |
||||
|
sudo docker run -it \ |
||||
|
--name electrum-wine-builder-cont \ |
||||
|
-v $PWD:/opt/wine64/drive_c/electrum \ |
||||
|
--rm \ |
||||
|
--workdir /opt/wine64/drive_c/electrum/contrib/build-wine \ |
||||
|
electrum-wine-builder-img \ |
||||
|
./build.sh |
||||
|
# do this in the fresh clone directorry! |
||||
|
cd contrib/build-wine/ |
||||
|
./sign.sh |
||||
|
cp ./signed/*.exe /opt/electrum/dist/ |
||||
|
popd |
||||
|
fi |
||||
|
|
||||
|
# android |
||||
|
target1=Electrum-$VERSION.0-armeabi-v7a-release.apk |
||||
|
target2=Electrum-$VERSION.0-arm64-v8a-release.apk |
||||
|
|
||||
|
if test -f dist/$target1; then |
||||
|
echo "file exists: $target" |
||||
|
else |
||||
|
./contrib/make_packages |
||||
|
sudo docker build -t electrum-android-builder-img contrib/android |
||||
|
|
||||
|
mkdir --parents $PWD/.buildozer/.gradle |
||||
|
sudo docker run -it --rm \ |
||||
|
--name electrum-android-builder-cont \ |
||||
|
-v $PWD:/home/user/wspace/electrum \ |
||||
|
-v $PWD/.buildozer/.gradle:/home/user/.gradle \ |
||||
|
-v ~/.keystore:/home/user/.keystore \ |
||||
|
--workdir /home/user/wspace/electrum \ |
||||
|
electrum-android-builder-img \ |
||||
|
./contrib/android/make_apk release |
||||
|
|
||||
|
cp bin/$target1 dist/ |
||||
|
cp bin/$target2 dist/ |
||||
|
|
||||
|
fi |
||||
|
|
||||
|
# wait for dmg before signing |
||||
|
if test -f dist/electrum-$VERSION.dmg; then |
||||
|
if test -f dist/electrum-$VERSION.dmg.asc; then |
||||
|
echo "packages are already signed" |
||||
|
else |
||||
|
echo "signing packages" |
||||
|
./contrib/sign_packages |
||||
|
fi |
||||
|
else |
||||
|
echo "dmg is missing, aborting" |
||||
|
exit 1 |
||||
|
fi |
||||
|
|
||||
|
|
||||
|
|
||||
|
echo "updating www repo" |
||||
|
./contrib/make_download $WWW_DIR |
||||
|
echo "signing the version file" |
||||
|
sig=`./run_electrum -o signmessage $ELECTRUM_SIGNING_ADDRESS $VERSION -w $ELECTRUM_SIGNING_WALLET` |
||||
|
echo "{ \"version\":\"$VERSION\", \"signatures\":{ \"$ELECTRUM_SIGNING_ADDRESS\":\"$sig\"}}" > $WWW_DIR/version |
||||
|
|
||||
|
|
||||
|
if [ $REV != $VERSION ]; then |
||||
|
echo "versions differ, not uploading" |
||||
|
exit 1 |
||||
|
fi |
||||
|
|
||||
|
# upload the files |
||||
|
if test -f dist/uploaded; then |
||||
|
echo "files already uploaded" |
||||
|
else |
||||
|
./contrib/upload uploadserver |
||||
|
touch dist/uploaded |
||||
|
fi |
||||
|
|
||||
|
#exit 0 |
||||
|
|
||||
|
# push changes to website |
||||
|
pushd $WWW_DIR |
||||
|
git diff |
||||
|
git commit -a -m "version $VERSION" |
||||
|
git push |
||||
|
popd |
||||
|
|
||||
|
# update webserver: |
||||
|
echo "to deploy, type:" |
||||
|
echo "ssh root@website \"cd /var/www/new; git pull github master\"" |
||||
|
|
||||
|
# clear cloudflare cache |
@ -1,4 +0,0 @@ |
|||||
#!/bin/bash |
|
||||
version=`python3 -c "import electrum; print(electrum.version.ELECTRUM_VERSION)"` |
|
||||
sig=`./run_electrum -o signmessage $SIGNING_ADDRESS $version -w $SIGNING_WALLET` |
|
||||
echo "{ \"version\":\"$version\", \"signatures\":{ \"$SIGNING_ADDRESS\":\"$sig\"}}" |
|
Loading…
Reference in new issue