2016-04-10 22:33:44 -04:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -euo pipefail
|
|
|
|
|
2016-05-07 14:15:42 -05:00
|
|
|
function HELP {
|
|
|
|
echo "Build a debian package for lbry"
|
|
|
|
echo "-----"
|
|
|
|
echo "When run without any arguments, this script expects the current directory"
|
|
|
|
echo "to be the main lbry repo and it builds what is in that directory"
|
|
|
|
echo
|
|
|
|
echo "Optional arguments:"
|
|
|
|
echo
|
|
|
|
echo "-c: clone a fresh copy of the repo"
|
|
|
|
echo "-b <branch>: use the specified branch of the lbry repo"
|
|
|
|
echo "-w <web-ui-branch>: set the webui branch"
|
|
|
|
echo "-d <build-dir>: specifiy the build directory"
|
|
|
|
echo "-h: show help"
|
|
|
|
echo "-t: turn trace on"
|
|
|
|
exit 1
|
|
|
|
}
|
2016-04-10 22:33:44 -04:00
|
|
|
|
2016-05-07 14:15:42 -05:00
|
|
|
CLONE=false
|
|
|
|
BUILD_DIR=""
|
|
|
|
BRANCH=""
|
|
|
|
WEB_UI_BRANCH="master"
|
|
|
|
|
|
|
|
while getopts :hctb:w:d: FLAG; do
|
|
|
|
case $FLAG in
|
2016-05-22 22:36:56 -04:00
|
|
|
c)
|
2016-05-07 14:15:42 -05:00
|
|
|
CLONE=true
|
|
|
|
;;
|
2016-05-22 22:36:56 -04:00
|
|
|
b)
|
2016-05-07 14:15:42 -05:00
|
|
|
BRANCH=${OPTARG}
|
|
|
|
;;
|
2016-05-22 22:36:56 -04:00
|
|
|
w)
|
2016-05-07 14:15:42 -05:00
|
|
|
WEB_UI_BRANCH=${OPTARG}
|
|
|
|
;;
|
|
|
|
d)
|
|
|
|
BUILD_DIR=${OPTARG}
|
|
|
|
;;
|
|
|
|
t)
|
|
|
|
set -o xtrace
|
|
|
|
;;
|
2016-05-22 22:36:56 -04:00
|
|
|
h)
|
2016-05-07 14:15:42 -05:00
|
|
|
HELP
|
|
|
|
;;
|
|
|
|
\?) #unrecognized option - show help
|
|
|
|
echo "Option -$OPTARG not allowed."
|
|
|
|
HELP
|
|
|
|
;;
|
|
|
|
:)
|
|
|
|
echo "Option -$OPTARG requires an argument."
|
|
|
|
HELP
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
shift $((OPTIND-1))
|
|
|
|
|
|
|
|
|
|
|
|
SUDO=''
|
|
|
|
if (( $EUID != 0 )); then
|
|
|
|
SUDO='sudo'
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$CLONE" = false ]; then
|
|
|
|
if [ `basename $PWD` != "lbry" ]; then
|
|
|
|
echo "Not currently in the lbry directory. Cowardly refusing to go forward"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
SOURCE_DIR=$PWD
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "${BUILD_DIR}" ]; then
|
|
|
|
if [ "$CLONE" = true ]; then
|
|
|
|
# build in the current directory
|
|
|
|
BUILD_DIR="lbry-build-$(date +%Y%m%d-%H%M%S)"
|
|
|
|
else
|
|
|
|
BUILD_DIR="../lbry-build-$(date +%Y%m%d-%H%M%S)"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
mkdir -p "$BUILD_DIR"
|
2016-04-12 18:50:47 -04:00
|
|
|
cd "$BUILD_DIR"
|
|
|
|
|
2016-05-07 14:15:42 -05:00
|
|
|
if [ -z ${TRAVIS+x} ]; then
|
|
|
|
# if not on travis, its nice to see progress
|
|
|
|
QUIET=""
|
|
|
|
else
|
|
|
|
QUIET="-qq"
|
|
|
|
fi
|
|
|
|
|
2016-04-10 22:33:44 -04:00
|
|
|
# get the required OS packages
|
2016-05-07 14:15:42 -05:00
|
|
|
$SUDO apt-get ${QUIET} update
|
|
|
|
$SUDO apt-get ${QUIET} install -y --no-install-recommends software-properties-common
|
|
|
|
$SUDO add-apt-repository -y ppa:spotify-jyrki/dh-virtualenv
|
|
|
|
$SUDO apt-get ${QUIET} update
|
|
|
|
$SUDO apt-get ${QUIET} install -y --no-install-recommends \
|
|
|
|
build-essential git python-dev libffi-dev libssl-dev \
|
2016-05-22 22:36:56 -04:00
|
|
|
libgmp3-dev dh-virtualenv debhelper wget python-pip fakeroot
|
2016-04-10 22:33:44 -04:00
|
|
|
|
|
|
|
# need a modern version of pip (more modern than ubuntu default)
|
2016-05-07 14:15:42 -05:00
|
|
|
$SUDO pip install --upgrade pip
|
2016-07-05 14:57:48 -05:00
|
|
|
$SUDO pip install git+https://github.com/jobevers/make-deb
|
2016-04-10 22:33:44 -04:00
|
|
|
|
|
|
|
# build packages
|
2016-05-07 14:15:42 -05:00
|
|
|
#
|
|
|
|
# dpkg-buildpackage outputs its results into '..' so
|
|
|
|
# we need to move/clone lbry into the build directory
|
2016-06-10 01:38:05 -05:00
|
|
|
if [ "$CLONE" == true ]; then
|
2016-05-07 14:15:42 -05:00
|
|
|
git clone https://github.com/lbryio/lbry.git
|
2016-06-16 22:41:08 -04:00
|
|
|
else
|
|
|
|
cp -a $SOURCE_DIR lbry
|
2016-05-07 14:15:42 -05:00
|
|
|
fi
|
2016-04-10 22:33:44 -04:00
|
|
|
(
|
2016-05-07 14:15:42 -05:00
|
|
|
cd lbry
|
|
|
|
if [ -n "${BRANCH}" ]; then
|
|
|
|
git checkout "${BRANCH}"
|
|
|
|
fi
|
|
|
|
make-deb
|
|
|
|
dpkg-buildpackage -us -uc
|
2016-04-10 22:33:44 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
### insert our extra files
|
|
|
|
|
|
|
|
# extract .deb
|
|
|
|
PACKAGE="$(ls | grep '.deb')"
|
|
|
|
ar vx "$PACKAGE"
|
|
|
|
mkdir control data
|
2016-05-07 14:15:42 -05:00
|
|
|
tar -xzf control.tar.gz --directory control
|
|
|
|
|
|
|
|
# The output of the travis build is a
|
|
|
|
# tar.gz and the output locally is tar.xz.
|
|
|
|
# Instead of having tar detect the compression used, we
|
|
|
|
# could update the config to output the same in either spot.
|
|
|
|
# Unfortunately, doing so requires editting some auto-generated
|
|
|
|
# files: http://linux.spiney.org/forcing_gzip_compression_when_building_debian_packages
|
|
|
|
tar -xf data.tar.?z --directory data
|
2016-04-10 22:33:44 -04:00
|
|
|
|
2016-05-06 14:30:00 -04:00
|
|
|
PACKAGING_DIR='lbry/packaging/ubuntu'
|
|
|
|
|
|
|
|
# set web ui branch
|
2016-05-20 12:13:58 -04:00
|
|
|
sed -i "s/^WEB_UI_BRANCH='[^']\+'/WEB_UI_BRANCH='$WEB_UI_BRANCH'/" "$PACKAGING_DIR/lbry"
|
2016-05-06 14:30:00 -04:00
|
|
|
|
2016-04-10 22:33:44 -04:00
|
|
|
# add files
|
|
|
|
function addfile() {
|
|
|
|
FILE="$1"
|
|
|
|
TARGET="$2"
|
|
|
|
mkdir -p "$(dirname "data/$TARGET")"
|
2016-07-06 14:13:11 -04:00
|
|
|
cp -d "$FILE" "data/$TARGET"
|
2016-04-10 22:33:44 -04:00
|
|
|
echo "$(md5sum "data/$TARGET" | cut -d' ' -f1) $TARGET" >> control/md5sums
|
|
|
|
}
|
2016-07-06 13:34:17 -04:00
|
|
|
|
2016-09-24 15:05:29 -04:00
|
|
|
function addlink() {
|
|
|
|
SRC="$1"
|
|
|
|
TARGET="$2"
|
|
|
|
TMP="$PACKAGING_DIR/lbry-temp-symlink"
|
|
|
|
ln -s "$SRC" "$TMP"
|
|
|
|
addfile "$TMP" "$TARGET"
|
|
|
|
rm "$TMP"
|
|
|
|
}
|
|
|
|
|
2016-07-06 14:58:06 -04:00
|
|
|
# add icons
|
2016-07-06 13:34:17 -04:00
|
|
|
addfile "$PACKAGING_DIR/icons/lbry32.png" usr/share/icons/hicolor/32x32/apps/lbry.png
|
|
|
|
addfile "$PACKAGING_DIR/icons/lbry48.png" usr/share/icons/hicolor/48x48/apps/lbry.png
|
|
|
|
addfile "$PACKAGING_DIR/icons/lbry96.png" usr/share/icons/hicolor/96x96/apps/lbry.png
|
|
|
|
addfile "$PACKAGING_DIR/icons/lbry128.png" usr/share/icons/hicolor/128x128/apps/lbry.png
|
|
|
|
addfile "$PACKAGING_DIR/icons/lbry256.png" usr/share/icons/hicolor/256x256/apps/lbry.png
|
2016-04-10 22:33:44 -04:00
|
|
|
addfile "$PACKAGING_DIR/lbry.desktop" usr/share/applications/lbry.desktop
|
|
|
|
|
2016-07-06 14:58:06 -04:00
|
|
|
# add lbry executable script
|
2016-07-06 13:41:47 -04:00
|
|
|
BINPATH=usr/share/python/lbrynet/bin
|
2016-07-06 13:34:17 -04:00
|
|
|
addfile "$PACKAGING_DIR/lbry" "$BINPATH/lbry"
|
|
|
|
|
2016-09-24 15:05:29 -04:00
|
|
|
# symlink scripts into /usr/bin
|
|
|
|
for script in "lbry" "lbrynet-daemon" "lbrynet-cli" "stop-lbrynet-daemon"; do
|
|
|
|
addlink "/$BINPATH/$script" "usr/bin/$script"
|
|
|
|
done
|
2016-07-06 13:34:17 -04:00
|
|
|
|
2016-07-06 14:58:06 -04:00
|
|
|
# add lbrycrdd and lbrycrd-cli
|
|
|
|
mkdir -p "$PACKAGING_DIR/bins"
|
2016-08-09 10:06:14 -05:00
|
|
|
wget "$(curl https://api.github.com/repos/lbryio/lbrycrd/releases/latest | grep 'browser_download_url' | grep linux | cut -d'"' -f4)" --output-document "$PACKAGING_DIR/bins.zip"
|
2016-07-06 15:33:06 -04:00
|
|
|
unzip "$PACKAGING_DIR/bins.zip" -d "$PACKAGING_DIR/bins/"
|
|
|
|
addfile "$PACKAGING_DIR/bins/lbrycrdd" usr/bin/lbrycrdd
|
|
|
|
addfile "$PACKAGING_DIR/bins/lbrycrd-cli" usr/bin/lbrycrd-cli
|
2016-07-06 14:58:06 -04:00
|
|
|
|
|
|
|
# add postinstall script
|
2016-05-23 00:19:55 -04:00
|
|
|
cat "$PACKAGING_DIR/postinst_append" >> control/postinst
|
|
|
|
|
2016-07-06 19:55:01 -04:00
|
|
|
# change package name from lbrynet to lbry
|
|
|
|
sed -i 's/^Package: lbrynet/Package: lbry/' control/control
|
2016-07-07 00:18:29 -04:00
|
|
|
echo "Conflicts: lbrynet (<< 0.3.5)" >> control/control
|
|
|
|
echo "Replaces: lbrynet (<< 0.3.5)" >> control/control
|
2016-07-06 19:55:01 -04:00
|
|
|
|
2016-04-10 22:33:44 -04:00
|
|
|
# repackage .deb
|
2016-05-07 14:15:42 -05:00
|
|
|
$SUDO chown -R root:root control data
|
|
|
|
tar -czf control.tar.gz -C control .
|
|
|
|
tar -cJf data.tar.xz -C data .
|
|
|
|
$SUDO chown root:root debian-binary control.tar.gz data.tar.xz
|
2016-04-10 22:33:44 -04:00
|
|
|
ar r "$PACKAGE" debian-binary control.tar.gz data.tar.xz
|
|
|
|
|
|
|
|
# TODO: we can append to data.tar instead of extracting it all and recompressing
|
2016-05-28 10:55:15 -05:00
|
|
|
|
2016-06-10 01:38:05 -05:00
|
|
|
if [[ ! -z "${TRAVIS_BUILD_DIR+x}" ]]; then
|
|
|
|
# move it to a consistent place so that later it can be uploaded
|
|
|
|
# to the github releases page
|
2016-05-28 10:55:15 -05:00
|
|
|
mv "${PACKAGE}" "${TRAVIS_BUILD_DIR}/${PACKAGE}"
|
2016-06-10 01:38:05 -05:00
|
|
|
# want to be able to check the size of the result in the log
|
|
|
|
ls -l "${TRAVIS_BUILD_DIR}/${PACKAGE}"
|
2016-05-28 10:55:15 -05:00
|
|
|
fi
|