Compare commits
	
		
			10 Commits
		
	
	
		
			49fa74159b
			...
			4d5f3fa809
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4d5f3fa809 | |||
| fb81443cba | |||
| 92c0217374 | |||
| 750ad05d06 | |||
| 0db9675bc4 | |||
| dd7ef19d88 | |||
| 810cbd44b7 | |||
| 2b583ad7e0 | |||
| 4a1c1e5153 | |||
| 2b55ae11f4 | 
| @ -47,6 +47,7 @@ HEALTHCHECK \ | |||||||
| # standardized labels | # standardized labels | ||||||
| MAINTAINER Asif Bacchus <asif@bacchus.cloud> | MAINTAINER Asif Bacchus <asif@bacchus.cloud> | ||||||
| LABEL maintainer="Asif Bacchus <asif@bacchus.cloud>" | LABEL maintainer="Asif Bacchus <asif@bacchus.cloud>" | ||||||
|  | LABEL dev.asifbacchus.docker.internalName="ab-nginx" | ||||||
| LABEL org.opencontainers.image.author="Asif Bacchus <asif@bacchus.cloud>" | LABEL org.opencontainers.image.author="Asif Bacchus <asif@bacchus.cloud>" | ||||||
| LABEL org.opencontainers.image.url="https://git.asifbacchus.dev/ab-docker/ab-nginx" | LABEL org.opencontainers.image.url="https://git.asifbacchus.dev/ab-docker/ab-nginx" | ||||||
| LABEL org.opencontainers.image.documentation="https://git.asifbacchus.dev/ab-docker/ab-nginx/wiki" | LABEL org.opencontainers.image.documentation="https://git.asifbacchus.dev/ab-docker/ab-nginx/wiki" | ||||||
| @ -102,7 +103,7 @@ ARG GIT_COMMIT | |||||||
| ARG INTERNAL_VERSION | ARG INTERNAL_VERSION | ||||||
| LABEL org.opencontainers.image.revision=${GIT_COMMIT} | LABEL org.opencontainers.image.revision=${GIT_COMMIT} | ||||||
| LABEL org.opencontainers.image.version=${NGINX_VERSION} | LABEL org.opencontainers.image.version=${NGINX_VERSION} | ||||||
| LABEL app.asifbacchus.docker.internalVersion=${INTERNAL_VERSION}-${NGINX_VERSION} | LABEL dev.asifbacchus.docker.internalVersion=${INTERNAL_VERSION}-${NGINX_VERSION} | ||||||
| LABEL org.opencontainers.image.created=${BUILD_DATE} | LABEL org.opencontainers.image.created=${BUILD_DATE} | ||||||
| 
 | 
 | ||||||
| #EOF | #EOF | ||||||
|  | |||||||
| @ -4,8 +4,7 @@ | |||||||
| # start ab-nginx container using params file variables | # start ab-nginx container using params file variables | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| # TODO: add stop & stop and remove commands | # | ||||||
| 
 |  | ||||||
| # text formatting presets | # text formatting presets | ||||||
| if command -v tput >/dev/null; then | if command -v tput >/dev/null; then | ||||||
|     cyan=$(tput bold)$(tput setaf 6) |     cyan=$(tput bold)$(tput setaf 6) | ||||||
| @ -23,56 +22,78 @@ else | |||||||
|     width=80 |     width=80 | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| ### parameter defaults | # | ||||||
|  | # parameter defaults | ||||||
| doShell=false | doShell=false | ||||||
|  | doStatus=false | ||||||
|  | doStop=false | ||||||
|  | removeStopped=false | ||||||
| container_name="ab-nginx" | container_name="ab-nginx" | ||||||
| NETWORK='nginx_network' | NETWORK='nginx_network' | ||||||
| SUBNET='172.31.254.0/24' | SUBNET='172.31.254.0/24' | ||||||
| HTTP_PORT=80 | HTTP_PORT=80 | ||||||
| HTTPS_PORT=443 | HTTPS_PORT=443 | ||||||
| unset CONFIG_DIR | CONFIG_DIR="" | ||||||
| unset SERVERS_DIR | SERVERS_DIR="" | ||||||
| unset WEBROOT_DIR | WEBROOT_DIR="" | ||||||
| unset vmount | volumeMounts="" | ||||||
| 
 | stopErr=0 | ||||||
