2016-07-05 20:48:14 +03:00
#!/bin/bash
2017-07-07 14:49:41 -07:00
#
# This script can be used to facilitate supervisor development. Its core feature is allowing
# faster development iterations by bind-mounting the local './dist' directly into the running
# supervisor container.
#
2017-07-10 09:37:36 -07:00
# Setting the '--mount-nm' flag in either 'run' or 'buildrun' action will bind-mount
2017-07-07 14:49:41 -07:00
# './node_modules/' into the running supervisor. In this case, it's up to the developer
# to make sure that the correct dependencies are installed.
#
# Usage: dindctl action [options]
#
# Actions:
2017-11-10 12:01:49 -08:00
# build build local supervisor image. By default it will be resin/amd64-supervisor:master, you can override the tag with --tag.
2017-07-10 09:37:36 -07:00
# run [options] build dind host container, run it (with name resin_supervisor_1), which will include the specified supervisor image and run it.
# buildrun [options] run 'build' and then immediately 'run' the built container.
2017-07-07 14:49:41 -07:00
# refresh recompile sources in './src' and restart supervisor container on dind host - requires --mount-dist in order to work properly.
# logs [-f] print out supervisor log files - use '-f' to follow instead, or any other arguments you'd send to journalctl.
# stop stop dind supervisor host container.
# Options:
# --arch | -a [arch] architecture of the supervisor to build (default: amd64 )
2017-07-10 09:37:36 -07:00
# --image | -i [image] image name for supervisor image to build/use ( default: resin/$ARCH-supervisor:master )
2018-02-09 11:30:15 -08:00
# --dind-image [image] image to use for the resinos-in-container host (default: resin/resinos:2.12.5_rev1-intel-nuc)
# --dind-container [name] container name suffix for the dind host container ( default: "supervisor", which will produce a container named resinos-in-container-supervisor)
2017-07-07 14:49:41 -07:00
# --mount-dist bind-mount './dist/' (where webpack stores the built js) from local development environment into supervisor container.
# --mount-nm bind-mount './node_modules/' from local development environment into supervisor container.
2018-02-09 11:30:15 -08:00
# --preload | -p use tools/dind/apps.json to preload an application image into the dind host.
2017-10-10 10:21:21 -07:00
# --config | -c [file] path to config.json, relative to tools/dind ( default: config.json )
2017-11-10 12:01:49 -08:00
# --tag | -t [tag] for the "build" action, specify the tag to build (default: master)
2018-02-09 11:30:15 -08:00
# --no-clean for the "stop" action, skip removing the data, boot and state volumes
2017-07-07 14:49:41 -07:00
#
# See README.md for examples.
#
# The script requires make and docker.
#
THIS_FILE=$0
2016-07-05 20:48:14 +03:00
set -o errexit
set -o pipefail
DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
2017-07-14 14:19:33 -03:00
SUPERVISOR_BASE_DIR="${DIR}"
2016-07-05 20:48:14 +03:00
2017-07-07 14:49:41 -07:00
ARCH="amd64"
SUPERVISOR_IMAGE="resin/${ARCH}-supervisor:master"
2018-02-09 11:30:15 -08:00
DIND_IMAGE="resin/resinos:2.12.5_rev1-intel-nuc"
MOUNT_DIST="false"
MOUNT_NODE_MODULES="false"
CONTAINER_NAME="supervisor"
2017-07-07 14:49:41 -07:00
PRELOADED_IMAGE=""
2017-07-26 15:43:44 -03:00
OPTIMIZE="true"
2017-10-10 10:21:21 -07:00
CONFIG_FILENAME="config.json"
2017-11-10 12:01:49 -08:00
TAG="master"
2018-02-09 11:30:15 -08:00
CLEAN_VOLUMES="true"
2016-07-05 20:48:14 +03:00
function showHelp {
2017-07-07 14:49:41 -07:00
cat $THIS_FILE | awk '{if(/^#/)print;else exit}' | tail -n +2 | sed 's/\#//' | sed 's|dindctl|'$THIS_FILE'|'
2016-07-05 20:48:14 +03:00
}
2017-07-07 14:49:41 -07:00
function parseOptions {
2017-07-26 14:44:09 -03:00
while [[ $# -ge 1 ]]
2016-07-05 20:48:14 +03:00
do
2017-07-07 14:49:41 -07:00
case $1 in
--mount-dist)
2018-02-09 11:30:15 -08:00
MOUNT_DIST="true"
2016-07-05 20:48:14 +03:00
;;
--mount-nm)
2018-02-09 11:30:15 -08:00
MOUNT_NODE_MODULES="true"
2017-07-07 14:49:41 -07:00
;;
-p|--preload)
PRELOADED_IMAGE="true"
;;
-i|--image)
SUPERVISOR_IMAGE="$2"
shift || { echo "--image provided not specified" && exit 1; }
;;
2017-10-10 10:21:21 -07:00
-c|--config)
CONFIG_FILENAME="$2"
shift || { echo "--config provided not specified" && exit 1; }
;;
2017-07-07 14:49:41 -07:00
--dind-image)
DIND_IMAGE="$2"
shift || { echo "--dind-image provided not specified" && exit 1; }
;;
2017-10-10 10:01:31 -07:00
--dind-container)
CONTAINER_NAME="$2"
shift || { echo "--dind-container provided not specified" && exit 1; }
;;
2017-07-07 14:49:41 -07:00
-a|--arch)
ARCH="$2"
shift || { echo "--arch provided not specified" && exit 1; }
2016-07-05 20:48:14 +03:00
;;
2017-11-10 12:01:49 -08:00
-t|--tag)
TAG="$2"
shift || { echo "--tag provided not specified" && exit 1; }
;;
-n|--no-optimize)
2017-07-26 15:43:44 -03:00
OPTIMIZE="false"
;;
2018-02-09 11:30:15 -08:00
--no-clean)
CLEAN_VOLUMES="false"
;;
2016-07-05 20:48:14 +03:00
*)
2016-07-06 12:25:48 +03:00
echo "Warning: unknown argument: $arg"
2016-07-05 20:48:14 +03:00
;;
esac
2017-07-07 14:49:41 -07:00
shift
2016-07-05 20:48:14 +03:00
done
2017-07-07 14:49:41 -07:00
}
2016-07-05 20:48:14 +03:00
2017-07-10 09:37:36 -07:00
function buildSupervisor {
2018-02-09 11:30:15 -08:00
echo "Building supervisor image for architecture $ARCH and tagging as $TAG"
2017-11-10 12:01:49 -08:00
ARCH="$ARCH" TAG="$TAG" bash automation/build.sh
2017-07-07 14:49:41 -07:00
}
function buildSupervisorSrc {
2017-07-26 15:43:44 -03:00
if [ "$OPTIMIZE" = "true" ]; then
echo "Rebuilding supervisor source"
( cd "$SUPERVISOR_BASE_DIR" && npm install && npm run build )
else
echo "Rebuilding supervisor source without optimizations"
2017-11-08 16:06:28 -08:00
( cd "$SUPERVISOR_BASE_DIR" && npm install && npm run build -- --env.noOptimize )
2017-07-26 15:43:44 -03:00
fi
2017-07-07 14:49:41 -07:00
}
function refreshSupervisorSrc {
buildSupervisorSrc
echo "Restarting the supervisor container"
2018-02-09 11:30:15 -08:00
docker exec -ti resinos-in-container-$CONTAINER_NAME systemctl restart resin-supervisor
2017-07-07 14:49:41 -07:00
}
function runDind {
2018-02-09 11:30:15 -08:00
if [ ! -f "tools/dind/resinos-in-container/resinos-in-container.sh" ]; then
git submodule update --init
fi
if [ "$MOUNT_DIST" = "true" ]; then
2017-07-07 14:49:41 -07:00
buildSupervisorSrc
echo "Running with mounted dist folder"
fi
if [ "$PRELOADED_IMAGE" = "true" ]; then
echo "Running with preloaded apps"
fi
2017-07-26 15:20:06 -03:00
if ! ( docker inspect $SUPERVISOR_IMAGE &> /dev/null ); then
echo "$SUPERVISOR_IMAGE not available locally, pulling"
docker pull $SUPERVISOR_IMAGE
fi
2017-07-07 14:49:41 -07:00
echo "Starting dind supervisor"
2016-07-05 20:48:14 +03:00
make -C "$SUPERVISOR_BASE_DIR" \
2016-07-06 01:44:03 +03:00
ARCH="$ARCH" \
2016-07-06 11:47:25 +03:00
SUPERVISOR_IMAGE="$SUPERVISOR_IMAGE" \
2018-02-09 11:30:15 -08:00
MOUNT_DIST="$MOUNT_DIST" \
MOUNT_NODE_MODULES="$MOUNT_NODE_MODULES" \
2017-07-26 14:44:09 -03:00
PRELOADED_IMAGE="$PRELOADED_IMAGE" \
2017-10-10 10:01:31 -07:00
CONTAINER_NAME="$CONTAINER_NAME" \
2017-10-10 10:21:21 -07:00
CONFIG_FILENAME="$CONFIG_FILENAME" \
2018-02-09 11:30:15 -08:00
DIND_IMAGE="$DIND_IMAGE" \
2016-07-05 20:48:14 +03:00
run-supervisor
}
2017-07-07 14:49:41 -07:00
function stopDind {
echo "Stopping dind supervisor"
2017-10-10 10:01:31 -07:00
make -C "$SUPERVISOR_BASE_DIR" CONTAINER_NAME="$CONTAINER_NAME" stop-supervisor
2018-02-09 11:30:15 -08:00
if [ "$CLEAN_VOLUMES" = "true" ]; then
cleanDind
fi
}
function cleanDind {
echo "Cleaning dind supervisor volumes"
docker volume rm "resin-boot-$CONTAINER_NAME" "resin-state-$CONTAINER_NAME" "resin-data-$CONTAINER_NAME" &> /dev/null || true
2017-07-07 14:49:41 -07:00
}
2016-07-06 12:25:48 +03:00
function logs {
2018-02-09 11:30:15 -08:00
docker exec -ti resinos-in-container-$CONTAINER_NAME journalctl $@
2016-07-06 12:25:48 +03:00
}
action="$1"
shift || true
2017-07-07 14:49:41 -07:00
if [ "$action" = "logs" ]; then
logs "$@"
else
parseOptions "$@"
case $action in
2017-07-10 09:37:36 -07:00
build)
buildSupervisor
2017-07-07 14:49:41 -07:00
;;
run)
2018-02-09 11:30:15 -08:00
stopDind
2017-07-07 14:49:41 -07:00
runDind
;;
2017-07-10 09:37:36 -07:00
buildrun)
buildSupervisor && runDind
2017-07-07 14:49:41 -07:00
;;
refresh)
refreshSupervisorSrc
;;
stop)
stopDind
;;
*)
showHelp
2017-07-26 14:44:09 -03:00
;;
2017-07-07 14:49:41 -07:00
esac
fi