build: improve appimage build script quality by addressing review comments

This commit is contained in:
Mike Salvatore 2021-04-01 12:25:06 -04:00
parent 05a368e534
commit 8278e0eb6b
2 changed files with 28 additions and 27 deletions

View File

@ -1,5 +0,0 @@
#!/bin/bash
cd ./usr/src
bash monkey_island/linux/run.sh $HOME/.monkey_island/db

View File

@ -45,13 +45,17 @@ install_pip_37() {
} }
install_nodejs() { install_nodejs() {
NODE_SRC=https://deb.nodesource.com/setup_12.x
log_message "Installing nodejs" log_message "Installing nodejs"
node_src=https://deb.nodesource.com/setup_12.x
curl -sL $node_src | sudo -E bash - curl -sL $NODE_SRC | sudo -E bash -
sudo apt-get install -y nodejs sudo apt-get install -y nodejs
} }
install_build_prereqs() { install_build_prereqs() {
sudo apt update
# appimage-builder prereqs # appimage-builder prereqs
sudo apt install -y python3 python3-pip python3-setuptools patchelf desktop-file-utils libgdk-pixbuf2.0-dev fakeroot strace sudo apt install -y python3 python3-pip python3-setuptools patchelf desktop-file-utils libgdk-pixbuf2.0-dev fakeroot strace
@ -69,8 +73,10 @@ install_appimage_builder() {
install_appimage_tool() { install_appimage_tool() {
APP_TOOL_BIN=$HOME/bin/appimagetool APP_TOOL_BIN=$HOME/bin/appimagetool
APP_TOOL_URL=https://github.com/AppImage/AppImageKit/releases/download/12/appimagetool-x86_64.AppImage
mkdir $HOME/bin mkdir $HOME/bin
curl -L -o $APP_TOOL_BIN https://github.com/AppImage/AppImageKit/releases/download/12/appimagetool-x86_64.AppImage curl -L -o $APP_TOOL_BIN $APP_TOOL_URL
chmod u+x $APP_TOOL_BIN chmod u+x $APP_TOOL_BIN
PATH=$PATH:$HOME/bin PATH=$PATH:$HOME/bin
@ -92,7 +98,7 @@ clone_monkey_repo() {
fi fi
log_message "Cloning files from git" log_message "Cloning files from git"
branch=${2:-"local-run-data-dir"} branch=${2:-"develop"}
git clone --single-branch --recurse-submodules -b "$branch" "${MONKEY_GIT_URL}" "${REPO_MONKEY_HOME}" 2>&1 || handle_error git clone --single-branch --recurse-submodules -b "$branch" "${MONKEY_GIT_URL}" "${REPO_MONKEY_HOME}" 2>&1 || handle_error
chmod 774 -R "${MONKEY_HOME}" chmod 774 -R "${MONKEY_HOME}"
@ -116,9 +122,9 @@ install_monkey_island_python_dependencies() {
log_message "Installing island requirements" log_message "Installing island requirements"
requirements_island="$ISLAND_PATH/requirements.txt" requirements_island="$ISLAND_PATH/requirements.txt"
# TODO: This is an ugly hack. PyInstaller is a build-time dependency and should # TODO: This is an ugly hack. PyInstaller and VirtualEnv are build-time
# not be installed as a runtime requirement. # dependencies and should not be installed as a runtime requirement.
sed '4d' $requirements_island | sponge $requirements_island cat $requirements_island | grep -Piv "virtualenv|pyinstaller" | sponge $requirements_island
${python_cmd} -m pip install -r "${requirements_island}" --ignore-installed --prefix /usr --root=$APPDIR || handle_error ${python_cmd} -m pip install -r "${requirements_island}" --ignore-installed --prefix /usr --root=$APPDIR || handle_error
} }