| ### functions | removeErr=0 | ||||||
| 
 | 
 | ||||||
|  | # | ||||||
|  | # functions | ||||||
| checkExist() { | checkExist() { | ||||||
|     if [ "$1" = 'file' ]; then |     if [ "$1" = 'file' ]; then | ||||||
|         if [ ! -f "$2" ]; then |         if [ ! -f "$2" ]; then | ||||||
|             printf "%s\nCannot find file: '$2'. Exiting.\n%s" "$err" "$norm" |             printf "%s\nCannot find file: '$2'. Exiting.\n%s" "$err" "$norm" | ||||||
|             exit 3 |             exit 1 | ||||||
|         fi |         fi | ||||||
|     elif [ "$1" = 'dir' ]; then |     elif [ "$1" = 'dir' ]; then | ||||||
|         if [ ! -d "$2" ]; then |         if [ ! -d "$2" ]; then | ||||||
|             printf "%s\nCannot find directory: '$2'. Exiting.\n$%s" "$err" "$norm" |             printf "%s\nCannot find directory: '$2'. Exiting.\n$%s" "$err" "$norm" | ||||||
|             exit 3 |             exit 1 | ||||||
|         fi |         fi | ||||||
|     fi |     fi | ||||||
|     return 0 |     return 0 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| scriptHelp() { | scriptHelp() { | ||||||
|  |     # header and description | ||||||
|     printf "\n%s" "$magenta" |     printf "\n%s" "$magenta" | ||||||
|     printf '%.0s-' $(seq "$width") |     printf '%.0s-' $(seq "$width") | ||||||
|     printf "\n%s" "$norm" |     printf "\n%s" "$norm" | ||||||
|     textBlock "This is a simple helper script so you can avoid typing lengthy commands when working with the ab-nginx container." |     textBlock "This is a simple helper script so you can avoid typing lengthy commands when working with the ab-nginx container." | ||||||
|     textBlock "The script reads the contents of 'ab-nginx.params' and constructs various 'docker run' commands based on that file. The biggest time-saver is working with certificates. If they are specified in the params file, the script will automatically bind-mount them so nginx serves content via SSL by default." |     textBlock "The script reads the contents of 'ab-nginx.params' and constructs various 'docker run' commands based on that file. The biggest time-saver is working with certificates. If they are specified in the params file, the script will automatically bind-mount them so nginx serves content via SSL by default." | ||||||
|     newline |     newline | ||||||
|  | 
 | ||||||
|  |     # explanatory text | ||||||
|     textBlock "If you run the script with no parameters, it will execute the container 'normally': Run in detached mode with nginx automatically launched. If you specified certificates, nginx will serve over SSL by default." |     textBlock "If you run the script with no parameters, it will execute the container 'normally': Run in detached mode with nginx automatically launched. If you specified certificates, nginx will serve over SSL by default." | ||||||
|     textBlock "Note: Containers (except shell) are always set to restart 'unless-stopped'. You must remove them manually if desired." |     textBlock "Note: Containers (except shell) are always set to restart 'unless-stopped'. You must remove them manually if desired." | ||||||
|     printf "%s" "$magenta" |     printf "%s" "$magenta" | ||||||
|     newline |     newline | ||||||
|  | 
 | ||||||
|  |     # parameters | ||||||
|     textBlock "The script has the following (optional) parameters:" |     textBlock "The script has the following (optional) parameters:" | ||||||
|     textBlockParam 'parameter in cyan' 'default in yellow' |     textBlockParam 'parameter in cyan' 'default in yellow' | ||||||
|     newline |     newline | ||||||
|     textBlockParam '-n|--name' 'ab-nginx' |     textBlockParam '-n|--name' 'ab-nginx' | ||||||
|     textBlock "Set the name of the container, otherwise the default will be used." |     textBlock "Set the name of the container, otherwise the default will be used." | ||||||
|     newline |     newline | ||||||
|     textBlockParam'-s|--shell' 'off: run in detached mode' |     textBlockParam '-s|--shell' 'off: run in detached mode' | ||||||
|     textBlock "Enter the container using an interactive ASH/BusyBox shell. This happens after startup operations but *before* nginx is actually started. This is a great way to see configuration changes possibly stopping nginx from starting normally." |     textBlock "Enter the container using an interactive ASH/BusyBox shell. This happens after startup operations but *before* nginx is actually started. This is a great way to see configuration changes possibly stopping nginx from starting normally." | ||||||
|     printf "%s" "$yellow" |  | ||||||
|     newline |     newline | ||||||
|  |     textBlockParam '--status' | ||||||
|  |     textBlock "Run a search for all AB-NGINX containers and display their name and status." | ||||||
|  |     newline | ||||||
|  |     textBlockParam '--stop' | ||||||
|  |     textBlock "Stops the container specified by the '--name' parameter or with the default name 'ab-nginx'." | ||||||
|  |     newline | ||||||
|  |     textBlockParam '--remove | --stop-remove' | ||||||
|  |     textBlock "Stops and removes the container specified by the '--name' parameter or with the default name 'ab-nginx'." | ||||||
|  | 
 | ||||||
|  |     # footer | ||||||
|  |     newline | ||||||
|  |     printf "%s" "$yellow" | ||||||
|     textBlock"More information can be found at: https://git.asifbacchus.dev/ab-docker/ab-nginx/wiki" |     textBlock"More information can be found at: https://git.asifbacchus.dev/ab-docker/ab-nginx/wiki" | ||||||
|     printf "\n%s" "$magenta" |     printf "\n%s" "$magenta" | ||||||
|     printf '%.0s-' $(seq "$width") |     printf '%.0s-' $(seq "$width") | ||||||
| @ -98,7 +119,8 @@ textBlockParam() { | |||||||
|     fi |     fi | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ### pre-requisite checks | # | ||||||
|  | # pre-requisite checks | ||||||
| 
 | 
 | ||||||
| # is docker installed? | # is docker installed? | ||||||
| if ! command -v docker >/dev/null; then | if ! command -v docker >/dev/null; then | ||||||
| @ -110,10 +132,101 @@ fi | |||||||
| if [ ! "$(id -u)" -eq 0 ]; then | if [ ! "$(id -u)" -eq 0 ]; then | ||||||
|     if ! id -Gn | grep docker >/dev/null; then |     if ! id -Gn | grep docker >/dev/null; then | ||||||
|         printf "%s\nYou must either be root or in the 'docker' group to run this script since you must be able to actually start the container! Exiting.\n$%s" "$err" "$norm" |         printf "%s\nYou must either be root or in the 'docker' group to run this script since you must be able to actually start the container! Exiting.\n$%s" "$err" "$norm" | ||||||
|         exit 2 |         exit 3 | ||||||
|     fi |     fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | # | ||||||
|  | # process startup parameters | ||||||
|  | while [ $# -gt 0 ]; do | ||||||
|  |     case "$1" in | ||||||
|  |     -h | -\? | --help) | ||||||
|  |         # display help | ||||||
|  |         scriptHelp | ||||||
|  |         exit 0 | ||||||
|  |         ;; | ||||||
|  |     -s | --shell) | ||||||
|  |         # start shell instead of default CMD | ||||||
|  |         doShell=true | ||||||
|  |         ;; | ||||||
|  |     -n | --name) | ||||||
|  |         # container name | ||||||
|  |         if [ -z "$2" ]; then | ||||||
|  |             printf "%s\nNo container name specified. Exiting.\n%s" "$err" "$norm" | ||||||
|  |             exit 1 | ||||||
|  |         fi | ||||||
|  |         container_name="$2" | ||||||
|  |         shift | ||||||
|  |         ;; | ||||||
|  |     --status) | ||||||
|  |         # find containers and check their status | ||||||
|  |         doStatus=true | ||||||
|  |         ;; | ||||||
|  |     --stop) | ||||||
|  |         # stop named container | ||||||
|  |         doStop=true | ||||||
|  |         ;; | ||||||
|  |     --remove | --stop-remove) | ||||||
|  |         # stop and remove named container | ||||||
|  |         doStop=true | ||||||
|  |         removeStopped=true | ||||||
|  |         ;; | ||||||
|  |     *) | ||||||
|  |         printf "%s\nUnknown option: %s\n" "$err" "$1" | ||||||
|  |         printf "Use '--help' for valid options.\n\n%s" "$norm" | ||||||
|  |         exit 1 | ||||||
|  |         ;; | ||||||
|  |     esac | ||||||
|  |     shift | ||||||
|  | done | ||||||
|  | 
 | ||||||
