forked from spritsail/plex-media-server
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathentrypoint
executable file
·91 lines (72 loc) · 2.72 KB
/
entrypoint
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/bin/sh
set -e
# ANSI colour escape sequences
RED='\033[0;31m'
CYANBOLD='\033[1;36m'
RESET='\033[0m'
chmod 777 /dev/dri/card0
chmod 777 /dev/dri/renderD128
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
source plex-util.sh
# Generate a default configuration on first run, including some user-specified values
if [ ! -e "\$PREF_FILE" ]; then
source 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