parent
e33f541c2b
commit
d8c22ca1cb
@ -0,0 +1,121 @@
|
||||
#!/bin/bash
|
||||
# vim:set ft=sh sw=2 sts=2 st=2 et:
|
||||
# Author: HurricaneHernandez <carlos@techbyte.ca>
|
||||
# Modified for CentOS/Fedora by: FC7 <casasfernando@outlook.com>
|
||||
|
||||
DESC=EmbyServer
|
||||
PATH=/sbin:/usr/sbin:/bin:/usr/bin
|
||||
NAME=emby-server
|
||||
CONF_FILE=/etc/${NAME}.conf
|
||||
DEFAULT_FILE=/etc/default/${NAME}
|
||||
SCRIPTNAME=/usr/bin/emby-server
|
||||
|
||||
# Source Emby server default configuration
|
||||
. $DEFAULT_FILE
|
||||
|
||||
# Source Emby server user configuration overrides
|
||||
if [[ -f $CONF_FILE ]]; then
|
||||
. $CONF_FILE
|
||||
else
|
||||
echo "${CONF_FILE} not found using default settings.";
|
||||
fi
|
||||
|
||||
# Ensure the runas user has restart privilege to restart the service if not try to add the user to emby group. WARN on failure
|
||||
if [[ "$EMBY_USER" != "emby" ]]; then
|
||||
groups $EMBY_USER | grep -q emby
|
||||
if [[ $? -ne 0 ]]; then
|
||||
if [[ $EUID -eq 0 ]]; then
|
||||
usermod -a -G emby $EMBY_USER
|
||||
else
|
||||
echo "WARNING: The runas user is not part of emby group and you don't have enough privileges to add it. The restart button in the GUI will probably fail."
|
||||
echo "To solve this start the emby-server service using the startup scripts (systemd/sysv) or"
|
||||
echo "add the runas user ($EMBY_USER) to the emby group manually and restart Emby."
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# Data directory where Emby database, cache and logs are stored
|
||||
PROGRAMDATA=$EMBY_DATA
|
||||
PROGRAMDATA_OPT="-programdata $PROGRAMDATA"
|
||||
|
||||
# Path to store PID file
|
||||
PIDFILE=$EMBY_PIDFILE
|
||||
|
||||
# Full path of Emby binary
|
||||
EMBY_EXEC=$EMBY_BIN
|
||||
|
||||
# Path of emby program files
|
||||
EMBY_PATH=$EMBY_DIR
|
||||
|
||||
# path to mono bin
|
||||
MONO_EXEC=$MONO_BIN
|
||||
|
||||
# umask
|
||||
UMASK=${UMASK:-002}
|
||||
|
||||
# Mono environment variables
|
||||
MAGICK_HOME_ENV="MAGICK_HOME=${EMBY_PATH}"
|
||||
EMBY_LIBRARY_PATH=$(find /usr/lib/emby-server/ -maxdepth 1 -mindepth 1 -type d| grep -v bin | grep -v etc | grep -v -e "/\.")
|
||||
MAGICK_CODER_FILTER_PATH_ENV="MAGICK_CODER_FILTER_PATH=$(find ${EMBY_LIBRARY_PATH} -type d -name "filters" | grep EmbyMagick)"
|
||||
MAGICK_CODER_MODULE_PATH_ENV="MAGICK_CODER_MODULE_PATH=$(find ${EMBY_LIBRARY_PATH} -type d -name "coders" | grep EmbyMagick)"
|
||||
MONO_EXEC_ENV="$MONO_ENV ${EMBY_LIBRARY_PATH:+"LD_LIBRARY_PATH=${EMBY_LIBRARY_PATH}${LD_LIBRARY_PATH:+:}$LD_LIBRARY_PATH"}"
|
||||
|
||||
# Mono options
|
||||
MONO_EXEC_OPTS=$MONO_OPTS
|
||||
|
||||
# restart function
|
||||
RESTART_OPTS="-restartpath ${EMBY_PATH}/restart.sh"
|
||||
|
||||
# Emby options
|
||||
EMBY_OPTS="$PROGRAMDATA_OPT $RESTART_OPTS $EMBY_ADD_OPTS"
|
||||
|
||||
PID_PATH=$(dirname $PIDFILE)
|
||||
|
||||
# Exit if the mono-sgen not installed
|
||||
if [[ ! -x $MONO_EXEC ]]; then
|
||||
if [[ -n "$(command -v mono-sgen)" ]]; then
|
||||
MONO_EXEC=$(command -v mono-sgen)
|
||||
else
|
||||
MONO_EXEC=$(command -v mono)
|
||||
fi
|
||||
fi
|
||||
|
||||
# Create programdata directory if not exist and ensure the emby user can write to it
|
||||
if [[ ! -d $PROGRAMDATA ]]; then
|
||||
if [[ $EUID -eq 0 ]]; then
|
||||
mkdir -p $PROGRAMDATA
|
||||
else
|
||||
echo "WARNING: $EMBY_DATA directory does not exist."
|
||||
echo "To solve this, if it is an upgrade verify that \"EMBY_DATA\" is set to the correct path in /etc/emby-server.conf."
|
||||
echo "You may need to locate the path of your library files and set EMBY_DATA to that path."
|
||||
echo "If this is an new installation please rerun last command with elevated permissions."
|
||||
fi
|
||||
fi
|
||||
|
||||
# Set right permission for directories
|
||||
DATA_CURRENT_USER=$(ls -lad $PROGRAMDATA | awk '{print $3}')
|
||||
|
||||
if [[ "$DATA_CURRENT_USER" != "$EMBY_USER" ]]; then
|
||||
if [[ $EUID -eq 0 ]]; then
|
||||
chown -R $EMBY_USER.$EMBY_GROUP $PROGRAMDATA
|
||||
else
|
||||
echo "WARNING: $EMBY_DATA directory does not have the correct permissions."
|
||||
echo "Please rerun this script with elevated permissions."
|
||||
fi
|
||||
fi
|
||||
|
||||
case "$1" in
|
||||
start)
|
||||
echo $$ > $PIDFILE
|
||||
exec su -s /bin/sh -c 'umask $0; exec "$1" "$@"' $EMBY_USER -- \
|
||||
$UMASK env $MAGICK_HOME_ENV $MAGICK_CODER_FILTER_PATH_ENV $MAGICK_CODER_MODULE_PATH_ENV \
|
||||
$MONO_EXEC_ENV $MONO_EXEC $MONO_EXEC_OPTS $EMBY_EXEC $EMBY_OPTS
|
||||
;;
|
||||
clear)
|
||||
[[ -e $PIDFILE ]] && rm -rf $PIDFILE
|
||||
;;
|
||||
*)
|
||||
echo "Usage: $SCRIPTNAME {start|clear}" >&2
|
||||
exit 3
|
||||
;;
|
||||
esac
|
Loading…
Reference in new issue