-
Notifications
You must be signed in to change notification settings - Fork 89
/
Copy pathPMS_Updater.sh
265 lines (231 loc) · 9.19 KB
/
PMS_Updater.sh
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
#!/bin/sh
AUTOUPDATE=1
FORCEUPDATE=0
VERBOSE=1
REMOVE=1
LOGGING=1
# Try to find the Preferences.xml in all possible folders to fetch the token for downloads of PlexPass versions.
if [ -f /Plex\ Media\ Server/Preferences.xml ]; then
PREFS="/Plex Media Server/Preferences.xml"
elif
[ -f /usr/local/plex/Plex\ Media\ Server/Preferences.xml ]; then
PREFS="/usr/local/plex/Plex Media Server/Preferences.xml"
elif
[ -f /usr/local/plexdata/Plex\ Media\ Server/Preferences.xml ]; then
PREFS="/usr/local/plexdata/Plex Media Server/Preferences.xml"
elif
[ -f /usr/local/plexdata-plexpass/Plex\ Media\ Server/Preferences.xml ]; then
PREFS="/usr/local/plexdata-plexpass/Plex Media Server/Preferences.xml"
else
echo "Preferences.xml not found. This will likely prevent the script from downloading the latest version of Plex. You can still manually download Plex and run PMS_Updater.sh with the -l flag."
fi
PLEXTOKEN="$(sed -n 's/.*PlexOnlineToken="//p' "${PREFS}" | sed 's/\".*//')"
BASEURL="https://plex.tv/api/downloads/5.json"
TOKENURL="$BASEURL?channel=plexpass&X-Plex-Token=$PLEXTOKEN"
DOWNLOADPATH="/tmp"
LOGPATH="/tmp"
LOGFILE="PMS_Updater.log"
PMSPARENTPATH="/usr/local/share"
PMSPATTERN="PlexMediaServer-[0-9]*.[0-9]*.[0-9]*.[0-9]*-[0-9,a-f]*-FreeBSD-amd64.tar.bz2"
# Initialize CURRENTVER to the script max so if reading the current version fails
# for some reason we don't blindly clobber things
CURRENTVER=9999.9999.9999.9999.9999
usage()
{
cat << EOF
usage: $0 options
This script will search the plex.tv download site for a download link
and if it is newer than the currently installed version the script will
download and optionaly install the new version.
OPTIONS:
-l Local file to install instead of latest from Plex.tv
-d download folder (default /tmp) Ignored if -l is used
-a Auto Update to newer version
-f Force Update even if version is not newer
-r Remove update packages older than current version
Done before any update actions are taken.
-v Verbose
-n Use normal version (not PlexPass) version
EOF
}
## LogMsg()
## READS: STDIN (Piped input) $1 (passed in string) $LOGPATH $LOGFILE
## MODIFIES: NONE
##
## Writes log entries to $LOGGINGPATH/$LOGGINGFILE
LogMsg()
{
if [ "$1" = "-n" ]; then SWITCH="-n"; fi
while read IN; do
tdStamp=`date +"%Y-%m-%d %H:%M.%S"`
if [ $LOGGING = 1 ]; then echo "$tdStamp $IN" >> $LOGPATH/$LOGFILE; fi
if [ $VERBOSE = 1 ] || [ "$1" = "-f" ]; then echo $SWITCH $IN; fi
done
}
## verNum()
## READS: $1 (passed in string)
## MODIFIES: NONE
##
## Converts the Plex version string to a mathmatically comparable
## number by removing non numericals and padding each section with zeros
## so v0.9.9.10.485 becomes 00000009000900100485
## NOTE: Plex version numbers appear to have changed from something like
## v0.9.14.4.1556-a10e3c2
## to
## v1.0.0.2261-a17e99e
## Unfortunately this makes the new 1.X versions appear to be an older
## version than the 0.9.X versions. This sed hack will append a .0 version
## to the 1.X version so that it will now behave correctly. The new 1.X will
## now looks omething like:
## 1.0.0.2261.0-a17e99e
## And will convert it to the proper long form such as:
## 00010000000022610000
verNum()
{
echo "$@" | sed -e 's/^.*[^\.]\([0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*\)\([^\.]\)/\1.0\2/' | awk -F. '{ printf("%04d%04d%04d%04d%04d", $1,$2,$3,$4,$5)}'
}
## removeOlder()
## READS: $DOWNLOADPATH $PMSPATTERN $CURRENTVER $VERBOSE $LOGGING
## MODIFIES: NONE
##
## Searches $DOWNLOADPATH for PMS install packages and removes versions older
## than $CURRENTVER
removeOlder()
{
for FOUNDINSTALLFILE in `ls $DOWNLOADPATH/$PMSPATTERN 2>/dev/null`
do {
if [ $(verNum `basename $FOUNDINSTALLFILE`) -lt $(verNum $CURRENTVER) ]; then {
echo Removing $FOUNDINSTALLFILE | LogMsg
rm -f $FOUNDINSTALLFILE 2>&1 | LogMsg
} fi
} done
}
## webFetch()
## READS: $1 (URL) $DOWNLOADPATH $VERBOSE $LOGGING
## MODIFIES: NONE
##
## invoke wget with configured account info
webFetch()
{
local QUIET="-q"
if [ $VERBOSE = 1 ]; then QUIET=""; fi
echo Downloading $1 | LogMsg
fetch $QUIET -o "$DOWNLOADPATH/" "$1" >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo Error downloading $1
exit 1
else
echo Download Complete | LogMsg
fi
}
## findLatest()
## READS: $URLBASIC $URLPLEXPASS $DOWNLOADPATH $PMSPATTERN $VERBOSE $lOGGING
## MODIFIES: $DOWNLOADURL
##
## connects to the Plex.tv download site and scrapes for the latest download link
findLatest()
{
if [ $VERBOSE = 1 ]; then echo Using URL $BASEURL; fi
echo Searching $BASEURL for the FreeBSD download URL ..... | LogMsg -n
DOWNLOADURL="$(fetch -q $TOKENURL -o- | $PMSPARENTPATH/$PMSLIVEFOLDER/Plex\ Script\ Host -c 'import sys, json; myobj = json.load(sys.stdin); print(myobj["computer"]["FreeBSD"]["releases"][0]["url"]);')"
if [ "x$DOWNLOADURL" = "x" ]; then {
# DOWNLOADURL is zero length, i.e. nothing matched PMSPATTERN. Error and exit
echo Could not find a FreeBSD download link on page $TOKENURL | LogMsg -f
exit 1
} else {
echo Done. | LogMsg -f
} fi
}
## applyUpdate()
## READS: $PMSPARENTPATH $PMSLIVEFOLDER $PMSBAKFOLDER $LOCALINSTALLFILE $VERBOSE $LOGGING
## MODIFIES: NONE
##
## Removes anything in the specified backup location, stops
## Plex, moves the current to backup, then tries to extract the new zip
## to the live location. If there is an error while unpacking the files
## are deleted and the backup is moved back. Plex is then started.
## It could be possible to check status after starting a new plex and
## rolling back if it does not start, should check that it is running
## properly before hand to avoid constantly trying to update a broken
## install
applyUpdate()
{
echo Removing previous PMS Backup ..... | LogMsg -n
rm -rf $PMSPARENTPATH/$PMSBAKFOLDER 2>&1 | LogMsg
echo Done. | LogMsg -f
echo Stopping Plex Media Server .....| LogMsg -n
service $SERVICENAME stop 2>&1
echo Done. | LogMsg -f
echo Moving current Plex Media Server to backup location .....| LogMsg -n
mv $PMSPARENTPATH/$PMSLIVEFOLDER/ $PMSPARENTPATH/$PMSBAKFOLDER/ 2>&1 | LogMsg
echo Done. | LogMsg -f
echo Extracting $LOCALINSTALLFILE .....| LogMsg -n
mkdir $PMSPARENTPATH/$PMSLIVEFOLDER/ 2>&1 | LogMsg
tar -xj --strip-components 1 --file $LOCALINSTALLFILE --directory $PMSPARENTPATH/$PMSLIVEFOLDER/ 2>&1 | LogMsg -f
if [ $? -ne 0 ]; then {
echo Error exctracting $LOCALINSTALLFILE. Rolling back to previous version. | LogMsg -f
rm -rf $PMSPARENTPATH/$PMSLIVEFOLDER/ 2>&1 | LogMsg -f
mv $PMSPARENTPATH/$PMSBAKFOLDER/ $PMSPARENTPATH/$PMSLIVEFOLDER/ 2>&1 | LogMsg -f
} else {
echo Done. | LogMsg -f
} fi
ln -s $PMSPARENTPATH/$PMSLIVEFOLDER/Plex\ Media\ Server $PMSPARENTPATH/$PMSLIVEFOLDER/Plex_Media_Server 2>&1 | LogMsg
echo Starting Plex Media Server .....| LogMsg -n
service $SERVICENAME start
echo Done. | LogMsg -f
}
while getopts x."l:d:afvrn" OPTION
do
case $OPTION in
l) LOCALINSTALLFILE=$OPTARG ;;
d) DOWNLOADPATH=$OPTARG ;;
a) AUTOUPDATE=1 ;;
f) FORCEUPDATE=1 ;;
v) VERBOSE=1 ;;
r) REMOVE=1 ;;
n) PLEXPASS=0 ;;
?) usage; exit 1 ;;
esac
done
if [ -d "${PMSPARENTPATH}/plexmediaserver-plexpass" ]; then {
PLEXPASS=1
PMSLIVEFOLDER="plexmediaserver-plexpass"
PMSBAKFOLDER="plexmediaserver-plexpass.bak"
SERVICENAME="plexmediaserver_plexpass"
} else {
PLEXPASS=0
PMSLIVEFOLDER="plexmediaserver"
PMSBAKFOLDER="plexmediaserver.bak"
SERVICENAME="plexmediaserver"
} fi
export PYTHONHOME="$PMSPARENTPATH/$PMSLIVEFOLDER/Resources/Python"
export PYTHONPATH="$PYTHONHOME/python27.zip"
# Get the current version
CURRENTVER=`export LD_LIBRARY_PATH=$PMSPARENTPATH/$PMSLIVEFOLDER/lib; $PMSPARENTPATH/$PMSLIVEFOLDER/Plex\ Media\ Server --version`
if [ $REMOVE = 1 ]; then removeOlder; fi
if [ "x$LOCALINSTALLFILE" = "x" ]; then {
# No local source provided, check the web
findLatest || exit $?
if [ $FORCEUPDATE = 1 ] || [ $(verNum `basename $DOWNLOADURL`) -gt $(verNum $CURRENTVER) ]; then {
webFetch "$DOWNLOADURL" || exit $?
LOCALINSTALLFILE="$DOWNLOADPATH/`basename $DOWNLOADURL`"
} else {
echo Already running latest version $CURRENTVER | LogMsg
exit
} fi
} elif [ ! $FORCEUPDATE = 1 ] && [ $(verNum `basename $LOCALINSTALLFILE`) -le $(verNum $CURRENTVER) ]; then {
echo Already running version $CURRENTVER | LogMsg
echo Use -f to force install $LOCALINSTALLFILE | LogMsg
exit
} fi
# If either update flag is set then verify archive integrity and install
if [ $FORCEUPDATE = 1 ] || [ $AUTOUPDATE = 1 ]; then {
echo Verifying $LOCALINSTALLFILE ..... | LogMsg -n
bzip2 -t $LOCALINSTALLFILE
if [ $? -ne 0 ]; then {
echo $LOCALINSTALLFILE is not a valid archive, cannot update with this file. | LogMsg -f
} else {
echo Done | LogMsg -f
applyUpdate
} fi
} fi