#
##########################################
-CURDIR=$(cd $(dirname $0) && pwd -P)
-
REGISTRY=docker.automotivelinux.org
REPO=agl
NAME=worker
FLAVOUR=xds
-VERSION=3.99.1
+VERSION=4.0
# ---------------------------------------------------
# --- computed - don't touch !
DEFIMAGE=$REGISTRY/$REPO/$NAME-$FLAVOUR:$VERSION
function usage() {
- echo "Usage: $(basename $0) <instance ID> [image name]" >&2
- echo "Instance ID must be 0 or a positive integer (1,2,...)" >&2
- echo "Image name is optional: 'make show-image' is used by default to get image" >&2
- echo "Default image: $DEFIMAGE" >&2
+ echo "Usage: $(basename $0) [-h|--help] [-fr] [-id <instance container ID>] "
+ echo " [-nc] [-nuu] [-v|--volume <inpath:outpath>] [image name]"
+ echo "Image name is optional; 'docker images' is used by default to get image"
+ echo "Default image:"
+ echo " $DEFIMAGE"
+ echo ""
+ echo "Options:"
+ echo " -fr | --force-restart Force restart of xds-server service"
+ echo " -id Instance ID used to build container name, a positive integer (0,1,2,...)"
+ echo " -nuu | --no-uid-update Don't update user/group id within docker"
+ echo " -v | --volume Additional docker volume to bind, syntax is -v /InDockerPath:/HostPath "
exit 1
}
ID=""
-IMAGE=$DEFIMAGE
-FORCE=false
+IMAGE=""
+FORCE_RESTART=false
+UPDATE_UID=true
+USER_VOLUME_OPTION=""
+NO_CLEANUP=false
while [ $# -ne 0 ]; do
case $1 in
-h|--help|"")
usage
;;
- -fr|-force-restart)
- FORCE=true
+ -fr|--force-restart)
+ FORCE_RESTART=true
+ ;;
+ -nc|--no-cleanup)
+ NO_CLEANUP=true
+ ;;
+ -nuu|--no-uid-update)
+ UPDATE_UID=false
+ ;;
+ -v|--volume)
+ shift
+ if [[ "$1" =~ .*:.* ]]; then
+ USER_VOLUME_OPTION="-v $1"
+ else
+ echo "Invalid volume option, format must be /InDockerPath:/hostPath"
+ exit 1
+ fi
;;
- *[0-9]*)
+ -id)
+ shift
ID=$1
;;
*)
- IMAGE=$1
+ if [[ "$1" =~ ^[\.0-9]+$ ]]; then
+ IMAGE=$REGISTRY/$REPO/$NAME-$FLAVOUR:$1
+ else
+ IMAGE=$1
+ fi
;;
esac
shift
done
-[ "$ID" = "" ] && usage
+[ "$ID" = "" ] && ID=0
+
+# Dynamically retrieve image name
+if [ "$IMAGE" = "" ]; then
+
+ IMAGES_LIST=$(docker images $REGISTRY/$REPO/$NAME-$FLAVOUR --format '{{.Tag}}')
+ VER_NUM=$(echo "$IMAGES_LIST" | wc -l)
+ if [ $VER_NUM -gt 1 ]; then
+ echo "ERROR: more than one xds image found, please set explicitly the image to use !"
+ echo "List of found images:"
+ echo "$IMAGES_LIST"
+ exit 1
+ elif [ $VER_NUM -lt 1 ]; then
+ echo "ERROR: cannot automatically retrieve image tag for $REGISTRY/$REPO/$NAME-$FLAVOUR"
+ exit 1
+ fi
+ if [ "$IMAGES_LIST" = "" ]; then
+ echo "ERROR: cannot automatically retrieve image tag for $REGISTRY/$REPO/$NAME-$FLAVOUR"
+ usage
+ exit 1
+ fi
+
+ IMAGE=$REGISTRY/$REPO/$NAME-$FLAVOUR:$VERSION
+fi
USER=$(id -un)
echo "Using instance ID #$ID (user $(id -un))"
NAME=agl-xds-$(hostname|cut -f1 -d'.')-$ID-$USER
-MIRRORDIR=$HOME/ssd/localmirror_$ID
-XDTDIR=$HOME/ssd/xdt_$ID
-SHAREDDIR=$HOME/$DOCKER_USER/docker/share
+docker ps -a |grep "$NAME" > /dev/null
+[ "$?" = "0" ] && { echo "Image name already exist ! (use -h option to read help)"; exit 1; }
+
+XDS_WKS=$HOME/xds-workspace
+XDTDIR=$XDS_WKS/.xdt_$ID
SSH_PORT=$((2222 + ID))
WWW_PORT=$((8000 + ID))
BOOT_PORT=$((69 + ID))
NBD_PORT=$((10809 + ID))
-mkdir -p $MIRRORDIR $XDTDIR $SHAREDDIR
+# Delete container on error
+creation_done=false
+trap "cleanExit" 0 1 2 15
+cleanExit ()
+{
+ if [ "$creation_done" != "true" -a "$NO_CLEANUP" != "true" ]; then
+ docker rm -f "${NAME}" > /dev/null 2>&1
+ fi
+}
+
+### Create the new container
+mkdir -p $XDS_WKS $XDTDIR || exit 1
docker run \
--publish=${SSH_PORT}:22 \
--publish=${WWW_PORT}:8000 \
--publish=${BOOT_PORT}:69/udp \
--publish=${NBD_PORT}:10809 \
--detach=true \
- --hostname=$NAME --name=$NAME \
+ --hostname="$NAME" --name="$NAME" \
--privileged -v /sys/fs/cgroup:/sys/fs/cgroup:ro \
- -v $MIRRORDIR:/home/$DOCKER_USER/mirror \
- -v $SHAREDDIR:/home/$DOCKER_USER/share \
+ -v $XDS_WKS:/home/$DOCKER_USER/xds-workspace \
-v $XDTDIR:/xdt \
+ $USER_VOLUME_OPTION \
-it $IMAGE
+if [ "$?" != "0" ]; then
+ echo "An error was encountered while creating docker container."
+ exit 1
+fi
-if ($FORCE); then
- echo "Stoping xds-server..."
- docker exec --user $DOCKER_USER ${NAME} bash -c "/usr/local/bin/xds-server-stop.sh"
+### Ssh key
+echo "Copying your identity to container $NAME"
+echo -n wait ssh service .
+res=3
+max=30
+count=0
+while [ $res -ne 0 ] && [ $count -le $max ]; do
sleep 1
- echo "Starting xds-server..."
- docker exec --user $DOCKER_USER ${NAME} bash -c "nohup /usr/local/bin/xds-server-start.sh"
-fi
+ docker exec ${NAME} bash -c "systemctl status ssh" 2>/dev/null 1>&2
+ res=$?
+ echo -n "."
+ count=$(expr $count + 1);
+done
+echo
+
+ssh-keygen -R [localhost]:$SSH_PORT -f ~/.ssh/known_hosts
+docker exec ${NAME} bash -c "mkdir -p /home/$DOCKER_USER/.ssh"
+docker cp ~/.ssh/id_rsa.pub ${NAME}:/home/$DOCKER_USER/.ssh/authorized_keys
+docker exec ${NAME} bash -c "chown $DOCKER_USER:$DOCKER_USER -R /home/$DOCKER_USER/.ssh ;chmod 0700 /home/$DOCKER_USER/.ssh; chmod 0600 /home/$DOCKER_USER/.ssh/*"
+ssh -o StrictHostKeyChecking=no -p $SSH_PORT $DOCKER_USER@localhost exit
echo "You can now login using:"
-echo " ssh -p $SSH_PORT $DOCKER_USER@$(hostname)"
+echo " ssh -p $SSH_PORT $DOCKER_USER@localhost"
+
+
+### User / Group id
+if ($UPDATE_UID); then
+ echo -n "Setup docker user and group id to match yours "
+
+ docker exec -t ${NAME} bash -c "/bin/loginctl kill-user devel"
+ res=3
+ max=30
+ count=0
+ while [ $res -ne 1 ] && [ $count -le $max ]; do
+ sleep 1
+ docker exec ${NAME} bash -c "loginctl user-status devel |grep sd-pam" 2>/dev/null 1>&2
+ res=$?
+ echo -n "."
+ count=$(expr $count + 1);
+ done
+
+ echo -n " ."
+
+ # Set uid
+ docker exec -t ${NAME} bash -c "id $(id -u)" > /dev/null 2>&1
+ if [ "$?" = "0" -a "$(id -u)" != "1664" ]; then
+ echo "Cannot set docker devel user id to your id: conflict id $(id -u) !"
+ exit 1
+ fi
+ docker exec -t ${NAME} bash -c "usermod -u $(id -u) $DOCKER_USER" || exit 1
+ echo -n "."
+
+ # Set gid
+ docker exec -t ${NAME} bash -c "grep $(id -g) /etc/group" > /dev/null 2>&1
+ if [ "$?" = "0" ]; then
+ docker exec -t ${NAME} bash -c "usermod -g $(id -g) $DOCKER_USER" || exit 1
+ else
+ docker exec -t ${NAME} bash -c "groupmod -g $(id -g) $DOCKER_USER" || exit 1
+ fi
+ echo -n "."
+
+ docker exec -t ${NAME} bash -c "chown -R $DOCKER_USER:$DOCKER_USER /home/$DOCKER_USER" || exit 1
+ echo -n "."
+ docker exec -t ${NAME} bash -c "chown -R $DOCKER_USER:$DOCKER_USER /tmp/xds*"
+ echo -n "."
+ docker exec -t ${NAME} bash -c "systemctl start autologin"
+ echo -n "."
+ ssh -p $SSH_PORT $DOCKER_USER@localhost -- "systemctl --user start xds-server" || exit 1
+ echo "."
+ docker restart ${NAME}
+fi
+
+creation_done=true
+
+### Force xds-server restart
+if ($FORCE_RESTART); then
+ echo "Restart xds-server..."
+ ssh -p $SSH_PORT $DOCKER_USER@localhost -- "systemctl --user restart xds-server" || exit 1
+fi
+
+echo "Done, docker container $NAME is ready to be used."