🗃️ modified: bin/entrypoint-aria2.sh 🗃️

This commit is contained in:
Jason 2022-07-11 13:02:53 -04:00
parent d5f40d7d10
commit 9ef649860d
No known key found for this signature in database
GPG Key ID: 4F765975C1F0EE5F

View File

@ -1,61 +1,75 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
##@Version : 202202020147-git ##@Version : 202207111253-git
# @Author : Jason Hempstead # @Author : Jason Hempstead
# @Contact : jason@casjaysdev.com # @Contact : jason@casjaysdev.com
# @License : WTFPL # @License : LICENSE.md
# @ReadME : docker-entrypoint --help # @ReadME : entrypoint-aria2.sh --help
# @Copyright : Copyright: (c) 2022 Jason Hempstead, Casjays Developments # @Copyright : Copyright: (c) 2022 Jason Hempstead, Casjays Developments
# @Created : Wednesday, Feb 02, 2022 01:47 EST # @Created : Monday, Jul 11, 2022 12:53 EDT
# @File : docker-entrypoint # @File : entrypoint-aria2.sh
# @Description : # @Description :
# @TODO : # @TODO :
# @Other : # @Other :
# @Resource : # @Resource :
# @sudo/root : no
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
APPNAME="$(basename "$0")" APPNAME="$(basename "$0" 2>/dev/null)"
VERSION="202202020147-git" VERSION="202207111253-git"
USER="${SUDO_USER:-${USER}}" HOME="${USER_HOME:-$HOME}"
HOME="${USER_HOME:-${HOME}}" USER="${SUDO_USER:-$USER}"
RUN_USER="${SUDO_USER:-$USER}"
SRC_DIR="${BASH_SOURCE%/*}" SRC_DIR="${BASH_SOURCE%/*}"
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# Set bash options # Set bash options
if [[ "$1" == "--debug" ]]; then shift 1 && set -xo pipefail && export SCRIPT_OPTS="--debug" && export _DEBUG="on"; fi if [[ "$1" == "--debug" ]]; then shift 1 && set -xo pipefail && export SCRIPT_OPTS="--debug" && export _DEBUG="on"; fi
trap 'exitCode=${exitCode:-$?};[ -n "$DOCKER_ENTRYPOINT_TEMP_FILE" ] && [ -f "$DOCKER_ENTRYPOINT_TEMP_FILE" ] && rm -Rf "$DOCKER_ENTRYPOINT_TEMP_FILE" &>/dev/null' EXIT trap 'exit $?' HUP INT QUIT TERM EXIT
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
ARIA2RPCPORT="${ARIA2RPCPORT:-6800}" __exec_bash() { [ -n "$1" ] && exec /bin/bash -c "${@:-bash}" || exec /bin/bash || exit 10; }
__find() { ls -A "$*" 2>/dev/null; }
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
DATA_DIR="${DATA_DIR:-$(__find /data/ 2>/dev/null | grep '^' || false)}"
CONFIG_DIR="${CONFIG_DIR:-$(__find /config/ 2>/dev/null | grep '^' || false)}"
export TZ="${TZ:-America/New_York}" export TZ="${TZ:-America/New_York}"
export HOSTNAME="${HOSTNAME:-casjaysdev-aria2}" export HOSTNAME="${HOSTNAME:-casjaysdev-bin}"
ARIA2RPCPORT="${ARIA2RPCPORT:-6800}"
[ -n "${TZ}" ] && echo "${TZ}" >/etc/timezone # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
[ -n "${HOSTNAME}" ] && echo "${HOSTNAME}" >/etc/hostname [[ -n "${TZ}" ]] && echo "${TZ}" >/etc/timezone
[ -n "${HOSTNAME}" ] && echo "127.0.0.1 $HOSTNAME localhost" >/etc/hosts # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
[ -f "/usr/share/zoneinfo/${TZ}" ] && ln -sf "/usr/share/zoneinfo/${TZ}" "/etc/localtime" [[ -f "/usr/share/zoneinfo/${TZ}" ]] && ln -sf "/usr/share/zoneinfo/${TZ}" "/etc/localtime"
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# copy nginx config if [[ -n "${HOSTNAME}" ]]; then
[ -d "/aria2/config/nginx" ] && echo "${HOSTNAME}" >/etc/hostname
cp -Rf "/aria2/config/nginx/." "/etc/nginx/" echo "127.0.0.1 $HOSTNAME localhost" >/etc/hosts
fi
# copy aria config # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
[ -f "/aria2/config/aria2.conf" ] && [[ -d "/config/" ]] && rm -Rf "/config/.gitkeep" || { [[ -n "$CONFIG_DIR" ]] && mkdir -p "/config/"; }
cp -Rf "/aria2/config/aria2.conf" "/etc/aria2.conf" [[ -d "/data/" ]] && rm -Rf "/data/.gitkeep" || { [[ -n "$DATA_DIR" ]] && mkdir -p "/data/"; }
[[ -d "/bin/" ]] && rm -Rf "/bin/.gitkeep" || { [[ -n "$BIN_DIR" ]] && mkdir -p "/bin/"; }
# copy ariang js script to webdir # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
if [[ -n "$CONFIG_DIR" ]]; then
for config in $CONFIG_DIR; do
if [[ -d "/config/$config" ]]; then
cp -Rf "/config/$config/." "/etc/$config/"
elif [[ -f "/config/$config" ]]; then
cp -Rf "/config/$config" "/etc/$config"
fi
done
fi
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
if [ -f "/aria2/config/ariang.js" ]; then if [ -f "/aria2/config/ariang.js" ]; then
ln -sf "/aria2/config/ariang.js" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js" ln -sf "/aria2/config/ariang.js" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js"
else else
cp -Rf "/etc/ariang.js" "/aria2/config/ariang.js" cp -Rf "/etc/ariang.js" "/aria2/config/ariang.js"
ln -sf "/aria2/config/ariang.js" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js" ln -sf "/aria2/config/ariang.js" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js"
fi fi
# allow Changing of port [unsupported] # allow Changing of port [unsupported]
if [[ -n "$ARIA2RPCPORT" ]] && [[ "$ARIA2RPCPORT" != "6800" ]]; then if [[ -n "$ARIA2RPCPORT" ]] && [[ "$ARIA2RPCPORT" != "6800" ]]; then
echo "Changing rpc request port to $ARIA2RPCPORT" echo "Changing rpc request port to $ARIA2RPCPORT"
sed -i "s|6800|${ARIA2RPCPORT}|g" "/etc/nginx/nginx.conf" sed -i "s|6800|${ARIA2RPCPORT}|g" "/etc/nginx/nginx.conf"
sed -i "ss|6800|${ARIA2RPCPORT}|g" "" sed -i "ss|6800|${ARIA2RPCPORT}|g" ""
fi fi
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# set rpc secret # set rpc secret
if [ -n "$RPC_SECRET" ]; then if [ -n "$RPC_SECRET" ]; then
echo "Changing rpc secret to $RPC_SECRET" echo "Changing rpc secret to $RPC_SECRET"
@ -64,18 +78,18 @@ if [ -n "$RPC_SECRET" ]; then
sed -i "s|rpc-secret=.*|rpc-secret=$RPC_SECRET|g" "/etc/aria2.conf" sed -i "s|rpc-secret=.*|rpc-secret=$RPC_SECRET|g" "/etc/aria2.conf"
sed -i "s|secret: |secret: $RPC_SECRET|g" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js" sed -i "s|secret: |secret: $RPC_SECRET|g" "/usr/local/www/ariang/js/aria-ng-f1dd57abb9.min.js"
fi fi
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# create directories
[[ -d "/aria2/config" ]] || mkdir -p "/aria2/config"
[[ -d "/aria2/data" ]] || mkdir -p "/aria2/data"
chmod -Rf 777 "/aria2"
#
[ -d "/etc/nginx" ] && cp -Rf "/etc/nginx/." "/aria2/config/nginx/" [ -d "/etc/nginx" ] && cp -Rf "/etc/nginx/." "/aria2/config/nginx/"
[ -f "/etc/aria2.conf" ] && cp -Rf "/etc/aria2.conf" "/aria2/config/aria2.conf" [ -f "/etc/aria2.conf" ] && cp -Rf "/etc/aria2.conf" "/aria2/config/aria2.conf"
[ -f "/aria2/config/aria2.session" ] || touch "/aria2/config/aria2.session" [ -f "/aria2/config/aria2.session" ] || touch "/aria2/config/aria2.session"
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
case "$1" in case "$1" in
--help)
echo 'Docker container for '$APPNAME''
echo "Usage: $APPNAME [healthcheck, bash, command]"
echo
exitCode=$?
;;
healthcheck) healthcheck)
if curl -q -LSsf -o /dev/null -s -w "200" "http://localhost:$ARIA2RPCPORT"; then if curl -q -LSsf -o /dev/null -s -w "200" "http://localhost:$ARIA2RPCPORT"; then
echo "OK" echo "OK"
@ -85,14 +99,19 @@ healthcheck)
exit 10 exit 10
fi fi
;; ;;
sh | bash | shell | */bin/sh | */bin/bash)
bash | shell | sh) shift 1
ARGS="$*" __exec_bash "$@"
exec /bin/bash ${ARGS:-} exitCode=$?
;; ;;
*) *)
echo starting server on $ARIA2RPCPORT
[ -f "/etc/nginx/nginx.conf" ] && nginx -c /etc/nginx/nginx.conf & [ -f "/etc/nginx/nginx.conf" ] && nginx -c /etc/nginx/nginx.conf &
[ -f "/etc/aria2.conf" ] && exec aria2c --conf-path="/etc/aria2.conf" || exit 10 [ -f "/etc/aria2.conf" ] && exec aria2c --conf-path="/etc/aria2.conf" || exit 10
;; ;;
esac esac
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
exit ${exitCode:-$?}
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
#end