mirror of
https://github.com/casjaysdevdocker/gotify
synced 2025-01-18 12:34:39 -05:00
🗃️ Committing everything that changed 🗃️
rootfs/usr/local/bin/entrypoint.sh rootfs/usr/local/etc/docker/functions/entrypoint.sh
This commit is contained in:
parent
388a12f112
commit
14e5e71ffc
@ -1,13 +1,13 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
# shellcheck shell=bash
|
# shellcheck shell=bash
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
##@Version : 202407271336-git
|
##@Version : 202408011327-git
|
||||||
# @@Author : Jason Hempstead
|
# @@Author : Jason Hempstead
|
||||||
# @@Contact : jason@casjaysdev.pro
|
# @@Contact : jason@casjaysdev.pro
|
||||||
# @@License : WTFPL
|
# @@License : WTFPL
|
||||||
# @@ReadME : entrypoint.sh --help
|
# @@ReadME : entrypoint.sh --help
|
||||||
# @@Copyright : Copyright: (c) 2024 Jason Hempstead, Casjays Developments
|
# @@Copyright : Copyright: (c) 2024 Jason Hempstead, Casjays Developments
|
||||||
# @@Created : Saturday, Jul 27, 2024 13:36 EDT
|
# @@Created : Thursday, Aug 01, 2024 13:27 EDT
|
||||||
# @@File : entrypoint.sh
|
# @@File : entrypoint.sh
|
||||||
# @@Description : Entrypoint file for gotify
|
# @@Description : Entrypoint file for gotify
|
||||||
# @@Changelog : New script
|
# @@Changelog : New script
|
||||||
@ -35,6 +35,7 @@ PATH="/usr/local/etc/docker/bin:/usr/local/bin:/usr/bin:/usr/sbin:/bin:/sbin"
|
|||||||
SCRIPT_FILE="$0"
|
SCRIPT_FILE="$0"
|
||||||
CONTAINER_NAME="gotify"
|
CONTAINER_NAME="gotify"
|
||||||
SCRIPT_NAME="$(basename "$SCRIPT_FILE" 2>/dev/null)"
|
SCRIPT_NAME="$(basename "$SCRIPT_FILE" 2>/dev/null)"
|
||||||
|
CONTAINER_NAME="${ENV_CONTAINER_NAME:-$CONTAINER_NAME}"
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# remove whitespaces from beginning argument
|
# remove whitespaces from beginning argument
|
||||||
while :; do [ "$1" = " " ] && shift 1 || break; done
|
while :; do [ "$1" = " " ] && shift 1 || break; done
|
||||||
@ -50,6 +51,17 @@ else
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
case "$1" in
|
||||||
|
# Help message
|
||||||
|
--help)
|
||||||
|
shift 1
|
||||||
|
echo 'Docker container for '$CONTAINER_NAME''
|
||||||
|
echo "Usage: $CONTAINER_NAME [cron exec start init shell certbot ssl procs ports healthcheck backup command]"
|
||||||
|
echo ""
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# Create the default env files
|
# Create the default env files
|
||||||
__create_env_file "/config/env/default.sh" "/root/env.sh" &>/dev/null
|
__create_env_file "/config/env/default.sh" "/root/env.sh" &>/dev/null
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
@ -183,8 +195,10 @@ mkdir -p "/data/logs"
|
|||||||
mkdir -p "/run/init.d"
|
mkdir -p "/run/init.d"
|
||||||
mkdir -p "/config/enable"
|
mkdir -p "/config/enable"
|
||||||
mkdir -p "/config/secure"
|
mkdir -p "/config/secure"
|
||||||
|
mkdir -p "/usr/local/etc/docker/exec"
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# create required files
|
# create required files
|
||||||
|
touch "/data/logs/start.log"
|
||||||
touch "/data/logs/entrypoint.log"
|
touch "/data/logs/entrypoint.log"
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# fix permissions
|
# fix permissions
|
||||||
@ -196,12 +210,12 @@ chmod -f 777 "/var/tmp"
|
|||||||
chmod -f 777 "/run/cron"
|
chmod -f 777 "/run/cron"
|
||||||
chmod -f 777 "/data/logs"
|
chmod -f 777 "/data/logs"
|
||||||
chmod -f 777 "/run/init.d"
|
chmod -f 777 "/run/init.d"
|
||||||
chmod -f 666 "/dev/stderr"
|
|
||||||
chmod -f 666 "/dev/stdout"
|
|
||||||
chmod -f 777 "/config/enable"
|
chmod -f 777 "/config/enable"
|
||||||
chmod -f 777 "/config/secure"
|
chmod -f 777 "/config/secure"
|
||||||
chmod -f 777 "/data/logs/entrypoint.log"
|
chmod -f 777 "/data/logs/entrypoint.log"
|
||||||
|
chmod -f 777 "/usr/local/etc/docker/exec"
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
# lets ensure everyone can write to std*
|
||||||
[ -f "/dev/stdin" ] && chmod -f 777 "/dev/stdin"
|
[ -f "/dev/stdin" ] && chmod -f 777 "/dev/stdin"
|
||||||
[ -f "/dev/stderr" ] && chmod -f 777 "/dev/stderr"
|
[ -f "/dev/stderr" ] && chmod -f 777 "/dev/stderr"
|
||||||
[ -f "/dev/stdout" ] && chmod -f 777 "/dev/stdout"
|
[ -f "/dev/stdout" ] && chmod -f 777 "/dev/stdout"
|
||||||
@ -352,19 +366,11 @@ if [ "$START_SERVICES" = "yes" ] && [ "$1" != "backup" ] && [ "$1" != "healthche
|
|||||||
echo "$$" >"/run/init.d/entrypoint.pid"
|
echo "$$" >"/run/init.d/entrypoint.pid"
|
||||||
__start_init_scripts "/usr/local/etc/docker/init.d"
|
__start_init_scripts "/usr/local/etc/docker/init.d"
|
||||||
START_SERVICES="no"
|
START_SERVICES="no"
|
||||||
CONTAINER_INIT="no"
|
CONTAINER_INIT="${CONTAINER_INIT:-no}"
|
||||||
fi
|
fi
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# Begin options
|
# Begin options
|
||||||
case "$1" in
|
case "$1" in
|
||||||
# Help message
|
|
||||||
--help)
|
|
||||||
echo 'Docker container for '$APPNAME''
|
|
||||||
echo "Usage: $APPNAME [cron exec start init shell certbot ssl procs ports healthcheck backup command]"
|
|
||||||
echo ""
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
|
|
||||||
init)
|
init)
|
||||||
shift 1
|
shift 1
|
||||||
echo "Container has been Initialized"
|
echo "Container has been Initialized"
|
||||||
@ -501,7 +507,7 @@ start)
|
|||||||
if [ $# -eq 0 ]; then
|
if [ $# -eq 0 ]; then
|
||||||
if [ ! -f "/run/init.d/entrypoint.pid" ]; then
|
if [ ! -f "/run/init.d/entrypoint.pid" ]; then
|
||||||
echo "$$" >"/run/init.d/entrypoint.pid"
|
echo "$$" >"/run/init.d/entrypoint.pid"
|
||||||
__start_init_scripts "/usr/local/etc/docker/init.d"
|
[ "$START_SERVICES" = "no" ] && [ "$CONTAINER_INIT" = "yes" ] || __start_init_scripts "/usr/local/etc/docker/init.d"
|
||||||
fi
|
fi
|
||||||
__no_exit
|
__no_exit
|
||||||
else
|
else
|
||||||
|
@ -42,10 +42,10 @@ __printf_space() {
|
|||||||
string2=${string2:1}
|
string2=${string2:1}
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__cd() { [ -d "$1" ] && builtin cd "$1" || return 1; }
|
|
||||||
__rm() { [ -n "$1" ] && [ -e "$1" ] && rm -Rf "${1:?}"; }
|
__rm() { [ -n "$1" ] && [ -e "$1" ] && rm -Rf "${1:?}"; }
|
||||||
__grep_test() { grep -s "$1" "$2" | grep -qwF "${3:-$1}" || return 1; }
|
__grep_test() { grep -s "$1" "$2" | grep -qwF "${3:-$1}" || return 1; }
|
||||||
__netstat() { [ -f "$(type -P netstat)" ] && netstat "$@" || return 10; }
|
__netstat() { [ -f "$(type -P netstat)" ] && netstat "$@" || return 10; }
|
||||||
|
__cd() { { [ -d "$1" ] || mkdir -p "$1"; } && builtin cd "$1" || return 1; }
|
||||||
__is_in_file() { [ -e "$2" ] && grep -Rsq "$1" "$2" && return 0 || return 1; }
|
__is_in_file() { [ -e "$2" ] && grep -Rsq "$1" "$2" && return 0 || return 1; }
|
||||||
__curl() { curl -q -sfI --max-time 3 -k -o /dev/null "$@" &>/dev/null || return 10; }
|
__curl() { curl -q -sfI --max-time 3 -k -o /dev/null "$@" &>/dev/null || return 10; }
|
||||||
__find() { find "$1" -mindepth 1 -type ${2:-f,d} 2>/dev/null | grep '^' || return 10; }
|
__find() { find "$1" -mindepth 1 -type ${2:-f,d} 2>/dev/null | grep '^' || return 10; }
|
||||||
@ -74,9 +74,7 @@ __clean_variables() {
|
|||||||
printf '%s' "$var" | grep -v '^$'
|
printf '%s' "$var" | grep -v '^$'
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__no_exit() {
|
__no_exit() { [ -f "/run/no_exit.pid" ] || exec bash -c "trap 'sleep 1;rm -Rf /run/no_exit.pid;exit 0' TERM INT;(while true; do echo $$ >/run/no_exit.pid;tail -qf /data/logs/start.log 2>/dev/null||sleep 20; done) & wait"; }
|
||||||
[ -f "/run/no_exit.pid" ] || exec /bin/sh -c "trap 'sleep 1;rm -Rf /run/no_exit.pid;exit 0' TERM INT;(while true; do echo $$ >/run/no_exit.pid;tail -qf /data/logs/entrypoint.log /data/logs/*/*log 2>/dev/null||sleep 20; done) & wait"
|
|
||||||
}
|
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__trim() {
|
__trim() {
|
||||||
local var="${*//;/ }"
|
local var="${*//;/ }"
|
||||||
@ -103,6 +101,32 @@ __find_mongodb_conf() { return; }
|
|||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__random_password() { cat "/dev/urandom" | tr -dc '0-9a-zA-Z' | head -c${1:-16} && echo ""; }
|
__random_password() { cat "/dev/urandom" | tr -dc '0-9a-zA-Z' | head -c${1:-16} && echo ""; }
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
__init_working_dir() {
|
||||||
|
local service_name="$SCRIPT_NAME" # get service name
|
||||||
|
local workdir="$(eval echo "${WORK_DIR:-}")" # expand variables
|
||||||
|
local home="$(eval echo "${workdir//\/root/\/tmp\/docker}")" # expand variables
|
||||||
|
# set working directories
|
||||||
|
[ "$home" = "$workdir" ] && workdir=""
|
||||||
|
[ "$home" = "/root" ] && home="/tmp/$service_name"
|
||||||
|
[ -z "$home" ] && home="${workdir:-/tmp/$service_name}"
|
||||||
|
# Change to working directory
|
||||||
|
[ -n "$WORK_DIR" ] && [ -n "$EXEC_CMD_BIN" ] && workdir="$WORK_DIR"
|
||||||
|
[ -z "$WORK_DIR" ] && [ "$HOME" = "/root" ] && [ "$RUNAS_USER" != "root" ] && [ "$PWD" != "/tmp" ] && home="${workdir:-$home}"
|
||||||
|
[ -z "$WORK_DIR" ] && [ "$HOME" = "/root" ] && [ "$SERVICE_USER" != "root" ] && [ "$PWD" != "/tmp" ] && home="${workdir:-$home}"
|
||||||
|
# create needed directories
|
||||||
|
[ -n "$home" ] && { [ -d "$home" ] || { mkdir -p "$home" && chown -Rf $SERVICE_USER:$SERVICE_GROUP "$home"; }; }
|
||||||
|
[ -n "$workdir" ] && { [ -d "$workdir" ] || { mkdir -p "$workdir" && chown -Rf $SERVICE_USER:$SERVICE_GROUP "$workdir"; }; }
|
||||||
|
[ "$SERVICE_USER" = "root " ] || [ -d "$home" ] && chmod -f 777 "$home"
|
||||||
|
[ "$SERVICE_USER" = "root " ] || [ -d "$workdir" ] && chmod -f 777 "$workdir"
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
# cd to dir
|
||||||
|
__cd "${workdir:-$home}"
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
__printf_space "40" "Setting the working directory to:" "$PWD"
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
export WORK_DIR="$workdir" HOME="$home"
|
||||||
|
}
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__exec_service() {
|
__exec_service() {
|
||||||
echo "Starting $1"
|
echo "Starting $1"
|
||||||
eval "$@" 2>>/dev/stderr &
|
eval "$@" 2>>/dev/stderr &
|
||||||
@ -166,6 +190,17 @@ __certbot() {
|
|||||||
return $statusCode
|
return $statusCode
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
__init_config_etc() {
|
||||||
|
if [ ! -d "$CONF_DIR" ] || __is_dir_empty "$CONF_DIR"; then
|
||||||
|
if [ -d "$ETC_DIR" ]; then
|
||||||
|
mkdir -p "$CONF_DIR"
|
||||||
|
__copy_templates "$ETC_DIR/." "$CONF_DIR/"
|
||||||
|
else
|
||||||
|
__copy_templates "$ETC_DIR" "$CONF_DIR"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
}
|
||||||
__create_ssl_cert() {
|
__create_ssl_cert() {
|
||||||
local SSL_DIR="${SSL_DIR:-/etc/ssl}"
|
local SSL_DIR="${SSL_DIR:-/etc/ssl}"
|
||||||
if ! __certbot create; then
|
if ! __certbot create; then
|
||||||
@ -286,7 +321,7 @@ __cron() {
|
|||||||
eval "$command"
|
eval "$command"
|
||||||
sleep $interval
|
sleep $interval
|
||||||
[ -f "/run/cron/$cmd" ] || break
|
[ -f "/run/cron/$cmd" ] || break
|
||||||
done |& tee -p /data/logs/cron.log
|
done 2>/dev/stderr | tee -p /data/logs/cron.log >/dev/null
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__replace() {
|
__replace() {
|
||||||
@ -340,7 +375,7 @@ __file_copy() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
printf '%s\n' "$from does not exist"
|
printf '%s\n' "$from does not exist" >&2
|
||||||
return 2
|
return 2
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -358,41 +393,39 @@ __generate_random_uids() {
|
|||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__setup_directories() {
|
__setup_directories() {
|
||||||
|
APPLICATION_DIRS="${APPLICATION_DIRS//,/ }"
|
||||||
|
APPLICATION_FILES="${APPLICATION_FILES//,/ }"
|
||||||
|
ADD_APPLICATION_DIRS="${ADD_APPLICATION_DIRS//,/ }"
|
||||||
|
ADD_APPLICATION_FILES="${ADD_APPLICATION_FILES//,/ }"
|
||||||
# Setup WWW_ROOT_DIR
|
# Setup WWW_ROOT_DIR
|
||||||
if [ "$IS_WEB_SERVER" = "yes" ]; then
|
if [ "$IS_WEB_SERVER" = "yes" ]; then
|
||||||
APPLICATION_DIRS="$APPLICATION_DIRS $WWW_ROOT_DIR"
|
APPLICATION_DIRS="$APPLICATION_DIRS $WWW_ROOT_DIR"
|
||||||
__initialize_www_root
|
__initialize_www_root
|
||||||
(echo "Creating directory $WWW_ROOT_DIR with permissions 755" && mkdir -p "$WWW_ROOT_DIR" && find "$WWW_ROOT_DIR" -type d -exec chmod -f 755 {} \;) |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
(echo "Creating directory $WWW_ROOT_DIR with permissions 755" && mkdir -p "$WWW_ROOT_DIR" && find "$WWW_ROOT_DIR" -type d -exec chmod -f 755 {} \;) 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
fi
|
fi
|
||||||
# Setup DATABASE_DIR
|
# Setup DATABASE_DIR
|
||||||
if [ "$IS_DATABASE_SERVICE" = "yes" ]; then
|
if [ "$IS_DATABASE_SERVICE" = "yes" ] || [ "$USES_DATABASE_SERVICE" = "yes" ]; then
|
||||||
APPLICATION_DIRS="$APPLICATION_DIRS $DATABASE_DIR"
|
APPLICATION_DIRS="$APPLICATION_DIRS $DATABASE_DIR"
|
||||||
if __is_dir_empty "$DATABASE_DIR" || [ ! -d "$DATABASE_DIR" ]; then
|
if __is_dir_empty "$DATABASE_DIR" || [ ! -d "$DATABASE_DIR" ]; then
|
||||||
(echo "Creating directory $DATABASE_DIR with permissions 777" && mkdir -p "$DATABASE_DIR" && chmod -f 777 "$DATABASE_DIR") |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
(echo "Creating directory $DATABASE_DIR with permissions 777" && mkdir -p "$DATABASE_DIR" && chmod -f 777 "$DATABASE_DIR") 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
# create default directories
|
# create default directories
|
||||||
for filedirs in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
for filedirs in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
||||||
if [ -n "$filedirs" ] && [ ! -d "$filedirs" ]; then
|
if [ -n "$filedirs" ] && [ ! -d "$filedirs" ]; then
|
||||||
(
|
(echo "Creating directory $filedirs with permissions 777" && mkdir -p "$filedirs" && chmod -f 777 "$filedirs") 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
echo "Creating directory $filedirs with permissions 777"
|
|
||||||
mkdir -p "$filedirs" && chmod -f 777 "$filedirs"
|
|
||||||
) |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
# create default files
|
# create default files
|
||||||
for application_files in $ADD_APPLICATION_FILES $APPLICATION_FILES; do
|
for application_files in $ADD_APPLICATION_FILES $APPLICATION_FILES; do
|
||||||
if [ -n "$application_files" ] && [ ! -e "$application_files" ]; then
|
if [ -n "$application_files" ] && [ ! -e "$application_files" ]; then
|
||||||
(
|
(echo "Creating file $application_files with permissions 777" && touch "$application_files" && chmod -Rf 777 "$application_files") 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
echo "Creating file $application_files with permissions 777"
|
|
||||||
touch "$application_files" && chmod -Rf 777 "$application_files"
|
|
||||||
) |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__fix_permissions() {
|
|
||||||
# set user on files/folders
|
# set user on files/folders
|
||||||
|
__fix_permissions() {
|
||||||
change_user="${1:-${SERVICE_USER:-root}}"
|
change_user="${1:-${SERVICE_USER:-root}}"
|
||||||
change_group="${2:-${SERVICE_GROUP:-$change_user}}"
|
change_group="${2:-${SERVICE_GROUP:-$change_user}}"
|
||||||
[ -n "$RUNAS_USER" ] && [ "$RUNAS_USER" != "root" ] && change_user="$RUNAS_USER" && change_group="$change_user"
|
[ -n "$RUNAS_USER" ] && [ "$RUNAS_USER" != "root" ] && change_user="$RUNAS_USER" && change_group="$change_user"
|
||||||
@ -400,7 +433,7 @@ __fix_permissions() {
|
|||||||
if grep -sq "^$change_user:" "/etc/passwd"; then
|
if grep -sq "^$change_user:" "/etc/passwd"; then
|
||||||
for permissions in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
for permissions in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
||||||
if [ -n "$permissions" ] && [ -e "$permissions" ]; then
|
if [ -n "$permissions" ] && [ -e "$permissions" ]; then
|
||||||
(chown -Rf $change_user:$change_group "$permissions" && echo "changed ownership on $permissions to user:$change_user and group:$change_group") |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
(chown -Rf $change_user:$change_group "$permissions" && echo "changed ownership on $permissions to user:$change_user and group:$change_group") 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
@ -409,7 +442,7 @@ __fix_permissions() {
|
|||||||
if grep -sq "^$change_group:" "/etc/group"; then
|
if grep -sq "^$change_group:" "/etc/group"; then
|
||||||
for permissions in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
for permissions in $ADD_APPLICATION_DIRS $APPLICATION_DIRS; do
|
||||||
if [ -n "$permissions" ] && [ -e "$permissions" ]; then
|
if [ -n "$permissions" ] && [ -e "$permissions" ]; then
|
||||||
(chgrp -Rf $change_group "$permissions" && echo "changed group ownership on $permissions to group $change_group") |& tee -p -a "$LOG_DIR/init.txt" &>/dev/null
|
(chgrp -Rf $change_group "$permissions" && echo "changed group ownership on $permissions to group $change_group") 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
@ -422,6 +455,21 @@ __check_for_uid() { cat "/etc/passwd" 2>/dev/null | awk -F ':' '{print $3}' | so
|
|||||||
__check_for_guid() { cat "/etc/group" 2>/dev/null | awk -F ':' '{print $3}' | sort -u | grep -q "^$1$" || false; }
|
__check_for_guid() { cat "/etc/group" 2>/dev/null | awk -F ':' '{print $3}' | sort -u | grep -q "^$1$" || false; }
|
||||||
__check_for_user() { cat "/etc/passwd" 2>/dev/null | awk -F ':' '{print $1}' | sort -u | grep -q "^$1$" || false; }
|
__check_for_user() { cat "/etc/passwd" 2>/dev/null | awk -F ':' '{print $1}' | sort -u | grep -q "^$1$" || false; }
|
||||||
__check_for_group() { cat "/etc/group" 2>/dev/null | awk -F ':' '{print $1}' | sort -u | grep -q "^$1$" || false; }
|
__check_for_group() { cat "/etc/group" 2>/dev/null | awk -F ':' '{print $1}' | sort -u | grep -q "^$1$" || false; }
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
# check if process is already running
|
||||||
|
__proc_check() {
|
||||||
|
cmd_bin="$(type -P "${1:-$EXEC_CMD_BIN}")"
|
||||||
|
cmd_name="$(basename "${cmd_bin:-$EXEC_CMD_NAME}")"
|
||||||
|
if __pgrep "$cmd_bin" || __pgrep "$cmd_name"; then
|
||||||
|
SERVICE_IS_RUNNING="yes"
|
||||||
|
touch "$SERVICE_PID_FILE"
|
||||||
|
echo "$cmd_name is already running"
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__set_user_group_id() {
|
__set_user_group_id() {
|
||||||
local exitStatus=0
|
local exitStatus=0
|
||||||
@ -435,12 +483,10 @@ __set_user_group_id() {
|
|||||||
[ -n "$set_user" ] && [ "$set_user" != "root" ] || return
|
[ -n "$set_user" ] && [ "$set_user" != "root" ] || return
|
||||||
if grep -sq "^$set_user:" "/etc/passwd" "/etc/group"; then
|
if grep -sq "^$set_user:" "/etc/passwd" "/etc/group"; then
|
||||||
if __check_for_guid "$set_gid"; then
|
if __check_for_guid "$set_gid"; then
|
||||||
groupmod -g "${set_gid}" $set_user 2>/dev/stderr | tee -p -a "${LOG_DIR/tmp/}/init.txt" &>/dev/null &&
|
groupmod -g "${set_gid}" $set_user 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt" >/dev/null && chown -Rf ":$set_gid"
|
||||||
chown -Rf ":$set_gid"
|
|
||||||
fi
|
fi
|
||||||
if __check_for_uid "$set_uid"; then
|
if __check_for_uid "$set_uid"; then
|
||||||
usermod -u "${set_uid}" -g "${set_gid}" $set_user 2>/dev/stderr | tee -p -a "${LOG_DIR/tmp/}/init.txt" &>/dev/null &&
|
usermod -u "${set_uid}" -g "${set_gid}" $set_user 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt" >/dev/null && chown -Rf $set_uid:$set_gid
|
||||||
chown -Rf $set_uid:$set_gid
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
export SERVICE_UID="$set_uid"
|
export SERVICE_UID="$set_uid"
|
||||||
@ -456,10 +502,16 @@ __create_service_user() {
|
|||||||
local create_uid="${4:-${SERVICE_UID:-$USER_UID}}"
|
local create_uid="${4:-${SERVICE_UID:-$USER_UID}}"
|
||||||
local create_gid="${5:-${SERVICE_GID:-$USER_GID}}"
|
local create_gid="${5:-${SERVICE_GID:-$USER_GID}}"
|
||||||
local random_id="$(__generate_random_uids)"
|
local random_id="$(__generate_random_uids)"
|
||||||
|
grep -sq "^$create_user:" "/etc/passwd" && grep -sq "^$create_group:" "/etc/group" && return
|
||||||
|
[ "$create_user" = "root" ] && [ "$create_group" = "root" ] && return 0
|
||||||
|
if [ "$RUNAS_USER" != "root" ] && [ "$RUNAS_USER" != "" ]; then
|
||||||
|
create_user="$RUNAS_USER"
|
||||||
|
create_group="$RUNAS_USER"
|
||||||
|
create_uid="${create_uid:-1000}"
|
||||||
|
create_gid="${create_gid:-1000}"
|
||||||
|
fi
|
||||||
create_uid="$(__get_uid "$set_user" || echo "$create_uid")"
|
create_uid="$(__get_uid "$set_user" || echo "$create_uid")"
|
||||||
create_gid="$(__get_gid "$set_user" || echo "$create_gid")"
|
create_gid="$(__get_gid "$set_user" || echo "$create_gid")"
|
||||||
grep -sq "^$create_user:" "/etc/passwd" && grep -sq "^$create_group:" "/etc/group" && return
|
|
||||||
[ "$create_user" != "root" ] || return 0
|
|
||||||
[ -n "$create_uid" ] && [ "$create_uid" != "0" ] || create_uid="$random_id"
|
[ -n "$create_uid" ] && [ "$create_uid" != "0" ] || create_uid="$random_id"
|
||||||
[ -n "$create_gid" ] && [ "$create_gid" != "0" ] || create_gid="$random_id"
|
[ -n "$create_gid" ] && [ "$create_gid" != "0" ] || create_gid="$random_id"
|
||||||
while :; do
|
while :; do
|
||||||
@ -472,17 +524,18 @@ __create_service_user() {
|
|||||||
done
|
done
|
||||||
if ! __check_for_group "$create_group"; then
|
if ! __check_for_group "$create_group"; then
|
||||||
echo "creating system group $create_group"
|
echo "creating system group $create_group"
|
||||||
groupadd -g $create_gid $create_group 2>/dev/stderr | tee -p -a "${LOG_DIR/tmp/}/init.txt" &>/dev/null
|
groupadd --force --system -g $create_gid $create_group 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt" >/dev/null
|
||||||
fi
|
fi
|
||||||
if ! __check_for_user "$create_user"; then
|
if ! __check_for_user "$create_user"; then
|
||||||
echo "creating system user $create_user"
|
echo "creating system user $create_user"
|
||||||
useradd -u $create_uid -g $create_gid -c "Account for $create_user" -d "$create_home_dir" -s /bin/false $create_user 2>/dev/stderr | tee -p -a "$LOG_DIR/tmp/init.txt" &>/dev/null
|
useradd --system -u $create_uid -g $create_group -c "Account for $create_user" -d "$create_home_dir" -s /bin/false $create_user 2>/dev/stderr | tee -p -a "$LOG_DIR/init.txt" >/dev/null
|
||||||
fi
|
fi
|
||||||
grep -qs "$create_group" "/etc/group" || exitStatus=$((exitCode + 1))
|
grep -qs "$create_group" "/etc/group" || exitStatus=$((exitCode + 1))
|
||||||
grep -qs "$create_user" "/etc/passwd" || exitStatus=$((exitCode + 1))
|
grep -qs "$create_user" "/etc/passwd" || exitStatus=$((exitCode + 1))
|
||||||
[ $exitStatus -eq 0 ] && export WORK_DIR="${set_home_dir:-}"
|
[ $exitStatus -eq 0 ] && export WORK_DIR="${set_home_dir:-}"
|
||||||
export SERVICE_UID="$create_uid"
|
[ -n "$WORK_DIR" ] && [ -d "$WORK_DIR" || mkdir -p "$WORK_DIR"
|
||||||
export SERVICE_GID="$create_gid"
|
export SERVICE_UID="$create_uid" SERVICE_GID="$create_gid"
|
||||||
|
export SERVICE_USER="$create_user" SERVICE_GROUP="$create_group"
|
||||||
return $exitStatus
|
return $exitStatus
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
@ -496,7 +549,7 @@ __create_env_file() {
|
|||||||
dir="$(dirname "$create_env")"
|
dir="$(dirname "$create_env")"
|
||||||
[ -d "$dir" ] || mkdir -p "$dir"
|
[ -d "$dir" ] || mkdir -p "$dir"
|
||||||
if [ -n "$create_env" ] && [ ! -f "$create_env" ]; then
|
if [ -n "$create_env" ] && [ ! -f "$create_env" ]; then
|
||||||
cat <<EOF | tee -p "$create_env" &>/dev/null
|
cat <<EOF | tee -p "$create_env" >/dev/null
|
||||||
$(<"$sample_file")
|
$(<"$sample_file")
|
||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
@ -578,6 +631,7 @@ __start_init_scripts() {
|
|||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
printf '%s\n' "$SERVICE_NAME started on $(date)" >"/data/logs/start.log"
|
||||||
return $retstatus
|
return $retstatus
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
@ -599,7 +653,7 @@ __setup_mta() {
|
|||||||
[ -f "/etc/ssmtp/ssmtp.conf" ] && rm -Rf "/etc/ssmtp/ssmtp.conf"
|
[ -f "/etc/ssmtp/ssmtp.conf" ] && rm -Rf "/etc/ssmtp/ssmtp.conf"
|
||||||
symlink_files="$(__find_file_relative "/config/ssmtp")"
|
symlink_files="$(__find_file_relative "/config/ssmtp")"
|
||||||
if [ ! -f "/config/ssmtp/ssmtp.conf" ]; then
|
if [ ! -f "/config/ssmtp/ssmtp.conf" ]; then
|
||||||
cat <<EOF | tee -p "/config/ssmtp/ssmtp.conf" &>/dev/null
|
cat <<EOF | tee -p "/config/ssmtp/ssmtp.conf" >/dev/null
|
||||||
# ssmtp configuration.
|
# ssmtp configuration.
|
||||||
root=${account_user:-root}@${account_domain:-$HOSTNAME}
|
root=${account_user:-root}@${account_domain:-$HOSTNAME}
|
||||||
mailhub=${relay_server:-172.17.0.1}:$relay_port
|
mailhub=${relay_server:-172.17.0.1}:$relay_port
|
||||||
@ -639,7 +693,7 @@ EOF
|
|||||||
[ -f "/etc/postfix/main.cf" ] && rm -Rf "/etc/postfix/main.cf"
|
[ -f "/etc/postfix/main.cf" ] && rm -Rf "/etc/postfix/main.cf"
|
||||||
symlink_files="$(__find_file_relative "/config/postfix")"
|
symlink_files="$(__find_file_relative "/config/postfix")"
|
||||||
if [ ! -f "/config/postfix/main.cf" ]; then
|
if [ ! -f "/config/postfix/main.cf" ]; then
|
||||||
cat <<EOF | tee -p "/config/postfix/main.cf" &>/dev/null
|
cat <<EOF | tee -p "/config/postfix/main.cf" >/dev/null
|
||||||
# postfix configuration.
|
# postfix configuration.
|
||||||
smtpd_banner = \$myhostname ESMTP email server
|
smtpd_banner = \$myhostname ESMTP email server
|
||||||
compatibility_level = 2
|
compatibility_level = 2
|
||||||
@ -744,7 +798,7 @@ __initialize_replace_variables() {
|
|||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__initialize_database() {
|
__initialize_database() {
|
||||||
[ "$IS_DATABASE_SERVICE" = "yes" ] || return 0
|
[ "$IS_DATABASE_SERVICE" = "yes" ] || [ "$USES_DATABASE_SERVICE" = "yes" ] || return 0
|
||||||
local dir="${1:-$ETC_DIR}"
|
local dir="${1:-$ETC_DIR}"
|
||||||
local db_normal_user="${DATABASE_USER_NORMAL:-$user_name}"
|
local db_normal_user="${DATABASE_USER_NORMAL:-$user_name}"
|
||||||
local db_normal_pass="${DATABASE_PASS_NORMAL:-$user_pass}"
|
local db_normal_pass="${DATABASE_PASS_NORMAL:-$user_pass}"
|
||||||
@ -763,7 +817,7 @@ __initialize_database() {
|
|||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
__initialize_db_users() {
|
__initialize_db_users() {
|
||||||
[ "$IS_DATABASE_SERVICE" = "yes" ] || return 0
|
[ "$IS_DATABASE_SERVICE" = "yes" ] || [ "$USES_DATABASE_SERVICE" = "yes" ] || return 0
|
||||||
db_normal_user="${DATABASE_USER_NORMAL:-$user_name}"
|
db_normal_user="${DATABASE_USER_NORMAL:-$user_name}"
|
||||||
db_normal_pass="${DATABASE_PASS_NORMAL:-$user_pass}"
|
db_normal_pass="${DATABASE_PASS_NORMAL:-$user_pass}"
|
||||||
db_admin_user="${DATABASE_USER_ROOT:-$root_user_name}"
|
db_admin_user="${DATABASE_USER_ROOT:-$root_user_name}"
|
||||||
@ -922,7 +976,7 @@ __initialize_ssl_certs() {
|
|||||||
[ -d "$SSL_DIR" ] || mkdir -p "$SSL_DIR"
|
[ -d "$SSL_DIR" ] || mkdir -p "$SSL_DIR"
|
||||||
__create_ssl_cert
|
__create_ssl_cert
|
||||||
fi
|
fi
|
||||||
type update-ca-certificates &>/dev/null && update-ca-certificates
|
type update-ca-certificates &>/dev/null && update-ca-certificates &>/dev/null
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
@ -939,6 +993,41 @@ __start_php_dev_server() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
__check_service() {
|
||||||
|
if [ "$1" = "check" ]; then
|
||||||
|
shift $#
|
||||||
|
__proc_check "$EXEC_CMD_NAME" || __proc_check "$EXEC_CMD_BIN"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
__switch_to_user() {
|
||||||
|
if [ "$RUNAS_USER" = "roo t" ]; then
|
||||||
|
su_cmd() {
|
||||||
|
su_exec=""
|
||||||
|
eval "$@" || return 1
|
||||||
|
}
|
||||||
|
elif [ "$(builtin type -P gosu)" ]; then
|
||||||
|
su_exec="gosu $RUNAS_USER"
|
||||||
|
su_cmd() { gosu $RUNAS_USER "$@" || return 1; }
|
||||||
|
elif [ "$(builtin type -P runuser)" ]; then
|
||||||
|
su_exec="runuser -u $RUNAS_USER"
|
||||||
|
su_cmd() { runuser -u $RUNAS_USER "$@" || return 1; }
|
||||||
|
elif [ "$(builtin type -P sudo)" ]; then
|
||||||
|
su_exec="sudo -u $RUNAS_USER"
|
||||||
|
su_cmd() { sudo -u $RUNAS_USER "$@" || return 1; }
|
||||||
|
elif [ "$(builtin type -P su)" ]; then
|
||||||
|
su_exec="su -s /bin/sh - $RUNAS_USER"
|
||||||
|
su_cmd() { su -s /bin/sh - $RUNAS_USER -c "$@" || return 1; }
|
||||||
|
else
|
||||||
|
su_cmd() {
|
||||||
|
su_exec=""
|
||||||
|
echo "Can not switch to $RUNAS_USER: attempting to run as root" && eval "$@" || return 1
|
||||||
|
}
|
||||||
|
fi
|
||||||
|
export su_exec
|
||||||
|
}
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
# set variables from function calls
|
# set variables from function calls
|
||||||
export INIT_DATE="${INIT_DATE:-$(date)}"
|
export INIT_DATE="${INIT_DATE:-$(date)}"
|
||||||
export START_SERVICES="${START_SERVICES:-yes}"
|
export START_SERVICES="${START_SERVICES:-yes}"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user