2021-07-28 02:04:35 +08:00
|
|
|
#!/bin/bash
|
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
LINUXDEPLOY_URL="https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage"
|
2021-09-15 20:13:26 +08:00
|
|
|
PYTHON_VERSION="3.7.12"
|
2021-07-28 02:04:35 +08:00
|
|
|
PYTHON_APPIMAGE_URL="https://github.com/niess/python-appimage/releases/download/python3.7/python${PYTHON_VERSION}-cp37-cp37m-manylinux1_x86_64.AppImage"
|
|
|
|
APPIMAGE_DIR="$(realpath $(dirname $BASH_SOURCE[0]))"
|
2021-07-29 03:54:20 +08:00
|
|
|
APPDIR="$APPIMAGE_DIR/squashfs-root"
|
|
|
|
BUILD_DIR="$APPDIR/usr/src"
|
|
|
|
|
|
|
|
ICON_PATH="$BUILD_DIR/monkey_island/cc/ui/src/images/monkey-icon.svg"
|
|
|
|
MONGO_PATH="$BUILD_DIR/monkey_island/bin/mongodb"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
source "$APPIMAGE_DIR/../common.sh"
|
|
|
|
|
|
|
|
install_package_specific_build_prereqs() {
|
2021-07-29 03:54:20 +08:00
|
|
|
log_message "Installing linuxdeploy"
|
2021-07-28 02:04:35 +08:00
|
|
|
WORKSPACE_BIN_DIR="$1/bin"
|
2021-07-29 03:54:20 +08:00
|
|
|
LINUXDEPLOY_BIN="$WORKSPACE_BIN_DIR/linuxdeploy"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
mkdir -p "$WORKSPACE_BIN_DIR"
|
2021-07-29 03:54:20 +08:00
|
|
|
curl -L -o "$LINUXDEPLOY_BIN" "$LINUXDEPLOY_URL"
|
|
|
|
chmod u+x "$LINUXDEPLOY_BIN"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
PATH=$PATH:$WORKSPACE_BIN_DIR
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_build_dir() {
|
|
|
|
local agent_binary_dir=$1
|
|
|
|
local monkey_repo=$2
|
2021-09-15 20:13:26 +08:00
|
|
|
local deployment_type=$3
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
pushd $APPIMAGE_DIR
|
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
setup_python_37_appdir
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
mkdir -p "$BUILD_DIR"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
copy_monkey_island_to_build_dir "$monkey_repo/monkey" "$BUILD_DIR"
|
|
|
|
copy_server_config_to_build_dir
|
2021-09-15 20:13:26 +08:00
|
|
|
modify_deployment "$deployment_type" "$BUILD_DIR"
|
2021-07-29 03:54:20 +08:00
|
|
|
add_agent_binaries_to_build_dir "$agent_binary_dir" "$BUILD_DIR"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
install_monkey_island_python_dependencies
|
|
|
|
install_mongodb
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
generate_ssl_cert "$BUILD_DIR"
|
|
|
|
build_frontend "$BUILD_DIR"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
remove_python_appdir_artifacts
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
popd
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_python_37_appdir() {
|
|
|
|
PYTHON_APPIMAGE="python${PYTHON_VERSION}_x86_64.AppImage"
|
|
|
|
|
|
|
|
log_message "downloading Python3.7 Appimage"
|
|
|
|
curl -L -o "$PYTHON_APPIMAGE" "$PYTHON_APPIMAGE_URL"
|
|
|
|
|
|
|
|
chmod u+x "$PYTHON_APPIMAGE"
|
|
|
|
|
|
|
|
"./$PYTHON_APPIMAGE" --appimage-extract
|
|
|
|
rm "$PYTHON_APPIMAGE"
|
|
|
|
}
|
|
|
|
|
|
|
|
copy_server_config_to_build_dir() {
|
2021-07-29 03:54:20 +08:00
|
|
|
cp "$APPIMAGE_DIR"/server_config.json.standard "$BUILD_DIR"/monkey_island/cc/server_config.json
|
2021-07-28 02:04:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
install_monkey_island_python_dependencies() {
|
|
|
|
log_message "Installing island requirements"
|
|
|
|
|
|
|
|
log_message "Installing pipenv"
|
2021-07-29 03:54:20 +08:00
|
|
|
"$APPDIR"/AppRun -m pip install pipenv || handle_error
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
requirements_island="$BUILD_DIR/monkey_island/requirements.txt"
|
|
|
|
generate_requirements_from_pipenv_lock "$requirements_island"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
log_message "Installing island python requirements"
|
2021-07-29 03:54:20 +08:00
|
|
|
"$APPDIR"/AppRun -m pip install -r "${requirements_island}" --ignore-installed || handle_error
|
2021-07-28 02:04:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
generate_requirements_from_pipenv_lock () {
|
2021-07-29 03:54:20 +08:00
|
|
|
local requirements_island=$1
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
log_message "Generating a requirements.txt file with 'pipenv lock -r'"
|
2021-07-29 03:54:20 +08:00
|
|
|
pushd "$BUILD_DIR/monkey_island"
|
|
|
|
"$APPDIR"/AppRun -m pipenv --python "$APPDIR/AppRun" lock -r > "$requirements_island" || handle_error
|
2021-07-28 02:04:35 +08:00
|
|
|
popd
|
|
|
|
}
|
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
|
2021-07-28 02:04:35 +08:00
|
|
|
install_mongodb() {
|
|
|
|
log_message "Installing MongoDB"
|
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
mkdir -p "$MONGO_PATH"
|
|
|
|
"$BUILD_DIR/monkey_island/linux/install_mongo.sh" "${MONGO_PATH}" || handle_error
|
2021-07-28 02:04:35 +08:00
|
|
|
}
|
|
|
|
|
2021-07-29 03:54:20 +08:00
|
|
|
remove_python_appdir_artifacts() {
|
|
|
|
rm "$APPDIR"/python.png
|
|
|
|
rm "$APPDIR"/python*.desktop
|
|
|
|
rm "$APPDIR"/AppRun
|
2021-07-28 02:04:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
build_package() {
|
2021-07-28 19:53:33 +08:00
|
|
|
local version=$1
|
|
|
|
local dist_dir=$2
|
2021-07-29 03:54:20 +08:00
|
|
|
|
2021-07-28 02:04:35 +08:00
|
|
|
log_message "Building AppImage"
|
2021-10-01 03:41:37 +08:00
|
|
|
set_version "$version"
|
2021-07-28 02:04:35 +08:00
|
|
|
|
2021-10-01 03:41:37 +08:00
|
|
|
pushd "$APPIMAGE_DIR"
|
2021-07-29 03:54:20 +08:00
|
|
|
ARCH="x86_64" linuxdeploy \
|
|
|
|
--appdir "$APPIMAGE_DIR/squashfs-root" \
|
|
|
|
--icon-file "$ICON_PATH" \
|
|
|
|
--desktop-file "$APPIMAGE_DIR/infection-monkey.desktop" \
|
|
|
|
--custom-apprun "$APPIMAGE_DIR/AppRun" \
|
|
|
|
--deploy-deps-only="$MONGO_PATH/bin/mongod"\
|
|
|
|
--output appimage
|
2021-07-28 19:53:33 +08:00
|
|
|
|
2021-10-18 21:06:04 +08:00
|
|
|
dst_name="InfectionMonkey-v$version.AppImage"
|
|
|
|
move_package_to_dist_dir $dist_dir $dst_name
|
2021-07-28 02:04:35 +08:00
|
|
|
|
|
|
|
popd
|
|
|
|
}
|
|
|
|
|
2021-10-01 03:41:37 +08:00
|
|
|
set_version() {
|
|
|
|
# The linuxdeploy and appimage-builder tools will use the commit hash of the
|
|
|
|
# repo to name the AppImage, which is preferable to using "dev". If the
|
|
|
|
# version was specified in a command-line argument (i.e. not "dev"), then
|
|
|
|
# setting the VERSION environment variable will change this behavior.
|
|
|
|
if [ $1 != "dev" ]; then
|
|
|
|
export VERSION=$1
|
|
|
|
fi
|
2021-07-28 02:04:35 +08:00
|
|
|
}
|
2021-07-28 19:53:33 +08:00
|
|
|
|
|
|
|
move_package_to_dist_dir() {
|
2021-10-18 21:06:04 +08:00
|
|
|
mv Infection_Monkey*.AppImage "$1/$2"
|
2021-07-28 19:53:33 +08:00
|
|
|
}
|