|  | # | ||||||
|  | # status check | ||||||
|  | if [ "$doStatus" = "true" ]; then | ||||||
|  |     printf "\nFound the following AB-NGINX containers:\n" | ||||||
|  |     docker ps -a --filter "label=dev.asifbacchus.docker.internalName=ab-nginx" | ||||||
|  |     printf "\n" | ||||||
|  |     exit 0 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # | ||||||
|  | # stop container | ||||||
|  | if [ "$doStop" = "true" ]; then | ||||||
|  |     printf "\nStopping container '%s'... " "$container_name" | ||||||
|  | 
 | ||||||
|  |     # ensure container exists | ||||||
|  |     if ! docker inspect "$container_name" >/dev/null 2>&1; then | ||||||
|  |         printf "[ERROR]: No container with that name found.\n\n" | ||||||
|  |         exit 11 | ||||||
|  |     fi | ||||||
|  | 
 | ||||||
|  |     # stop and/or remove container | ||||||
|  |     if ! docker stop "$container_name" >/dev/null 2>&1; then stopErr=1; fi | ||||||
|  |     if [ "$removeStopped" = "true" ] && [ "$stopErr" -eq 0 ]; then | ||||||
|  |         if ! docker rm "$container_name" >/dev/null 2>&1; then removeErr=1; fi | ||||||
|  |     fi | ||||||
|  | 
 | ||||||
