Compare commits
1 Commits
dev
...
9c1ffac186
| Author | SHA1 | Date | |
|---|---|---|---|
| 9c1ffac186 |
292
installJRMC
292
installJRMC
@@ -20,13 +20,12 @@ shopt -s extglob
|
|||||||
#######################################
|
#######################################
|
||||||
installJRMC() {
|
installJRMC() {
|
||||||
|
|
||||||
_scriptversion="0.3"
|
_scriptversion="0.4"
|
||||||
_boardurl="https://yabb.jriver.com/interact/index.php/board,64.0.html"
|
_boardurl="https://yabb.jriver.com/interact/index.php/board,64.0.html"
|
||||||
_outputdir="$_basedir/output"
|
_outputdir="$_basedir/output"
|
||||||
_createrepo_webroot="/srv/jriver"
|
_createrepo_webroot="/srv/jriver"
|
||||||
_createrepo_user="$(whoami)"
|
_exec_user="$(whoami)"
|
||||||
_user="$(whoami)"
|
_available_services=("jriver-createrepo" "jriver-x11vnc" "jriver-mediaserver" "jriver-mediacenter" "jriver-vnc-mediacenter")
|
||||||
_available_services=("createrepo" "x11vnc" "mediaserver" "mediacenter" "mediacenter-vncserver")
|
|
||||||
#_available_containers=("mediacenter-vncserver" "createrepo")
|
#_available_containers=("mediacenter-vncserver" "createrepo")
|
||||||
|
|
||||||
|
|
||||||
@@ -55,6 +54,8 @@ OPTIONS
|
|||||||
Restore file location for registration (Default: skip registration)
|
Restore file location for registration (Default: skip registration)
|
||||||
--betapass PASSWORD
|
--betapass PASSWORD
|
||||||
Enter beta team password for access to beta builds
|
Enter beta team password for access to beta builds
|
||||||
|
--service-user USER
|
||||||
|
Install systemd services and containers for USER
|
||||||
--service, -s SERVICE
|
--service, -s SERVICE
|
||||||
See SERVICES section below for a list of possible services to install
|
See SERVICES section below for a list of possible services to install
|
||||||
--container, -c CONTAINER
|
--container, -c CONTAINER
|
||||||
@@ -77,21 +78,22 @@ OPTIONS
|
|||||||
Uninstall JRiver MC, cleanup service files, and remove firewall rules (does not remove library files)
|
Uninstall JRiver MC, cleanup service files, and remove firewall rules (does not remove library files)
|
||||||
|
|
||||||
SERVICES
|
SERVICES
|
||||||
mediaserver
|
jriver-mediaserver
|
||||||
Enable and start a mediaserver systemd service (requires an existing X server)
|
Enable and start a mediaserver systemd service (requires an existing X server)
|
||||||
mediacenter
|
jriver-mediacenter
|
||||||
Enable and start a mediacenter systemd service (requires an existing X server)
|
Enable and start a mediacenter systemd service (requires an existing X server)
|
||||||
x11vnc
|
jriver-x11vnc
|
||||||
Enable and start x11vnc for the local desktop (requires an existing X server)
|
Enable and start x11vnc for the local desktop (requires an existing X server)
|
||||||
--vncpass and --display are also valid options (see below)
|
--vncpass and --display are also valid options (see below)
|
||||||
mediacenter-vncserver
|
jriver-vnc-mediacenter
|
||||||
Enable and start a vncserver running JRiver Media Center
|
Enable and start a vncserver running JRiver Media Center
|
||||||
--vncpass PASSWORD
|
--vncpass PASSWORD
|
||||||
Set vnc password for x11vnc access. If no password is set, the script will either
|
Set vnc password for x11vnc/vncserver access. If no password is set, the script
|
||||||
use existing password stored in ~/.vnc/jrmc_passwd or use no password
|
will either use existing password stored in ~/.vnc/jrmc_passwd or use no password
|
||||||
--display DISPLAY
|
--display DISPLAY
|
||||||
Display to start vncserver/x11vnc (Default: The current display (x11vnc) or next available display (vncserver))
|
Display to start vncserver/x11vnc (Default: The current display (x11vnc) or next
|
||||||
createrepo
|
available display (vncserver))
|
||||||
|
jriver-createrepo
|
||||||
Install hourly service to build latest MC RPM and run createrepo
|
Install hourly service to build latest MC RPM and run createrepo
|
||||||
|
|
||||||
CONTAINERS
|
CONTAINERS
|
||||||
@@ -114,7 +116,7 @@ EOF
|
|||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if _input=$(getopt -o +vdhus:c: -l install-repo,install-rpmbuild,rpmbuild,outputdir:,mcversion:,restorefile:,betapass:,service:,version,debug,force,help,uninstall,createrepo,createrepo-webroot:,createrepo-user:,vncpass:,display:,container: -- "$@"); then
|
if _input=$(getopt -o +vdhus:c: -l install-repo,install-rpmbuild,rpmbuild,outputdir:,mcversion:,restorefile:,betapass:,service-user:,service:,version,debug,force,help,uninstall,createrepo,createrepo-webroot:,createrepo-user:,vncpass:,display:,container: -- "$@"); then
|
||||||
eval set -- "$_input"
|
eval set -- "$_input"
|
||||||
while true; do
|
while true; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
@@ -140,6 +142,9 @@ EOF
|
|||||||
--betapass)
|
--betapass)
|
||||||
shift && _betapass="$1"
|
shift && _betapass="$1"
|
||||||
;;
|
;;
|
||||||
|
--service-user)
|
||||||
|
shift && _service_user="$1"
|
||||||
|
;;
|
||||||
--service|-s)
|
--service|-s)
|
||||||
shift && _services+=("$1")
|
shift && _services+=("$1")
|
||||||
;;
|
;;
|
||||||
@@ -209,11 +214,13 @@ EOF
|
|||||||
|
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Prepend this to any command that you wish to execute with sudo (i.e. when _user is NOT root)
|
# Prepend this to any command that you wish to execute with sudo
|
||||||
|
# Requires:
|
||||||
|
# _exec_user
|
||||||
#######################################
|
#######################################
|
||||||
_ifSudo() {
|
_ifSudo() {
|
||||||
|
|
||||||
if [[ "$_user" != "root" ]]; then
|
if [[ "$_exec_user" != "root" ]]; then
|
||||||
sudo "$@"
|
sudo "$@"
|
||||||
else
|
else
|
||||||
"$@"
|
"$@"
|
||||||
@@ -221,25 +228,6 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_checkUser() {
|
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
|
||||||
|
|
||||||
if [[ "$_user" == "root" ]]; then
|
|
||||||
|
|
||||||
cat <<EOF
|
|
||||||
Warning! You are currently running installJRMC as the root user. This is not recommended! When
|
|
||||||
running as a regular user, installJRMC will ask you for your sudo password when necessary.
|
|
||||||
|
|
||||||
Installation will continue but any systemd services will be installed as system services and you
|
|
||||||
may run into permissions issues.
|
|
||||||
EOF
|
|
||||||
else
|
|
||||||
[[ -n $_debug ]] && echo "Installing as user: $_user"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Sources /etc/os-release so we know which OS we're running on
|
# Sources /etc/os-release so we know which OS we're running on
|
||||||
# Used in: _buildCommands()
|
# Used in: _buildCommands()
|
||||||
@@ -248,8 +236,8 @@ EOF
|
|||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
if [[ -e /etc/os-release ]]; then
|
if [[ -e "/etc/os-release" ]]; then
|
||||||
source /etc/os-release
|
source "/etc/os-release"
|
||||||
else
|
else
|
||||||
err "No /etc/os-release found"
|
err "No /etc/os-release found"
|
||||||
err "Your OS is unsupported"
|
err "Your OS is unsupported"
|
||||||
@@ -337,8 +325,8 @@ EOF
|
|||||||
else
|
else
|
||||||
_createrepo_cmd(){ sudo -u "$_createrepo_user" createrepo -q "$@"; }
|
_createrepo_cmd(){ sudo -u "$_createrepo_user" createrepo -q "$@"; }
|
||||||
fi
|
fi
|
||||||
_mkdir_cmd(){ sudo -u "$_createrepo_user" mkdir -p "$@"; }
|
_cr_mkdir_cmd(){ sudo -u "$_createrepo_user" mkdir -p "$@"; }
|
||||||
_cp_cmd(){ sudo -u "$_createrepo_user" cp -n "$@"; }
|
_cr_cp_cmd(){ sudo -u "$_createrepo_user" cp -n "$@"; }
|
||||||
else
|
else
|
||||||
if [[ -d "$_createrepo_webroot/repodata" ]]; then
|
if [[ -d "$_createrepo_webroot/repodata" ]]; then
|
||||||
_createrepo_cmd(){ createrepo -q --update "$@"; }
|
_createrepo_cmd(){ createrepo -q --update "$@"; }
|
||||||
@@ -350,6 +338,21 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Sets default user variables
|
||||||
|
# Requires:
|
||||||
|
# _exec_user
|
||||||
|
# Globals
|
||||||
|
# _service_user
|
||||||
|
# _createrepo_user
|
||||||
|
#######################################
|
||||||
|
_setUser() {
|
||||||
|
|
||||||
|
[[ -z $_service_user ]] && _service_user="$_exec_user"
|
||||||
|
[[ -z $_createrepo_user ]] && _createrepo_user="$_exec_user"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Installs a package using the system package manager
|
# Installs a package using the system package manager
|
||||||
# Arguments:
|
# Arguments:
|
||||||
@@ -545,6 +548,9 @@ EOF
|
|||||||
# Check for bad service name
|
# Check for bad service name
|
||||||
#
|
#
|
||||||
_checkServices() {
|
_checkServices() {
|
||||||
|
|
||||||
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
for _service in "${_services[@]}"; do
|
for _service in "${_services[@]}"; do
|
||||||
if ! _inArray "$_service" "${_available_services[@]}"; then
|
if ! _inArray "$_service" "${_available_services[@]}"; then
|
||||||
echo "Incorrect service type provided"
|
echo "Incorrect service type provided"
|
||||||
@@ -554,33 +560,43 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_createrepoBuild() {
|
|
||||||
|
|
||||||
if _inArray "createrepo" "${_services[@]}"; then
|
|
||||||
echo "Incorrect service type provided"
|
|
||||||
_printHelpAndExit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
_checkMCInstalled() {
|
_checkMCInstalled() {
|
||||||
|
|
||||||
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
if [[ "${_services[*]}" =~ ^(mediacenter|mediaserver|mediacenter-vncserver)$ ]]; then
|
if [[ "${_services[*]}" =~ ^(mediacenter|mediaserver|mediacenter-vncserver)$ ]]; then
|
||||||
if [[ -z $_repoinstall && -z $_rpminstall ]]; then
|
if [[ -z $_repoinstall && -z $_rpminstall ]]; then
|
||||||
if [[ -x $(command -v "mediacenter$_mversion") ]]; then
|
if [[ -x $(command -v "mediacenter$_mversion") ]]; then
|
||||||
err "You are attempting to install a service that relies on mediacenter$_mversion but --install-repo/--install-rpmbuild are not set and mediacenter$_mversion is not installed"
|
err "You are attempting to install a service that relies on mediacenter$_mversion but --install-repo/--install-rpmbuild are not set and mediacenter$_mversion is not installed"
|
||||||
_printHelpAndExit 1
|
return 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
_checkUser() {
|
||||||
|
|
||||||
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
|
if [[ "$_exec_user" == "root" && -z "$_service_user" && "${_services[*]}" ]]; then
|
||||||
|
err "Attempting to install services as the root user"
|
||||||
|
err "This is not recommended and we are exiting now to prevent permission hell"
|
||||||
|
err "You can override this safety check by manually specifying --user root"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
# Enable/disable sanity checks
|
# Enable/disable sanity checks
|
||||||
_checkServices
|
if _checkServices && _checkMCInstalled && _checkUser; then
|
||||||
_checkMCInstalled
|
[[ -n $_debug ]] && echo "Sanity checks passed!"
|
||||||
#_createrepoBuild
|
return 0
|
||||||
|
else
|
||||||
|
err "Sanity checks failed!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -822,7 +838,7 @@ EOF"
|
|||||||
|
|
||||||
# If the webroot does not exist, create it
|
# If the webroot does not exist, create it
|
||||||
if [[ ! -d "$_createrepo_webroot" ]]; then
|
if [[ ! -d "$_createrepo_webroot" ]]; then
|
||||||
if ! _mkdir_cmd "$_createrepo_webroot"; then
|
if ! _cr_mkdir_cmd "$_createrepo_webroot"; then
|
||||||
err "Could not create the createrepo-webroot path!"
|
err "Could not create the createrepo-webroot path!"
|
||||||
err "Make sure that the createrepo-webroot is writeable by createrepo-user"
|
err "Make sure that the createrepo-webroot is writeable by createrepo-user"
|
||||||
return 1
|
return 1
|
||||||
@@ -830,7 +846,7 @@ EOF"
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Copy built rpms to webroot
|
# Copy built rpms to webroot
|
||||||
if ! _cp_cmd "$_rpmfile" "$_createrepo_webroot"; then
|
if ! _cr_cp_cmd "$_rpmfile" "$_createrepo_webroot"; then
|
||||||
err "Could not copy the RPM to the createrepo-webroot path"
|
err "Could not copy the RPM to the createrepo-webroot path"
|
||||||
err "Make sure that the createrepo-webroot path is writeable by createrepo-user"
|
err "Make sure that the createrepo-webroot path is writeable by createrepo-user"
|
||||||
return 1
|
return 1
|
||||||
@@ -924,6 +940,9 @@ EOF"
|
|||||||
elif [[ "$1" =~ ^(x11vnc|vncserver)$ ]]; then
|
elif [[ "$1" =~ ^(x11vnc|vncserver)$ ]]; then
|
||||||
_f_ports=("$_port/tcp")
|
_f_ports=("$_port/tcp")
|
||||||
_u_ports="$_port/tcp"
|
_u_ports="$_port/tcp"
|
||||||
|
else
|
||||||
|
err "_openFirewall unrecognized service name"
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Open the ports
|
# Open the ports
|
||||||
@@ -1031,23 +1050,59 @@ EOF"
|
|||||||
|
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Create associated service variables based on service name
|
# Set display and port variables
|
||||||
# Arguments:
|
# Arguments:
|
||||||
# Requires exactly one argument, the name of the service to parse
|
# One optional integer argument to increment _service_display by
|
||||||
|
# Globals:
|
||||||
|
# _service_display
|
||||||
|
# _service_displaynum
|
||||||
|
# _port
|
||||||
|
#######################################
|
||||||
|
_setDisplayAndPort() {
|
||||||
|
|
||||||
|
declare -g _service_display
|
||||||
|
declare -g _service_displaynum
|
||||||
|
declare -g _port
|
||||||
|
|
||||||
|
if [[ -n $_display ]]; then
|
||||||
|
_service_display="$_display"
|
||||||
|
elif [[ -n $DISPLAY ]]; then
|
||||||
|
_service_displaynum="${DISPLAY#:}" # strip colon
|
||||||
|
_service_displaynum="${_service_displaynum%.*}" # strip suffix
|
||||||
|
_service_displaynum=$(( _service_displaynum + "${1:-0}" )) # incr by $1
|
||||||
|
_service_display=":$_service_displaynum"
|
||||||
|
else
|
||||||
|
_service_display=":0"
|
||||||
|
fi
|
||||||
|
|
||||||
|
_port=$(( _service_displaynum + 5900 ))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Create associated service variables based on service name
|
||||||
|
# Requires:
|
||||||
|
# _service_user
|
||||||
|
# Globals:
|
||||||
|
# _service_fname
|
||||||
|
# _timer_fname
|
||||||
|
# _service_name
|
||||||
|
# _timer_name
|
||||||
|
# _user_specifier
|
||||||
#######################################
|
#######################################
|
||||||
_servicePrep() {
|
_servicePrep() {
|
||||||
|
|
||||||
if [[ "$_user" == "root" ]]; then
|
if [[ "$_service_user" == "root" ]]; then
|
||||||
_service_fname="/usr/lib/systemd/system/jriver-${1}.service"
|
_service_fname="/usr/lib/systemd/system/${1}.service"
|
||||||
_timer_fname="/usr/lib/systemd/system/jriver-${1}.timer"
|
_timer_fname="/usr/lib/systemd/system/${1}.timer"
|
||||||
_service_name="jriver-${1}.service"
|
_service_name="jriver-${1}.service"
|
||||||
_timer_name="jriver-${1}}.timer"
|
_timer_name="jriver-${1}}.timer"
|
||||||
_user_specifier=""
|
_user_specifier=""
|
||||||
else
|
else
|
||||||
_service_fname="/usr/lib/systemd/system/jriver-${1}@.service"
|
_service_fname="/usr/lib/systemd/system/${1}@.service"
|
||||||
_timer_fname="/usr/lib/systemd/system/jriver-${1}@.timer"
|
_timer_fname="/usr/lib/systemd/system/${1}@.timer"
|
||||||
_service_name="jriver-${1}@$_user.service"
|
_service_name="${1}@$_service_user.service"
|
||||||
_timer_name="jriver-${1}@$_user.timer"
|
_timer_name="${1}@$_service_user.timer"
|
||||||
_user_specifier="User=%I"
|
_user_specifier="User=%I"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -1056,11 +1111,11 @@ EOF"
|
|||||||
#######################################
|
#######################################
|
||||||
# SERVICES
|
# SERVICES
|
||||||
#######################################
|
#######################################
|
||||||
_serviceMediaserver() {
|
_service_jriver-mediaserver() {
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
[[ -z $_display ]] && _display="${DISPLAY:-":0"}"
|
_setDisplayAndPort
|
||||||
|
|
||||||
_bash_cmd "cat <<-EOF > $_service_fname
|
_bash_cmd "cat <<-EOF > $_service_fname
|
||||||
[Unit]
|
[Unit]
|
||||||
@@ -1083,16 +1138,16 @@ WantedBy=graphical.target
|
|||||||
EOF"
|
EOF"
|
||||||
_systemctl_reload && \
|
_systemctl_reload && \
|
||||||
_systemctl_start "$_service_name" && \
|
_systemctl_start "$_service_name" && \
|
||||||
_systemctl_enable "$_service_name"
|
_systemctl_enable "$_service_name" && \
|
||||||
|
_openFirewall "jriver"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_serviceMediacenter() {
|
_service_jriver-mediacenter() {
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
# Set the display to use
|
_setDisplayAndPort
|
||||||
[[ -z $_display ]] && _display="${DISPLAY:-":0"}"
|
|
||||||
|
|
||||||
_bash_cmd "cat <<-EOF > $_service_fname
|
_bash_cmd "cat <<-EOF > $_service_fname
|
||||||
[Unit]
|
[Unit]
|
||||||
@@ -1102,7 +1157,7 @@ After=graphical.target
|
|||||||
[Service]
|
[Service]
|
||||||
$_user_specifier
|
$_user_specifier
|
||||||
Type=simple
|
Type=simple
|
||||||
Environment=DISPLAY=$_display
|
Environment=DISPLAY=$_service_display
|
||||||
Environment=XAUTHORITY=$XAUTHORITY
|
Environment=XAUTHORITY=$XAUTHORITY
|
||||||
ExecStart=/usr/bin/mediacenter$_mversion
|
ExecStart=/usr/bin/mediacenter$_mversion
|
||||||
Restart=always
|
Restart=always
|
||||||
@@ -1115,36 +1170,27 @@ WantedBy=graphical.target
|
|||||||
EOF"
|
EOF"
|
||||||
_systemctl_reload && \
|
_systemctl_reload && \
|
||||||
_systemctl_start "$_service_name" && \
|
_systemctl_start "$_service_name" && \
|
||||||
_systemctl_enable "$_service_name"
|
_systemctl_enable "$_service_name" && \
|
||||||
|
_openFirewall "jriver"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_serviceVNC() {
|
_service_jriver-vnc-mediacenter() {
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
_installPackage tigervnc-server
|
_installPackage tigervnc-server
|
||||||
|
|
||||||
|
_setDisplayAndPort 1
|
||||||
_setVNCPass
|
_setVNCPass
|
||||||
|
|
||||||
if [[ -n $_novncauth ]]; then
|
if [[ -n $_novncauth ]]; then
|
||||||
_exec_start_cmd="/usr/bin/vncserver $_display -geometry 1440x900 -alwaysshared -fg -SecurityTypes None -xstartup /usr/bin/mediacenter$_mversion"
|
_exec_start_cmd="/usr/bin/vncserver $_service_display -geometry 1440x900 -alwaysshared -fg -SecurityTypes None -xstartup /usr/bin/mediacenter$_mversion"
|
||||||
else
|
else
|
||||||
_exec_start_cmd="/usr/bin/vncserver $_display -geometry 1440x900 -alwaysshared -fg -rfbauth $HOME/.vnc/jrmc_passwd -xstartup /usr/bin/mediacenter$_mversion"
|
_exec_start_cmd="/usr/bin/vncserver $_service_display -geometry 1440x900 -alwaysshared -fg -rfbauth $HOME/.vnc/jrmc_passwd -xstartup /usr/bin/mediacenter$_mversion"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set the display to use
|
declare -g _port=$(( ${_service_display#:} + 5900 ))
|
||||||
if [[ -z $_display ]]; then
|
|
||||||
# If we are running on existing X server then increment DISPLAY by one
|
|
||||||
if [[ -n $DISPLAY ]]; then
|
|
||||||
_display=$(( ${DISPLAY#:} + 1 ))
|
|
||||||
_display=":$_display"
|
|
||||||
else
|
|
||||||
_display=":0"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
declare -g _port=$(( ${_display#:} + 5900 ))
|
|
||||||
|
|
||||||
_bash_cmd "cat <<-EOF > $_service_fname
|
_bash_cmd "cat <<-EOF > $_service_fname
|
||||||
[Unit]
|
[Unit]
|
||||||
@@ -1154,9 +1200,9 @@ After=syslog.target network.target
|
|||||||
[Service]
|
[Service]
|
||||||
Type=simple
|
Type=simple
|
||||||
$_user_specifier
|
$_user_specifier
|
||||||
ExecStartPre=/bin/sh -c '/usr/bin/vncserver -kill $_display > /dev/null 2>&1 || :'
|
ExecStartPre=/bin/sh -c '/usr/bin/vncserver -kill $_service_display > /dev/null 2>&1 || :'
|
||||||
ExecStart=$_exec_start_cmd
|
ExecStart=$_exec_start_cmd
|
||||||
ExecStop=/usr/bin/vncserver -kill $_display
|
ExecStop=/usr/bin/vncserver -kill $_service_display
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
@@ -1164,31 +1210,30 @@ EOF"
|
|||||||
_systemctl_reload && \
|
_systemctl_reload && \
|
||||||
_systemctl_start "$_service_name" && \
|
_systemctl_start "$_service_name" && \
|
||||||
_systemctl_enable "$_service_name" && \
|
_systemctl_enable "$_service_name" && \
|
||||||
echo "vncserver running on localhost:$_port"
|
echo "vncserver running on localhost:$_port" && \
|
||||||
|
_openFirewall "vncserver" && \
|
||||||
|
_openFirewall "jriver"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_serviceX11VNC() {
|
_service_jriver-x11vnc() {
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
_installPackage x11vnc
|
_installPackage x11vnc
|
||||||
|
|
||||||
|
_setDisplayAndPort
|
||||||
_setX11VNCPass
|
_setX11VNCPass
|
||||||
|
|
||||||
[[ -z $_display ]] && _display="${DISPLAY:-":0"}"
|
|
||||||
|
|
||||||
declare -g _port=$(( ${_display#:} + 5900 ))
|
|
||||||
|
|
||||||
# Get current desktop resolution
|
# Get current desktop resolution
|
||||||
# TODO: may need to break this out into its own function and get smarter at identifying multi-monitors
|
# TODO: may need to break this out into its own function and get smarter at identifying multi-monitors
|
||||||
local _res
|
local _res
|
||||||
_res=$(xdpyinfo | grep dimensions | awk '{print $2}')
|
_res=$(xdpyinfo | grep dimensions | awk '{print $2}')
|
||||||
|
|
||||||
if [[ -n $_novncauth ]]; then
|
if [[ -n $_novncauth ]]; then
|
||||||
_exec_start_cmd="/usr/bin/x11vnc -display $_display -noscr -geometry $_res -auth guess -forever -bg -nopw"
|
_exec_start_cmd="/usr/bin/x11vnc -display $_service_display -noscr -geometry $_res -auth guess -forever -bg -nopw"
|
||||||
else
|
else
|
||||||
_exec_start_cmd="/usr/bin/x11vnc -display $_display -noscr -geometry $_res -auth guess -forever -bg -rfbauth $HOME/.vnc/jrmc_passwd"
|
_exec_start_cmd="/usr/bin/x11vnc -display $_service_display -noscr -geometry $_res -auth guess -forever -bg -rfbauth $HOME/.vnc/jrmc_passwd"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
_bash_cmd "cat <<-EOF > $_service_fname
|
_bash_cmd "cat <<-EOF > $_service_fname
|
||||||
@@ -1199,7 +1244,7 @@ After=multi.service
|
|||||||
[Service]
|
[Service]
|
||||||
$_user_specifier
|
$_user_specifier
|
||||||
Type=forking
|
Type=forking
|
||||||
Environment=DISPLAY=$_display
|
Environment=DISPLAY=$_service_display
|
||||||
ExecStart=$_exec_start_cmd
|
ExecStart=$_exec_start_cmd
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=10
|
RestartSec=10
|
||||||
@@ -1209,12 +1254,13 @@ WantedBy=multi-user.target
|
|||||||
EOF"
|
EOF"
|
||||||
_systemctl_reload && \
|
_systemctl_reload && \
|
||||||
_systemctl_start "$_service_name" && \
|
_systemctl_start "$_service_name" && \
|
||||||
_systemctl_enable "$_service_name"
|
_systemctl_enable "$_service_name" && \
|
||||||
echo "x11vnc running on localhost:$_port"
|
echo "x11vnc running on localhost:$_port" && \
|
||||||
|
_openFirewall "x11vnc"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_serviceCreaterepo() {
|
_service_jriver-createrepo() {
|
||||||
|
|
||||||
_runDebug "${FUNCNAME[0]}"
|
_runDebug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
@@ -1314,21 +1360,21 @@ EOF"
|
|||||||
|
|
||||||
__main() {
|
__main() {
|
||||||
|
|
||||||
# Check user
|
|
||||||
_checkUser
|
|
||||||
|
|
||||||
# Parse input
|
# Parse input
|
||||||
_parseInput "$@"
|
_parseInput "$@"
|
||||||
|
|
||||||
|
# Sanity checks
|
||||||
|
_sanityChecks
|
||||||
|
|
||||||
|
# Set user variables
|
||||||
|
_setUser
|
||||||
|
|
||||||
# Build some OS-specific commands based on the selected OS
|
# Build some OS-specific commands based on the selected OS
|
||||||
_buildCommands
|
_buildCommands
|
||||||
|
|
||||||
# Set version to install/uninstall
|
# Set version to install/uninstall
|
||||||
_setVersion
|
_setVersion
|
||||||
|
|
||||||
# Sanity checks
|
|
||||||
_sanityChecks
|
|
||||||
|
|
||||||
# Uninstall and exit
|
# Uninstall and exit
|
||||||
if [[ -n $_uninstall ]]; then
|
if [[ -n $_uninstall ]]; then
|
||||||
_uninstall
|
_uninstall
|
||||||
@@ -1369,42 +1415,12 @@ EOF"
|
|||||||
# Install services
|
# Install services
|
||||||
for _service in "${_services[@]}"; do
|
for _service in "${_services[@]}"; do
|
||||||
_servicePrep "$_service"
|
_servicePrep "$_service"
|
||||||
case "$_service" in
|
"_service_$_service"
|
||||||
createrepo)
|
|
||||||
_serviceCreaterepo
|
|
||||||
;;
|
|
||||||
x11vnc)
|
|
||||||
_serviceX11VNC
|
|
||||||
_openFirewall "x11vnc"
|
|
||||||
;;
|
|
||||||
mediaserver)
|
|
||||||
_serviceMediaserver
|
|
||||||
;;
|
|
||||||
mediacenter)
|
|
||||||
_serviceMediacenter
|
|
||||||
;;
|
|
||||||
mediacenter-vncserver)
|
|
||||||
_serviceVNC
|
|
||||||
_openFirewall "vncserver"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
esac
|
|
||||||
done
|
done
|
||||||
|
|
||||||
# Install containers
|
# Install containers
|
||||||
for _container in "${_containers[@]}"; do
|
for _container in "${_containers[@]}"; do
|
||||||
case "$_container" in
|
"_container_$_container"
|
||||||
createrepo)
|
|
||||||
_containerCreaterepo
|
|
||||||
;;
|
|
||||||
mediacenter-vncserver)
|
|
||||||
_containerVNC
|
|
||||||
;;
|
|
||||||
mediacenter)
|
|
||||||
_containerMC
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
esac
|
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user