]> code.citadel.org Git - citadel-docker.git/blobdiff - run-citadel.sh
Fleshing out the command line options for run-citadel.sh
[citadel-docker.git] / run-citadel.sh
index 486a2e4a277fc22df95ea47b35c065f45b57cf8f..a763998e9862f83a88494d17e862f17e966cfcb5 100755 (executable)
@@ -5,22 +5,78 @@
 # The container expects a persistent volume called "citadel-data" in which it will keep everything.
 # The remainder of the container is ephermal and can be deleted at any time.
 
-docker run \
+
+# Parse the command line arguments
+
+migrate_mode=false
+database_cleanup_mode=false
+volume_mode=false
+bind_mode=false
+
+while getopts ":mdv:h:" o
+do
+       case "${o}" in
+               m)
+                       echo "migrate mode"
+                       migrate_mode=true
+                       ;;
+               d)
+                       echo "database cleanup mode";
+                       database_cleanup_mode=true
+                       ;;
+               v)
+                       volume_mode=true
+                       CTDL_DIR=${OPTARG}
+                       ;;
+               h)
+                       bind_mode=true
+                       CTDL_DIR=${OPTARG}
+                       ;;
+               *)
+                       echo "$0: usage: $0 [-v volume_name] [-h home_directory] [-m] [-v] container_image_name [other parameters]"
+                       exit 1
+                       ;;
+       esac
+done
+shift $((OPTIND-1))
+
+if ( ${volume_mode} && ${bind_mode} ) ; then
+       echo "$0: -v and -h cannot both be specified."
+       exit 2
+fi
+
+if ${volume_mode} ; then
+       CTDL_VOL=volume
+elif ${bind_mode} ; then
+       CTDL_VOL=bind
+else
+       volume_mode=true
+       CTDL_VOL=volume
+       CTDL_DIR=citadel-data
+fi
+
+if ( ${migrate_mode} && ${database_cleanup_mode} ) ; then
+       echo "$0: -m and -d cannot both be specified."
+       exit 3
+fi
+
+docker version >/dev/null 2>&1 || {
+       echo Docker engine is not installed on this host.
+       exit 1
+}
+
+exec docker run \
        --name citadel \
        -it \
        --rm \
-       -p 25:25 \
-       -p 80:80 \
-       -p 110:110 \
-       -p 119:119 \
-       -p 143:143 \
-       -p 443:443 \
-       -p 465:465 \
-       -p 504:504 \
-       -p 563:563 \
-       -p 587:587 \
-       -p 993:993 \
-       -p 995:995 \
-       -p 5222:5222 \
-       --mount type=bind,source=/root/citadel/citadel,target=/citadel-data \
+       --network host \
+       --mount type=${CTDL_VOL},source=${CTDL_DIR},target=/citadel-data \
        $*
+
+#      Explanation of the above options:
+#
+#      --name citadel                  Create a container named "citadel"
+#      -it                             Run in the foreground
+#      --rm                            Delete the container when it exits
+#      --network host                  Bind directly to the host's network ports instead of creating a separate interface
+#      --mount                         This identifies where on the host our persistent Citadel database is found