|  |     # update status message | ||||||
|  |     if [ "$stopErr" -eq 1 ]; then | ||||||
|  |         printf "[ERROR]: Unable to stop container. Please try removing it manually.\n\n" | ||||||
|  |         exit 12 | ||||||
|  |     fi | ||||||
|  |     if [ "$removeErr" -eq 1 ]; then | ||||||
|  |         printf "[STOPPED]\n" | ||||||
|  |         printf "[ERROR]: Unable to remove container. Please try removing it manually.\n\n" | ||||||
|  |         exit 13 | ||||||
|  |     fi | ||||||
|  |     if [ "$removeStopped" = "true" ]; then | ||||||
|  |         printf "[REMOVED]\n\n" | ||||||
|  |     else | ||||||
|  |         printf "[STOPPED]\n\n" | ||||||
|  |     fi | ||||||
|  |     exit 0 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # | ||||||
|  | # run container | ||||||
|  | 
 | ||||||
| # does the params file exist? | # does the params file exist? | ||||||
| checkExist 'file' './ab-nginx.params' | checkExist 'file' './ab-nginx.params' | ||||||
| 
 | 
 | ||||||
| @ -147,53 +260,23 @@ fi | |||||||
| 
 | 
 | ||||||
| # set up volume mounts | # set up volume mounts | ||||||
| if [ "$CONFIG_DIR" ]; then | if [ "$CONFIG_DIR" ]; then | ||||||
|     vmount="$vmount -v $CONFIG_DIR:/etc/nginx/config" |     volumeMounts="${volumeMounts} -v $CONFIG_DIR:/etc/nginx/config" | ||||||
| fi | fi | ||||||
| if [ "$SERVERS_DIR" ]; then | if [ "$SERVERS_DIR" ]; then | ||||||
|     vmount="$vmount -v $SERVERS_DIR:/etc/nginx/sites" |     volumeMounts="${volumeMounts} -v $SERVERS_DIR:/etc/nginx/sites" | ||||||
| fi | fi | ||||||
| if [ "$SNIPPETS_DIR" ]; then | if [ "$SNIPPETS_DIR" ]; then | ||||||
|     vmount="$vmount -v $SNIPPETS_DIR:/etc/nginx/snippets" |     volumeMounts="${volumeMounts} -v $SNIPPETS_DIR:/etc/nginx/snippets" | ||||||
| fi | fi | ||||||
| if [ "$WEBROOT_DIR" ]; then | if [ "$WEBROOT_DIR" ]; then | ||||||
|     vmount="$vmount -v $WEBROOT_DIR:/usr/share/nginx/html" |     volumeMounts="${volumeMounts} -v $WEBROOT_DIR:/usr/share/nginx/html" | ||||||
| fi | fi | ||||||
| # trim leading whitespace | # trim leading whitespace | ||||||
| vmount=${vmount##[[:space:]]} | volumeMounts=${volumeMounts##[[:space:]]} | ||||||
| 
 | 
 | ||||||
| # handle null HOSTNAMES | # handle null HOSTNAMES | ||||||
| if [ -z "$HOSTNAMES" ]; then HOSTNAMES="_"; fi | if [ -z "$HOSTNAMES" ]; then HOSTNAMES="_"; fi | ||||||
| 
 | 
 | ||||||
| # process startup parameters |  | ||||||
| while [ $# -gt 0 ]; do |  | ||||||
|     case "$1" in |  | ||||||
|     -h | -\? | --help) |  | ||||||
|         # display help |  | ||||||
|         scriptHelp |  | ||||||
|         exit 0 |  | ||||||
|         ;; |  | ||||||
|     -s | --shell) |  | ||||||
|         # start shell instead of default CMD |  | ||||||
|         doShell=true |  | ||||||
|         ;; |  | ||||||
|     -n | --name) |  | ||||||
|         # container name |  | ||||||
|         if [ -z "$2" ]; then |  | ||||||
|             printf "%s\nNo container name specified. Exiting.\n%s" "$err" "$norm" |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|         container_name="$2" |  | ||||||
|         shift |  | ||||||
|         ;; |  | ||||||
|     *) |  | ||||||
|         printf "%s\nUnknown option: %s\n" "$err" "$1" |  | ||||||
|         printf "Use '--help' for valid options.\n\n%s" "$norm" |  | ||||||
|         exit 1 |  | ||||||
|         ;; |  | ||||||
|     esac |  | ||||||
|     shift |  | ||||||
| done |  | ||||||
| 
 |  | ||||||
