mirror of
https://github.com/spritsail/plex-media-server.git
synced 2025-01-11 19:42:19 +00:00
Joe Groocock
4579290641
Signed-off-by: Adam Dodman <adam@adam-ant.co.uk> Signed-off-by: Joe Groocock <me@frebib.net>
89 lines
2.7 KiB
Bash
Executable File
89 lines
2.7 KiB
Bash
Executable File
#!/bin/sh
|
|
set -e
|
|
|
|
# ANSI colour escape sequences
|
|
RED='\033[0;31m'
|
|
CYANBOLD='\033[1;36m'
|
|
RESET='\033[0m'
|
|
|
|
CONFIG_DIR="/config"
|
|
OLD_CONFIG="/config/Plex Media Server"
|
|
|
|
if [ -d "$OLD_CONFIG" ] && mountpoint -q "$OLD_CONFIG"; then
|
|
rm -rf /var/lib/plexmediaserver
|
|
ln -sf "$CONFIG_DIR" /var/lib/plexmediaserver
|
|
|
|
2>&1 echo -e "${RED}####################### NOTICE #######################${RESET}"
|
|
2>&1 echo
|
|
2>&1 echo -e "${RED} The config mountpoint has changed!${RESET}"
|
|
2>&1 echo -e "${RED} Please change the volume as follows:${RESET}"
|
|
2>&1 echo
|
|
2>&1 echo -e "${CYANBOLD} '$OLD_CONFIG'${RESET} -> ${CYANBOLD}'$CONFIG_DIR'${RESET}"
|
|
2>&1 echo
|
|
2>&1 echo -e "${RED}######################################################${RESET}"
|
|
2>&1 echo
|
|
|
|
CONFIG_DIR="$OLD_CONFIG"
|
|
fi
|
|
|
|
if su-exec -e [ ! -w "$CONFIG_DIR" ]; then
|
|
2>&1 echo -e "${RED}####################### WARNING #######################${RESET}"
|
|
2>&1 echo
|
|
2>&1 echo -e "${RED} No permission to write in '$CONFIG_DIR' directory.${RESET}"
|
|
2>&1 echo -e "${RED} Correcting permissions to prevent a crash.${RESET}"
|
|
2>&1 echo
|
|
2>&1 echo -e "${RED}#######################################################${RESET}"
|
|
2>&1 echo
|
|
|
|
chown "$SUID:$SGID" "$CONFIG_DIR"
|
|
chmod o+rw "$CONFIG_DIR"
|
|
fi
|
|
|
|
export CONFIG_DIR
|
|
export PREF_FILE="$CONFIG_DIR/Preferences.xml"
|
|
|
|
exec su-exec -e sh <<EOF
|
|
|
|
. plex-util.sh
|
|
|
|
# Generate a default configuration on first run, including some user-specified values
|
|
if [ ! -e "\$PREF_FILE" ]; then
|
|
. gen-config.sh
|
|
fi
|
|
|
|
# Changes the log verbosity (Environment variable takes precedence on Plex Config)
|
|
if [ "$LOG_VERBOSE" = "1" ]; then
|
|
setPref "LogVerbose" "1"
|
|
elif [ "$LOG_VERBOSE" = "0" ]; then
|
|
setPref "LogVerbose" "0"
|
|
elif [ ! -z "$LOG_VERBOSE" ]; then
|
|
2>&1 echo -e "${RED}LOG_VERBOSE value '$LOG_VERBOSE' is invalid${RESET}"
|
|
exit 1
|
|
fi
|
|
|
|
# Changes the debug verbosity (Environment variable takes precedence on Plex Config)
|
|
if [ "$LOG_DEBUG" = "1" ]; then
|
|
setPref "logDebug" "1"
|
|
elif [ "$LOG_DEBUG" = "0" ]; then
|
|
setPref "logDebug" "0"
|
|
elif [ ! -z "$LOG_DEBUG" ]; then
|
|
2>&1 echo -e "${RED}LOG_DEBUG value '$LOG_DEBUG' is invalid${RESET}"
|
|
exit 1
|
|
fi
|
|
|
|
# Always attempt to claim an unclaimed server in case it was signed out
|
|
token="\$(getPref "PlexOnlineToken")"
|
|
if [ ! -z "\${PLEX_CLAIM}" ] && [ -z "\${token}" ]; then
|
|
claim-server.sh --load-client-id --save
|
|
fi
|
|
|
|
# Duplicate the Plex logs to stdout (docker logs)
|
|
tail -Fn 0 "\$CONFIG_DIR/Logs/Plex Media Server.log" 2>/dev/null &
|
|
|
|
# Use a random pidfile
|
|
export PLEX_MEDIA_SERVER_PIDFILE="\$(mktemp -ut pms-pid.XXXXXX)"
|
|
|
|
exec "\$PLEX_MEDIA_SERVER_HOME/Plex Media Server"
|
|
|
|
EOF
|