Merge pull request #88 from demonbane/cron-changes

Make -c useful again
This commit is contained in:
Henric Andersson 2016-08-16 16:52:19 -07:00 committed by GitHub
commit 482f1d2c5a
2 changed files with 96 additions and 85 deletions

View file

@ -13,26 +13,26 @@ It's fairly easy, but let's take it step by step (if it seems too much, skip to
####Using wget and unzip ####Using wget and unzip
You can either download it as a [zip file](https://github.com/mrworf/plexupdate/archive/master.zip) and unzip it on your server. Download it as a [zip file](https://github.com/mrworf/plexupdate/archive/master.zip) and unzip it on your server.
``` ```
wget https://github.com/mrworf/plexupdate/archive/master.zip && unzip master.zip && mv plexupdate-master plexupdate && rm master.zip wget https://github.com/mrworf/plexupdate/archive/master.zip && unzip master.zip && mv plexupdate-master plexupdate && rm master.zip
``` ```
Note that unzip is requered (`sudo apt-get install unzip`). Note that unzip is requered (`sudo apt-get install unzip`).
####Using git to clone (Recommended) ####Using git to clone (Recommended)
Using git is way eaiser and recommended, if you ask me. Using git is way easier and recommended, if you ask me.
``` ```
git clone https://github.com/mrworf/plexupdate.git git clone https://github.com/mrworf/plexupdate.git
``` ```
Note that git is requered (`sudo apt-get install git-all`) Note that git is requered (`sudo apt-get install git-all`)
The main benefit with git clone is that you can update to latest version very easily. *Said in another way*: Auto update only works, if you've done a git clone. The main benefit with git clone is that you can update to latest version very easily. If you want to use the auto update feature, you must be using a git clone.
## 2. Setting it up ## 2. Setting it up
plexupdate.sh looks for a file named `.plexupdate` located in your home directory. Please note that I'm referring to the home directory of the user who is running the plexupdate.sh ... If that user is someone else (root for instance) you'll need to make sure that user has the config file set up properly as well. plexupdate.sh looks for a file named `.plexupdate` located in your home directory. Please note that I'm referring to the home directory of the user who is running the plexupdate.sh ... If that user is someone else (root for instance) you'll need to make sure that user has the config file set up properly as well.
The contents of this file usually is The contents of this file are usually:
``` ```
EMAIL="my.email@plex-server.com" EMAIL="my.email@plex-server.com"
@ -40,16 +40,16 @@ PASS="my-secret-plex-password"
DOWNLOADDIR="/a/folder/to/save/the/files/in" DOWNLOADDIR="/a/folder/to/save/the/files/in"
``` ```
Obviously you need to change these three so they match your account information. And if you don't put anything as a `DOWNLOADDIR`, the tool will use the folder you're executing the script from. So take care. Obviously you need to change these so they match your account information. And if you don't put anything as a `DOWNLOADDIR`, the tool will use the folder you're executing the script from. So take care.
## 3. Advanced options ## 3. Advanced options
You can point out a different file than ```.plexupdate``` by providing it as the last argument to the script. It HAS to be the LAST argument, or it will be ignored. Any options set by the config file can be overriden with commandline options. You can point out a different file than ```.plexupdate``` by providing it as the last argument to the script. It HAS to be the LAST argument, or it will be ignored. Any options set by the config file can be overriden with command-line options.
There are also a few additional options for the more enterprising user. Setting any of these to `yes` will enable the function. There are also a few additional options for the more enterprising user. Setting any of these to `yes` will enable the function.
- PLEXSERVER - PLEXSERVER
If set, and combined with AUTOINSTALL, the script will automatically check if server is in-use and deferr the update. Great for crontab users. PLEXSERVER should be set to the IP/DNS of your Plex Media Server, which typically is 127.0.0.1 If set, and combined with AUTOINSTALL, the script will automatically check if the server is in-use and deferr the update. Great for crontab users. PLEXSERVER should be set to the IP/DNS of your Plex Media Server, which typically is 127.0.0.1
- AUTOUPDATE - AUTOUPDATE
Makes plexupdate.sh automatically update itself using git. Note! This will fail if git isn't available on the command line. Makes plexupdate.sh automatically update itself using git. Note! This will fail if git isn't available on the command line.
- AUTOINSTALL - AUTOINSTALL
@ -59,11 +59,11 @@ There are also a few additional options for the more enterprising user. Setting
- PUBLIC - PUBLIC
The default behavior of plexupdate.sh is to download the PlexPass edition of Plex Media Center. Setting this option to `yes` will make it download the public version instead. If this is yes, then `EMAIL` and `PASS` is no longer needed. The default behavior of plexupdate.sh is to download the PlexPass edition of Plex Media Center. Setting this option to `yes` will make it download the public version instead. If this is yes, then `EMAIL` and `PASS` is no longer needed.
- FORCE - FORCE
Normally plexupdate.sh will avoid downloading a file it already has or if it's the same as the installed version, but this allows you to override. Normally plexupdate.sh will avoid downloading a file it already has or if it's the same as the installed version. Using this option will force it to download again and, if you have AUTOINSTALL set, reinstall it.
- PRINT_URL - PRINT_URL
Authenticate, fetch the download URL, print it, and then exit. Authenticate, fetch the download URL, print it, and then exit.
- DISTRO_INSTALL - DISTRO_INSTALL
The commandline used to install packages, only change if you need special options. Natively supports Debian and Redhat, so need to set this for these systems. The command used to install packages, only change if you need special options. Natively supports Debian and Redhat, so you don't need to set this for these systems.
NOTE! If you define this, you MUST define DISTRO and BUILD NOTE! If you define this, you MUST define DISTRO and BUILD
- DISTRO and BUILD - DISTRO and BUILD
Override which version to download, use -l option to see what you can select. Override which version to download, use -l option to see what you can select.
@ -72,15 +72,9 @@ Most of these options can be specified on the command-line as well, this is just
### Using it from CRON ### Using it from CRON
It seems quite popular to run this via crontab, which is fine. But the behavior of the script has been somewhat, shall we say, annoying. If you want to use plexupdate as either a cron job or as a [systemd job](https://github.com/mrworf/plexupdate/wiki/Running-plexupdate-daily-as-a-systemd-timer), the -c option should do what you want. All non-error exit codes will be set to 0 and no output will be printed to stdout unless something has actually been done. (a new version was downloaded, installed, etc)
Starting today, the ```-C``` option is deprecated and will give an error to check the docs. The new version is ```-c``` and will make sure that only fatal errors are reported back via the exit code. No more 2, 3, 4 or 5 exitcodes. They are converted into 0. Combining this option with ```-q``` will hide any and all non-essential output from the script as well. Only error messages are emitted, so if it fails, you'll know why. If you don't even want to know when something has been done, you can combine this with the -q option and you will only receive output in the event of an error. Everything else will just silenty finish without producing any output.
Take a look at the Wiki, and find the article called [Running plexupdate daily as a systemd timer](https://github.com/mrworf/plexupdate/wiki/Running-plexupdate-daily-as-a-systemd-timer).
## 4. Command-line
I'm going to be lazy, just run the tool with `-h` and you'll find out what you can do. It will basically be a mirror of what section 3 just stated :-)
# Running it # Running it
@ -112,6 +106,6 @@ The username and password for http://plex.tv
## My password is rejected even though correct ## My password is rejected even though correct
If you use certain characters, such as dollar sign, in your password, bash will interpret that as a reference to a variable. To resolve this, enclose your password with single quotes instead of the normal quotes. If you use certain characters (such as `$`) in your password, bash will interpret that as a reference to a variable. To resolve this, enclose your password within single quotes (`'`) instead of the normal quotes (`"`).
Ie, `PASS="MyP4$$w0rD"` will not work, but changing to it to `PASS='MyP4$$w0rD'` will i.e. `PASS="MyP4$$w0rD"` will not work, but changing to it to `PASS='MyP4$$w0rD'` will

View file

@ -31,7 +31,7 @@
#################################################################### ####################################################################
# Quick-check before we allow bad things to happen # Quick-check before we allow bad things to happen
if [ -z "${BASH_VERSINFO}" ]; then if [ -z "${BASH_VERSINFO}" ]; then
echo "ERROR: You must execute this script with BASH" echo "ERROR: You must execute this script with BASH" >&2
exit 255 exit 255
fi fi
#################################################################### ####################################################################
@ -66,15 +66,14 @@ DEBIAN_INSTALL="dpkg -i"
DISTRO_INSTALL="" DISTRO_INSTALL=""
# Sanity, make sure wget is in our path... # Sanity, make sure wget is in our path...
wget >/dev/null 2>/dev/null if ! hash wget 2>/dev/null; then
if [ $? -eq 127 ]; then echo "ERROR: This script requires wget in the path. It could also signify that you don't have the tool installed." >&2
echo "Error: This script requires wget in the path. It could also signify that you don't have the tool installed." >&2
exit 1 exit 1
fi fi
# Allow manual control of configfile # Allow manual control of configfile
HASCFG="${@: -1}" HASCFG="${@: -1}"
if [ ! "${HASCFG}" = "" -a ! "${HASCFG:0:1}" = "-" ]; then if [ ! -z "${HASCFG}" -a ! "${HASCFG:0:1}" = "-" ]; then
if [ -f "${HASCFG}" ]; then if [ -f "${HASCFG}" ]; then
source "${HASCFG}" source "${HASCFG}"
else else
@ -84,7 +83,7 @@ if [ ! "${HASCFG}" = "" -a ! "${HASCFG:0:1}" = "-" ]; then
else else
# Load settings from config file if it exists # Load settings from config file if it exists
# Also, respect SUDO_USER and try that first # Also, respect SUDO_USER and try that first
if [ "${SUDO_USER}" != "" ]; then if [ ! -z "${SUDO_USER}" ]; then
# Make sure nothing bad comes from this (since we use eval) # Make sure nothing bad comes from this (since we use eval)
ERROR=0 ERROR=0
if [[ $SUDO_USER == *";"* ]]; then ERROR=1 ; # Allows more commands if [[ $SUDO_USER == *";"* ]]; then ERROR=1 ; # Allows more commands
@ -102,11 +101,11 @@ else
# Try using original user's config # Try using original user's config
CONFIGDIR="$( eval cd ~${SUDO_USER} 2>/dev/null && pwd )" CONFIGDIR="$( eval cd ~${SUDO_USER} 2>/dev/null && pwd )"
if [ "${CONFIGDIR}" == "" ]; then if [ -z "${CONFIGDIR}" ]; then
echo "WARNING: SUDO_USER \"${SUDO_USER}\" does not have a valid home directory, ignoring." >&2 echo "WARNING: SUDO_USER \"${SUDO_USER}\" does not have a valid home directory, ignoring." >&2
fi fi
if [ "${CONFIGDIR}" != "" -a -f "${CONFIGDIR}/.plexupdate" ]; then if [ ! -z "${CONFIGDIR}" -a -f "${CONFIGDIR}/.plexupdate" ]; then
#echo "INFO: Using \"${SUDO_USER}\" configuration: ${CONFIGDIR}/.plexupdate" #echo "INFO: Using \"${SUDO_USER}\" configuration: ${CONFIGDIR}/.plexupdate"
source "${CONFIGDIR}/.plexupdate" source "${CONFIGDIR}/.plexupdate"
elif [ -f ~/.plexupdate ]; then elif [ -f ~/.plexupdate ]; then
@ -119,12 +118,6 @@ else
fi fi
fi fi
if [ ! "${RELEASE}" = "" ]; then
echo "ERROR: RELEASE keyword is deprecated and should be removed from .plexupdate" >&2
echo " Use DISTRO and BUILD instead to manually select what to install (check README.md)" >&2
exit 255
fi
# Current pages we need - Do not change unless Plex.tv changes again # Current pages we need - Do not change unless Plex.tv changes again
URL_LOGIN=https://plex.tv/users/sign_in.json URL_LOGIN=https://plex.tv/users/sign_in.json
URL_DOWNLOAD=https://plex.tv/api/downloads/1.json?channel=plexpass URL_DOWNLOAD=https://plex.tv/api/downloads/1.json?channel=plexpass
@ -132,8 +125,9 @@ URL_DOWNLOAD_PUBLIC=https://plex.tv/api/downloads/1.json
cronexit() { cronexit() {
# Don't give anything but true error codes if in CRON mode # Don't give anything but true error codes if in CRON mode
RAWEXIT=$1
if [ "${CRON}" = "yes" -a $1 -gt 1 -a $1 -lt 255 ]; then if [ "${CRON}" = "yes" -a $1 -gt 1 -a $1 -lt 255 ]; then
cronexit 0 exit 0
fi fi
exit $1 exit $1
} }
@ -148,7 +142,7 @@ usage() {
echo " -c Cron mode, only fatal errors return non-zero cronexit code" echo " -c Cron mode, only fatal errors return non-zero cronexit code"
echo " -d Auto delete after auto install" echo " -d Auto delete after auto install"
echo " -f Force download even if it's the same version or file" echo " -f Force download even if it's the same version or file"
echo " already exists (WILL NOT OVERWRITE)" echo " already exists"
echo " -h This help" echo " -h This help"
echo " -l List available builds and distros" echo " -l List available builds and distros"
echo " -p Public Plex Media Server version" echo " -p Public Plex Media Server version"
@ -175,7 +169,7 @@ do
(-h) usage;; (-h) usage;;
(-a) AUTOINSTALL=yes;; (-a) AUTOINSTALL=yes;;
(-c) CRON=yes;; (-c) CRON=yes;;
(-C) echo "ERROR: CRON option has changed, please review README.md" 1>&2; cronexit 255;; (-C) echo "ERROR: CRON option has changed, please review README.md" >&2; cronexit 255;;
(-d) AUTODELETE=yes;; (-d) AUTODELETE=yes;;
(-f) FORCE=yes;; (-f) FORCE=yes;;
(-l) LISTOPTS=yes;; (-l) LISTOPTS=yes;;
@ -183,51 +177,61 @@ do
(-q) QUIET=yes;; (-q) QUIET=yes;;
(-r) PRINT_URL=yes;; (-r) PRINT_URL=yes;;
(-s) AUTOSTART=yes;; (-s) AUTOSTART=yes;;
(-S) echo "ERROR: SILENT option has been removed, please use QUIET (-q) instead" 1>&2; cronexit 1;; (-S) echo "ERROR: SILENT option has been removed, please use QUIET (-q) instead" >&2; cronexit 255;;
(-u) AUTOUPDATE=yes;; (-u) AUTOUPDATE=yes;;
(-U) AUTOUPDATE=no;; (-U) AUTOUPDATE=no;;
(--) ;; (--) ;;
(-*) echo "Error: unrecognized option $1" 1>&2; usage; cronexit 1;; (-*) echo "ERROR: unrecognized option $1" >&2; usage; cronexit 1;;
(*) break;; (*) break;;
esac esac
shift shift
done done
if [ "${KEEP}" = "yes" ]; then if [ "${KEEP}" = "yes" ]; then
echo "ERROR: KEEP is deprecated" >&2 echo "ERROR: KEEP is deprecated and should be removed from .plexupdate" >&2
cronexit 1 cronexit 255
fi fi
if [ "${SILENT}" = "yes" ]; then if [ "${SILENT}" = "yes" ]; then
echo "ERROR: SILENT option has been removed, please use QUIET instead" >&2 echo "ERROR: SILENT option has been removed and should be removed from .plexupdate" >&2
cronexit 1 echo " Use QUIET or -q instead" >&2
cronexit 255
fi fi
# send all stdout to /dev/null if [ ! -z "${RELEASE}" ]; then
if [ "${QUIET}" = "yes" ]; then echo "ERROR: RELEASE keyword is deprecated and should be removed from .plexupdate" >&2
exec 5>&1 >/dev/null echo " Use DISTRO and BUILD instead to manually select what to install (check README.md)" >&2
cronexit 255
fi fi
if [ "${AUTOUPDATE}" == "yes" ]; then if [ "${CRON}" = "yes" -a "${QUIET}" = "no" ]; then
git >/dev/null 2>/dev/null # If running in cron mode, redirect STDOUT to temporary file
if [ $? -eq 127 ]; then STDOUTLOG="$(mktemp)"
echo "Error: You need to have git installed for this to work" >&2 exec 3>&1 >"${STDOUTLOG}"
elif [ "${QUIET}" = "yes" ]; then
# Redirect STDOUT to dev null. Use >&3 if you really, really, REALLY need to print to STDOUT
exec 3>&1 > /dev/null
fi
if [ "${AUTOUPDATE}" = "yes" ]; then
if ! hash git 2>/dev/null; then
echo "ERROR: You need to have git installed for this to work" >&2
cronexit 1 cronexit 1
fi fi
pushd "$(dirname "$0")" >/dev/null pushd "$(dirname "$0")" >/dev/null
if [ ! -d .git ]; then if [ ! -d .git ]; then
echo "Error: This is not a git repository, auto update only works if you've done a git clone" >&2 echo "ERROR: This is not a git repository, auto update only works if you've done a git clone" >&2
cronexit 1 cronexit 1
fi fi
git status | grep "git commit -a" >/dev/null 2>/dev/null git status | grep "git commit -a" >/dev/null 2>/dev/null
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
echo "Error: You have made changes to the script, cannot auto update" >&2 echo "ERROR: You have made changes to the script, cannot auto update" >&2
cronexit 1 cronexit 1
fi fi
echo -n "Auto updating..." echo -n "Auto updating..."
git pull >/dev/null git pull >/dev/null
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
echo 'Error: Unable to update git, try running "git pull" manually to see what is wrong' >&2 echo 'ERROR: Unable to update git, try running "git pull" manually to see what is wrong' >&2
cronexit 1 cronexit 1
fi fi
echo "OK" echo "OK"
@ -245,7 +249,7 @@ if [ "${AUTOUPDATE}" == "yes" ]; then
if [ -f "$0" ]; then if [ -f "$0" ]; then
/bin/bash "$0" -U ${ALLARGS[@]} /bin/bash "$0" -U ${ALLARGS[@]}
else else
echo "Error: Unable to relaunch, couldn't find $0" >&2 echo "ERROR: Unable to relaunch, couldn't find $0" >&2
cronexit 1 cronexit 1
fi fi
else else
@ -255,29 +259,29 @@ if [ "${AUTOUPDATE}" == "yes" ]; then
fi fi
# Sanity check # Sanity check
if [ "${EMAIL}" == "" -o "${PASS}" == "" ] && [ "${PUBLIC}" == "no" ] && [ ! -f /tmp/kaka ]; then if [ -z "${EMAIL}" -o -z "${PASS}" ] && [ "${PUBLIC}" = "no" ] && [ ! -f /tmp/kaka ]; then
echo "Error: Need username & password to download PlexPass version. Otherwise run with -p to download public version." >&2 echo "ERROR: Need username & password to download PlexPass version. Otherwise run with -p to download public version." >&2
cronexit 1 cronexit 1
fi fi
if [ "${AUTOINSTALL}" == "yes" -o "${AUTOSTART}" == "yes" ]; then if [ "${AUTOINSTALL}" = "yes" -o "${AUTOSTART}" = "yes" ]; then
id | grep -i 'uid=0(' 2>&1 >/dev/null id | grep -i 'uid=0(' 2>&1 >/dev/null
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
echo "Error: You need to be root to use autoinstall/autostart option." >&2 echo "ERROR: You need to be root to use autoinstall/autostart option." >&2
cronexit 1 cronexit 1
fi fi
fi fi
# Remove any ~ or other oddness in the path we're given # Remove any ~ or other oddness in the path we're given
DOWNLOADDIR="$(eval cd ${DOWNLOADDIR// /\\ } ; if [ $? -eq 0 ]; then pwd; fi)" DOWNLOADDIR="$(eval cd ${DOWNLOADDIR// /\\ } && pwd)"
if [ -z "${DOWNLOADDIR}" ]; then if [ ! -d "${DOWNLOADDIR}" ]; then
echo "Error: Download directory does not exist or is not a directory" >&2 echo "ERROR: Download directory does not exist or is not a directory" >&2
cronexit 1 cronexit 1
fi fi
if [ "${DISTRO_INSTALL}" == "" ]; then if [ -z "${DISTRO_INSTALL}" ]; then
if [ "${DISTRO}" == "" -a "${BUILD}" == "" ]; then if [ -z "${DISTRO}" -a -z "${BUILD}" ]; then
# Detect if we're running on redhat instead of ubuntu # Detect if we're running on redhat instead of ubuntu
if [ -f /etc/redhat-release ]; then if [ -f /etc/redhat-release ]; then
REDHAT=yes REDHAT=yes
@ -290,12 +294,12 @@ if [ "${DISTRO_INSTALL}" == "" ]; then
DISTRO="ubuntu" DISTRO="ubuntu"
DISTRO_INSTALL="${DEBIAN_INSTALL}" DISTRO_INSTALL="${DEBIAN_INSTALL}"
fi fi
elif [ "${DISTRO}" == "" -o "${BUILD}" == "" ]; then elif [ -z "${DISTRO}" -o -z "${BUILD}" ]; then
echo "ERROR: You must define both DISTRO and BUILD" >&2 echo "ERROR: You must define both DISTRO and BUILD" >&2
cronexit 255 cronexit 255
fi fi
else else
if [ "${DISTRO}" == "" -o "${BUILD}" == "" ]; then if [ -z "${DISTRO}" -o -z "${BUILD}" ]; then
echo "Using custom DISTRO_INSTALL requires custom DISTRO and BUILD too" >&2 echo "Using custom DISTRO_INSTALL requires custom DISTRO and BUILD too" >&2
cronexit 255 cronexit 255
fi fi
@ -327,6 +331,11 @@ keypair() {
# Setup an cronexit handler so we cleanup # Setup an cronexit handler so we cleanup
function cleanup { function cleanup {
if [ "${CRON}" = yes -a "${RAWEXIT}" -ne 5 -a -f "${STDOUTLOG}" ]; then
exec 1>&3
cat "${STDOUTLOG}"
fi
rm "${STDOUTLOG}" 2>/dev/null >/dev/null
rm /tmp/postdata 2>/dev/null >/dev/null rm /tmp/postdata 2>/dev/null >/dev/null
rm /tmp/raw 2>/dev/null >/dev/null rm /tmp/raw 2>/dev/null >/dev/null
rm /tmp/failcause 2>/dev/null >/dev/null rm /tmp/failcause 2>/dev/null >/dev/null
@ -349,8 +358,7 @@ if [ -f /tmp/kaka_token ]; then
TOKEN=$(cat /tmp/kaka_token) TOKEN=$(cat /tmp/kaka_token)
fi fi
# If user wants, we skip authentication, but only if previous auth exists if [ "${PUBLIC}" = "no" ]; then
if [ "${PUBLIC}" == "no" ]; then
echo -n "Authenticating..." echo -n "Authenticating..."
# Clean old session # Clean old session
@ -392,7 +400,7 @@ elif [ "$PUBLIC" != "no" ]; then
URL_DOWNLOAD=${URL_DOWNLOAD_PUBLIC} URL_DOWNLOAD=${URL_DOWNLOAD_PUBLIC}
fi fi
if [ "${LISTOPTS}" == "yes" ]; then if [ "${LISTOPTS}" = "yes" ]; then
opts="$(wget --load-cookies /tmp/kaka --save-cookies /tmp/kaka --keep-session-cookies "${URL_DOWNLOAD}" -O - 2>/dev/null | grep -oe '"label"[^}]*' | grep -v Download | sed 's/"label":"\([^"]*\)","build":"\([^"]*\)","distro":"\([^"]*\)".*/"\3" "\2" "\1"/' | uniq | sort)" opts="$(wget --load-cookies /tmp/kaka --save-cookies /tmp/kaka --keep-session-cookies "${URL_DOWNLOAD}" -O - 2>/dev/null | grep -oe '"label"[^}]*' | grep -v Download | sed 's/"label":"\([^"]*\)","build":"\([^"]*\)","distro":"\([^"]*\)".*/"\3" "\2" "\1"/' | uniq | sort)"
eval opts=( "DISTRO" "BUILD" "DESCRIPTION" "======" "=====" "==============================================" $opts ) eval opts=( "DISTRO" "BUILD" "DESCRIPTION" "======" "=====" "==============================================" $opts )
@ -400,12 +408,16 @@ if [ "${LISTOPTS}" == "yes" ]; then
DISTRO= DISTRO=
for X in "${opts[@]}" ; do for X in "${opts[@]}" ; do
if [ "$DISTRO" == "" ]; then if [ -z "$DISTRO" ]; then
DISTRO="$X" DISTRO="$X"
elif [ "$BUILD" == "" ]; then elif [ -z "$BUILD" ]; then
BUILD="$X" BUILD="$X"
else else
printf "%-12s %-30s %s\n" "$DISTRO" "$BUILD" "$X" if [ "${QUIET}" = "yes" ]; then
printf "%-12s %-30s %s\n" "$DISTRO" "$BUILD" "$X" >&3
else
printf "%-12s %-30s %s\n" "$DISTRO" "$BUILD" "$X"
fi
BUILD= BUILD=
DISTRO= DISTRO=
fi fi
@ -419,9 +431,9 @@ fi
# Set "X-Plex-Token" to the auth token, if no token is specified or it is invalid, the list will return public downloads by default # Set "X-Plex-Token" to the auth token, if no token is specified or it is invalid, the list will return public downloads by default
DOWNLOAD=$(wget --header "X-Plex-Token:"${TOKEN}"" --load-cookies /tmp/kaka --save-cookies /tmp/kaka --keep-session-cookies "${URL_DOWNLOAD}" -O - 2>/dev/null | grep -ioe '"label"[^}]*' | grep -i "\"distro\":\"${DISTRO}\"" | grep -i "\"build\":\"${BUILD}\"" | grep -m1 -ioe 'https://[^\"]*' ) DOWNLOAD=$(wget --header "X-Plex-Token:"${TOKEN}"" --load-cookies /tmp/kaka --save-cookies /tmp/kaka --keep-session-cookies "${URL_DOWNLOAD}" -O - 2>/dev/null | grep -ioe '"label"[^}]*' | grep -i "\"distro\":\"${DISTRO}\"" | grep -i "\"build\":\"${BUILD}\"" | grep -m1 -ioe 'https://[^\"]*' )
echo -e "OK" echo "OK"
if [ "${DOWNLOAD}" == "" ]; then if [ -z "${DOWNLOAD}" ]; then
echo "ERROR: Unable to retrieve the URL needed for download (Query DISTRO: $DISTRO, BUILD: $BUILD)" >&2 echo "ERROR: Unable to retrieve the URL needed for download (Query DISTRO: $DISTRO, BUILD: $BUILD)" >&2
cronexit 3 cronexit 3
fi fi
@ -432,9 +444,9 @@ if [ $? -ne 0 ]; then
cronexit 3 cronexit 3
fi fi
if [ "${PRINT_URL}" == "yes" ]; then if [ "${PRINT_URL}" = "yes" ]; then
if [ "${QUIET}" = "yes" ]; then if [ "${QUIET}" = "yes" ]; then
echo "${DOWNLOAD}" >&5 echo "${DOWNLOAD}" >&3
else else
echo "${DOWNLOAD}" echo "${DOWNLOAD}"
fi fi
@ -448,7 +460,7 @@ SKIP_DOWNLOAD="no"
if [ "${REDHAT}" != "yes" ]; then if [ "${REDHAT}" != "yes" ]; then
INSTALLED_VERSION=$(dpkg-query -s plexmediaserver 2>/dev/null | grep -Po 'Version: \K.*') INSTALLED_VERSION=$(dpkg-query -s plexmediaserver 2>/dev/null | grep -Po 'Version: \K.*')
else else
if [ "${AUTOSTART}" == "no" ]; then if [ "${AUTOSTART}" = "no" ]; then
echo "WARNING: Your distribution may require the use of the AUTOSTART [-s] option for the service to start after the upgrade completes." echo "WARNING: Your distribution may require the use of the AUTOSTART [-s] option for the service to start after the upgrade completes."
fi fi
INSTALLED_VERSION=$(rpm -qv plexmediaserver 2>/dev/null) INSTALLED_VERSION=$(rpm -qv plexmediaserver 2>/dev/null)
@ -466,7 +478,7 @@ if [ -f "${DOWNLOADDIR}/${FILENAME}" -a "${FORCE}" != "yes" ]; then
SKIP_DOWNLOAD="yes" SKIP_DOWNLOAD="yes"
fi fi
if [ "${SKIP_DOWNLOAD}" == "no" ]; then if [ "${SKIP_DOWNLOAD}" = "no" ]; then
if [ -f "${DOWNLOADDIR}/${FILENAME}" ]; then if [ -f "${DOWNLOADDIR}/${FILENAME}" ]; then
echo "Note! File exists, but asked to overwrite with new copy" echo "Note! File exists, but asked to overwrite with new copy"
fi fi
@ -481,7 +493,7 @@ if [ "${SKIP_DOWNLOAD}" == "no" ]; then
echo "OK" echo "OK"
fi fi
if [ ! "${PLEXSERVER}" = "" -a "${AUTOINSTALL}" == "yes" ]; then if [ ! -z "${PLEXSERVER}" -a "${AUTOINSTALL}" = "yes" ]; then
# Check if server is in-use before continuing (thanks @AltonV, @hakong and @sufr3ak)... # Check if server is in-use before continuing (thanks @AltonV, @hakong and @sufr3ak)...
if ! wget --no-check-certificate -q -O - https://${PLEXSERVER}:32400/status/sessions | grep -q '<MediaContainer size="0">' ; then if ! wget --no-check-certificate -q -O - https://${PLEXSERVER}:32400/status/sessions | grep -q '<MediaContainer size="0">' ; then
echo "Server ${PLEXSERVER} is currently being used by one or more users, skipping installation. Please run again later" echo "Server ${PLEXSERVER} is currently being used by one or more users, skipping installation. Please run again later"
@ -489,12 +501,12 @@ if [ ! "${PLEXSERVER}" = "" -a "${AUTOINSTALL}" == "yes" ]; then
fi fi
fi fi
if [ "${AUTOINSTALL}" == "yes" ]; then if [ "${AUTOINSTALL}" = "yes" ]; then
sudo ${DISTRO_INSTALL} "${DOWNLOADDIR}/${FILENAME}" sudo ${DISTRO_INSTALL} "${DOWNLOADDIR}/${FILENAME}"
fi fi
if [ "${AUTODELETE}" == "yes" ]; then if [ "${AUTODELETE}" = "yes" ]; then
if [ "${AUTOINSTALL}" == "yes" ]; then if [ "${AUTOINSTALL}" = "yes" ]; then
rm -rf "${DOWNLOADDIR}/${FILENAME}" rm -rf "${DOWNLOADDIR}/${FILENAME}"
echo "Deleted \"${FILENAME}\"" echo "Deleted \"${FILENAME}\""
else else
@ -502,15 +514,20 @@ if [ "${AUTODELETE}" == "yes" ]; then
fi fi
fi fi
if [ "${AUTOSTART}" == "yes" ]; then if [ "${AUTOSTART}" = "yes" ]; then
if [ "${REDHAT}" == "no" ]; then if [ "${REDHAT}" = "no" ]; then
echo "The AUTOSTART [-s] option may not be needed on your distribution." echo "The AUTOSTART [-s] option may not be needed on your distribution." >&2
fi fi
# Check for systemd # Check for systemd
if [ -f "/bin/systemctl" ]; then if hash systemctl 2>/dev/null; then
systemctl start plexmediaserver.service systemctl start plexmediaserver.service
elif hash service 2>/dev/null; then
service plexmediaserver start
elif [ -x /etc/init.d/plexmediaserver ]; then
/etc/init.d/plexmediaserver start
else else
/sbin/service plexmediaserver start echo "ERROR: AUTOSTART was specified but no startup scripts were found for 'plexmediaserver'." >&2
cronexit 1
fi fi
fi fi