| # create network if it doesn't already exist | # create network if it doesn't already exist | ||||||
| docker network inspect ${NETWORK} >/dev/null 2>&1 || | docker network inspect ${NETWORK} >/dev/null 2>&1 || | ||||||
|     docker network create \ |     docker network create \ | ||||||
| @ -212,7 +295,7 @@ if [ -z "$SSL_CERT" ]; then | |||||||
|             --env-file ab-nginx.params \ |             --env-file ab-nginx.params \ | ||||||
|             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ |             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ | ||||||
|             -e SERVER_NAMES="$HOSTNAMES" \ |             -e SERVER_NAMES="$HOSTNAMES" \ | ||||||
|             $vmount \ |             ${volumeMounts} \ | ||||||
|             --network=${NETWORK} \ |             --network=${NETWORK} \ | ||||||
|             -p ${HTTP_PORT}:80 \ |             -p ${HTTP_PORT}:80 \ | ||||||
|             docker.asifbacchus.dev/nginx/ab-nginx:latest /bin/sh |             docker.asifbacchus.dev/nginx/ab-nginx:latest /bin/sh | ||||||
| @ -224,7 +307,7 @@ if [ -z "$SSL_CERT" ]; then | |||||||
|             --env-file ab-nginx.params \ |             --env-file ab-nginx.params \ | ||||||
|             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ |             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ | ||||||
|             -e SERVER_NAMES="$HOSTNAMES" \ |             -e SERVER_NAMES="$HOSTNAMES" \ | ||||||
|             $vmount \ |             ${volumeMounts} \ | ||||||
|             --network=${NETWORK} \ |             --network=${NETWORK} \ | ||||||
|             -p ${HTTP_PORT}:80 \ |             -p ${HTTP_PORT}:80 \ | ||||||
|             --restart unless-stopped \ |             --restart unless-stopped \ | ||||||
| @ -243,7 +326,7 @@ else | |||||||
|             --env-file ab-nginx.params \ |             --env-file ab-nginx.params \ | ||||||
|             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ |             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ | ||||||
|             -e SERVER_NAMES="$HOSTNAMES" \ |             -e SERVER_NAMES="$HOSTNAMES" \ | ||||||
|             $vmount \ |             ${volumeMounts} \ | ||||||
|             --network=${NETWORK} \ |             --network=${NETWORK} \ | ||||||
|             -v "$SSL_CERT":/certs/fullchain.pem:ro \ |             -v "$SSL_CERT":/certs/fullchain.pem:ro \ | ||||||
|             -v "$SSL_KEY":/certs/privkey.pem:ro \ |             -v "$SSL_KEY":/certs/privkey.pem:ro \ | ||||||
| @ -261,7 +344,7 @@ else | |||||||
|             --env-file ab-nginx.params \ |             --env-file ab-nginx.params \ | ||||||
|             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ |             --user="${NGINX_UID:-8080}:${NGINX_GID:-8080}" \ | ||||||
|             -e SERVER_NAMES="$HOSTNAMES" \ |             -e SERVER_NAMES="$HOSTNAMES" \ | ||||||
|             $vmount \ |             ${volumeMounts} \ | ||||||
|             --network=${NETWORK} \ |             --network=${NETWORK} \ | ||||||
|             -v "$SSL_CERT":/certs/fullchain.pem:ro \ |             -v "$SSL_CERT":/certs/fullchain.pem:ro \ | ||||||
|             -v "$SSL_KEY":/certs/privkey.pem:ro \ |             -v "$SSL_KEY":/certs/privkey.pem:ro \ | ||||||
| @ -272,5 +355,20 @@ else | |||||||
|     fi |     fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| ### exit gracefully | # | ||||||
| exit 0 | # exit with code from docker | ||||||
|  | exit "$?" | ||||||
|  | 
 | ||||||
|  | # | ||||||
|  | # exit return codes | ||||||
|  | # 0:        normal exit, no errors | ||||||
|  | # 1:        missing or invalid parameter | ||||||
|  | # 2:        cannot find docker | ||||||
|  | # 3:        incorrect permissions to access docker | ||||||
|  | # 1x:       operation errors | ||||||
|  | #   11      no container found with specified name | ||||||
|  | #   12      unable to stop container | ||||||
|  | #   13      unable to remove container | ||||||
|  | # other     refer to docker exit codes | ||||||
|  | 
 | ||||||
|  | #EOF | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user