11 Commits

Author SHA1 Message Date
0d93284a45 1.0-rc9 release 2023-06-12 14:53:42 -04:00
8c5b0c4f75 Update hardcoded version 2023-06-12 14:52:53 -04:00
7b725d7db0 Fix duplicate service file entries 2023-06-12 14:49:20 -04:00
212a851f1a Remove Xauthority file 2023-06-12 14:43:49 -04:00
283586102e Use MCC stub for ExecStop 2023-06-09 12:50:10 -04:00
8938c061ce Don't use symlink for root 2023-06-05 09:28:51 -04:00
d148427f69 Revert to SIGHUP for testing 2023-05-26 14:48:55 -04:00
6da0b0d89b Rename vars and use stub to kill MC 2023-05-25 18:49:12 -04:00
b8f70fcd04 Switch from SIGHUP to SIGTERM for service exit 2023-05-25 14:50:43 -04:00
cad9bd6f20 MC31: Remove libxcb version requirement for Fedora/CentOS 2023-05-24 08:11:24 -04:00
4a99d184b3 Alias aarch64 to amd64 2023-05-20 11:31:12 -04:00
3 changed files with 136 additions and 109 deletions

View File

@@ -23,7 +23,7 @@ $ installJRMC --help
--compat
Build/install MC without minimum dependency version requirements
--mcversion VERSION
Build or install a specific MC version, ex. "31.0.12" (default: latest version)
Build or install a specific MC version, ex. "31.0.19" (default: latest version)
--arch ARCH
Specify the MC architecture, ex. "amd64", "arm64", etc (default: host architecture)
--outputdir PATH
@@ -112,9 +112,9 @@ Multiple services (but not `--service-types`) can be installed at one time using
Install MC from the repository and start/enable `jriver-mediacenter.service` as a user service.
* `installJRMC --install local --compat --restorefile /path/to/license.mjr --mcversion 31.0.12`
* `installJRMC --install local --compat --restorefile /path/to/license.mjr --mcversion 31.0.19`
Build and install an MC 31.0.12 comptability RPM locally and activate it using the `/path/to/license.mjr`
Build and install an MC 31.0.19 comptability RPM locally and activate it using the `/path/to/license.mjr`
* `installJRMC --createrepo --createrepo-webroot /srv/jriver/repo --createrepo-user www-user`

View File

@@ -27,7 +27,7 @@ $ installJRMC --help
--compat
Build/install MC without minimum dependency version requirements
--mcversion VERSION
Build or install a specific MC version, ex. "31.0.12"
Build or install a specific MC version, ex. "31.0.19"
--arch ARCH
Specify the MC architecture, ex. "amd64", "arm64", etc (default: host architecture)
--outputdir PATH
@@ -106,8 +106,8 @@ Install the latest version of MC from the best available repository.
Install a more widely-compatible version of the latest MC version.
[code]installJRMC --install repo --service jriver-mediacenter --service-type user[/code]
Install MC from the repository and start/enable jriver-mediacenter.service as a user service.
[code]installJRMC --install local --compat --restorefile /path/to/license.mjr --mcversion 31.0.12[/code]
Build and install an MC 31.0.12 comptability RPM locally and activate it using the /path/to/license.mjr
[code]installJRMC --install local --compat --restorefile /path/to/license.mjr --mcversion 31.0.19[/code]
Build and install an MC 31.0.19 comptability RPM locally and activate it using the /path/to/license.mjr
[code]installJRMC --createrepo --createrepo-webroot /srv/jriver/repo --createrepo-user www-user[/code]
Build an RPM locally for the current distro, move it to the webroot, and run createrepo as www-user.
[code]installJRMC --service jriver-createrepo --createrepo-webroot /srv/jriver/repo --createrepo-user www-user[/code]

View File

@@ -16,10 +16,10 @@
shopt -s extglob
declare -g SCRIPTVERSION="1.0-dev"
declare -g SCRIPTVERSION="1.0-rc9"
declare -g BOARDURL="https://yabb.jriver.com/interact/index.php/board,80.0.html" # MC31
declare -g DEBIANBASE="bullseye"
declare -g MCVERSION_HARDCODE="31.0.12"
declare -g MC_VERSION_HARDCODE="31.0.19" # Do find all replace
printHelp() {
debug "Running: ${FUNCNAME[0]}"
@@ -40,7 +40,7 @@ printHelp() {
--compat
Build/install MC locally without minimum dependency version requirements
--mcversion VERSION
Specify the MC version, ex. "31.0.12" (default: latest version)
Specify the MC version, ex. "31.0.19" (default: latest version)
--arch VERSION
Specify the MC architecture, ex. "amd64", "arm64", etc (default: host architecture)
--outputdir PATH
@@ -149,6 +149,9 @@ init() {
x86_64)
ARCH="amd64"
;;
aarch64)
ARCH="arm64"
;;
esac
debug "Detected host platform: $ID $VERSION_ID $ARCH"
@@ -309,12 +312,11 @@ parseInput() {
;;
--mcversion)
shift
MCVERSION="$1"
MC_VERSION="$1"
USER_VERSION_SWITCH=1
;;
--arch)
shift
USER_ARCH="$1"
shift && USER_ARCH="$1"
;;
--restorefile)
shift && RESTOREFILE="$1"
@@ -393,54 +395,61 @@ parseInput() {
setMCVersion() {
debug "Running: ${FUNCNAME[0]}"
declare -g MCVERSION_SOURCE MVERSION MCPKG MCRPM
declare -g MC_VERSION_SOURCE MC_MVERSION MC_ROOT
declare -g MC_PKG MC_RPM MC_STUB MC_STUB_TARGET
declare cnt
# User input
if (( USER_VERSION_SWITCH )) &&
[[ $MCVERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MCVERSION_SOURCE="user input"
[[ $MC_VERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MC_VERSION_SOURCE="user input"
# Containerized package manager
elif installPackage --silent buildah &&
hash buildah &>/dev/null &&
cnt=$(buildah from --quiet debian:$DEBIANBASE-slim) &>/dev/null &&
buildah run "$cnt" -- bash -c \
"echo 'deb [trusted=no arch=amd64,i386,armhf,arm64] http://dist.jriver.com/latest/mediacenter/ $DEBIANBASE main' > /etc/apt/sources.list 2>&1" &>/dev/null &&
buildah run "$cnt" -- bash -c \
"apt update --allow-insecure-repositories &>/dev/null" &>/dev/null &&
MCVERSION=$(buildah run "$cnt" -- apt-cache policy mediacenter?? | grep Candidate | awk '{print $2}' | sort -V | tail -n1) &>/dev/null &&
[[ $MCVERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MCVERSION_SOURCE="containerized package manager"
buildah rm "$cnt" &>/dev/null
# Webscrape
elif installPackage wget && MCVERSION=$(wget -qO- "$BOARDURL" | grep -o "[0-9][0-9]\.[0-9]\.[0-9]\+" | head -n 1) &&
[[ $MCVERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MCVERSION_SOURCE="webscrape"
# Hardcoded
else
declare -g MCVERSION="$MCVERSION_HARDCODE"
MCVERSION_SOURCE="hardcoded or MCVERSION env"
err "Warning! Using hardcoded version number"
echo "Determining latest MC version"
if installPackage --silent buildah &&
hash buildah &>/dev/null &&
cnt=$(buildah from --quiet debian:$DEBIANBASE-slim) &>/dev/null &&
buildah run "$cnt" -- bash -c \
"echo 'deb [trusted=no arch=amd64,i386,armhf,arm64] http://dist.jriver.com/latest/mediacenter/ $DEBIANBASE main' > /etc/apt/sources.list 2>&1" &>/dev/null &&
buildah run "$cnt" -- bash -c \
"apt update --allow-insecure-repositories &>/dev/null" &>/dev/null &&
MC_VERSION=$(buildah run "$cnt" -- apt-cache policy mediacenter?? | grep Candidate | awk '{print $2}' | sort -V | tail -n1) &>/dev/null &&
[[ $MC_VERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MC_VERSION_SOURCE="containerized package manager"
execute buildah rm "$cnt"
# Webscrape
elif installPackage wget && MC_VERSION=$(wget -qO- "$BOARDURL" | grep -o "[0-9][0-9]\.[0-9]\.[0-9]\+" | head -n 1) &&
[[ $MC_VERSION =~ ([0-9]+.[0-9]+.[0-9]+) ]]; then
MC_VERSION_SOURCE="webscrape"
# Hardcoded
else
declare -g MC_VERSION="$MC_VERSION_HARDCODE"
MC_VERSION_SOURCE="hardcoded or MC_VERSION env"
err "Warning! Using hardcoded version number"
fi
fi
MVERSION="${MCVERSION%%.*}"
MCPKG="mediacenter$MVERSION"
MCRPM="$OUTPUTDIR/RPMS/x86_64/mediacenter$MVERSION-$MCVERSION.x86_64.rpm"
MC_MVERSION="${MC_VERSION%%.*}"
MC_PKG="mediacenter$MC_MVERSION"
MC_RPM="$OUTPUTDIR/RPMS/x86_64/mediacenter$MC_MVERSION-$MC_VERSION.x86_64.rpm"
MC_ROOT="/usr/lib/jriver/Media Center $MC_MVERSION"
MC_STUB="$MC_ROOT/mc$MC_MVERSION"
MC_STUB_TARGET="/usr/bin/mc$MC_MVERSION"
if [[ $MCVERSION_SOURCE == "user input" ]]; then
if [[ $MC_VERSION_SOURCE == "user input" ]]; then
# Append explicit package version when user provides --mcversion
case $ID in
fedora|centos|suse)
MCPKG+="-$MCVERSION"
MC_PKG+="-$MC_VERSION"
;;
debian|ubuntu)
MCPKG+="=$MCVERSION"
MC_PKG+="=$MC_VERSION"
;;
esac
fi
echo "Using MC version $MCVERSION determined by $MCVERSION_SOURCE"
[[ $MCVERSION_SOURCE == "user input" ]] || echo "To override, use --mcversion"
debug "MVERSION: $MVERSION, MCVERSION: $MCVERSION, MCPKG: $MCPKG, MCRPM: $MCRPM"
echo "Using MC version $MC_VERSION determined by $MC_VERSION_SOURCE"
[[ $MC_VERSION_SOURCE == "user input" ]] || echo "To override, use --mcversion"
debug "MVERSION: $MC_MVERSION, MC_VERSION: $MC_VERSION, MC_PKG: $MC_PKG, MC_RPM: $MC_RPM"
}
@@ -603,7 +612,7 @@ installMCFromRepo() {
declare repo_dir="/etc/apt/sources.list.d"
[[ -d $repo_dir ]] || execute sudo mkdir -p "$repo_dir"
# Remove existing MC repositories
sudo rm -rf "$repo_dir"/mediacenter*.list
execute sudo rm -rf "$repo_dir"/mediacenter*.list
installPackage wget
sudo bash -c "cat <<-EOF > $repo_dir/jriver.list
deb [trusted=yes arch=amd64,i386,armhf,arm64] http://dist.jriver.com/latest/mediacenter/ $DEBIANBASE main
@@ -630,7 +639,7 @@ installMCFromRepo() {
--no-install-check \
--allow-downgrades \
--no-gpg-check \
"$MCPKG"; then
"$MC_PKG"; then
err "Package install failed!"
return 1
fi
@@ -643,33 +652,33 @@ installMCFromRepo() {
acquireDeb() {
debug "Running: ${FUNCNAME[0]}"
declare -g MCDEB="$OUTPUTDIR/SOURCES/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb"
declare -g MC_DEB="$OUTPUTDIR/SOURCES/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb"
debug "MCDEB=$MCDEB"
debug "MC_DEB=$MC_DEB"
# If deb file already exists, skip download
if [[ -f $MCDEB ]]; then
echo "Using existing DEB: $MCDEB"
if [[ -f $MC_DEB ]]; then
echo "Using existing DEB: $MC_DEB"
return 0
fi
if [[ -v BETAPASS ]] &&
echo "Checking beta repo for DEB package" && execute wget -q -O "$MCDEB" \
"https://files.jriver-cdn.com/mediacenter/channels/v$MVERSION/beta/$BETAPASS/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb"; then
echo "Checking beta repo for DEB package" && execute wget -q -O "$MC_DEB" \
"https://files.jriver-cdn.com/mediacenter/channels/v$MC_MVERSION/beta/$BETAPASS/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb"; then
echo "Found!"
elif echo "Checking latest repo for DEB package" && execute wget -q -O "$MCDEB" \
"https://files.jriver-cdn.com/mediacenter/channels/v$MVERSION/latest/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb"; then
elif echo "Checking latest repo for DEB package" && execute wget -q -O "$MC_DEB" \
"https://files.jriver-cdn.com/mediacenter/channels/v$MC_MVERSION/latest/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb"; then
echo "Found!"
elif echo "Checking test repo for DEB package" && execute wget -q -O "$MCDEB" \
"https://files.jriver-cdn.com/mediacenter/test/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb"; then
elif echo "Checking test repo for DEB package" && execute wget -q -O "$MC_DEB" \
"https://files.jriver-cdn.com/mediacenter/test/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb"; then
echo "Found!"
else
err "Cannot find DEB file"
exit 1
fi
if [[ -f $MCDEB ]]; then
echo "Downloaded MC $MCVERSION DEB to $MCDEB"
if [[ -f $MC_DEB ]]; then
echo "Downloaded MC $MC_VERSION DEB to $MC_DEB"
else
err "Downloaded DEB file missing or corrupted"
exit 1
@@ -687,14 +696,14 @@ buildRPM() {
declare -a requires recommends
# skip rebuilding the rpm if it already exists
if [[ -f $MCRPM ]]; then
echo "$MCRPM already exists. Skipping build step"
if [[ -f $MC_RPM ]]; then
echo "$MC_RPM already exists. Skipping build step"
return 0
fi
# Load deb dependencies into array
IFS=',' read -ra requires <<< "$(dpkg-deb -f "$MCDEB" Depends)"
IFS=',' read -ra recommends <<< "$(dpkg-deb -f "$MCDEB" Recommends)"
IFS=',' read -ra requires <<< "$(dpkg-deb -f "$MC_DEB" Depends)"
IFS=',' read -ra recommends <<< "$(dpkg-deb -f "$MC_DEB" Recommends)"
# Clean up formatting
requires=("${requires[@]%%|*}")
@@ -718,7 +727,7 @@ buildRPM() {
requires=("${requires[@]/libuuid1/libuuid}")
requires=("${requires[@]/libx11-6/libX11}")
requires=("${requires[@]/libxext6/libXext}")
requires=("${requires[@]/libxcb1/libxcb}")
requires=("${requires[@]/libxcb1*/libxcb}") # TODO Remove minimum version for MC31 (*)
requires=("${requires[@]/libxdmcp6/libXdmcp}")
requires=("${requires[@]/libstdc++6/libstdc++}")
requires=("${requires[@]/libgtk-3-0/gtk3}")
@@ -783,12 +792,12 @@ buildRPM() {
# Create spec file
cat <<-EOF > "$OUTPUTDIR/SPECS/mediacenter.spec"
Name: mediacenter$MVERSION
Version: $MCVERSION
Name: mediacenter$MC_MVERSION
Version: $MC_VERSION
Release: 1
Summary: JRiver Media Center
Group: Applications/Media
Source0: http://files.jriver-cdn.com/mediacenter/channels/v$MVERSION/latest/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb
Source0: http://files.jriver-cdn.com/mediacenter/channels/v$MC_MVERSION/latest/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb
BuildArch: x86_64
%define _rpmfilename %%{ARCH}/%%{NAME}-%%{version}.%%{ARCH}.rpm
@@ -799,7 +808,7 @@ buildRPM() {
Conflicts: MediaCenter
Provides: mediacenter$MVERSION
Provides: mediacenter$MC_MVERSION
License: Copyright 1998-2023, JRiver, Inc. All rights reserved. Protected by U.S. patents #7076468 and #7062468
URL: http://www.jriver.com/
@@ -821,15 +830,15 @@ buildRPM() {
%postun -p /sbin/ldconfig
%files
%{_bindir}/mediacenter$MVERSION
%{_bindir}/mediacenter$MC_MVERSION
%{_libdir}/jriver
%{_datadir}
%exclude %{_datadir}/applications/media_center_packageinstaller_$MVERSION.desktop
%exclude %{_datadir}/applications/media_center_packageinstaller_$MC_MVERSION.desktop
/etc/security/limits.d/*
EOF
# Run rpmbuild
echo "Building MC $MCVERSION RPM, this may take awhile"
echo "Building MC $MC_VERSION RPM, this may take awhile"
rpmbuild_cmd=(
rpmbuild
--define="%_topdir $OUTPUTDIR"
@@ -837,13 +846,13 @@ buildRPM() {
-bb
"$OUTPUTDIR/SPECS/mediacenter.spec"
)
if execute "${rpmbuild_cmd[@]}" && [[ -f $MCRPM ]] ; then
echo "Build successful. The RPM file is located at: $MCRPM"
if execute "${rpmbuild_cmd[@]}" && [[ -f $MC_RPM ]] ; then
echo "Build successful. The RPM file is located at: $MC_RPM"
else
err "Build failed"
# For automation, let's remove the source DEB and reaquire it on next
# run after failure in case it is corrupted or buggy
[[ -f $MCDEB ]] && echo "Removing source DEB" && rm -f "$MCDEB"
[[ -f $MC_DEB ]] && echo "Removing source DEB" && rm -f "$MC_DEB"
exit 1
fi
}
@@ -858,7 +867,7 @@ installMCDEB() {
if (( COMPAT_SWITCH )); then
declare extract_dir && extract_dir="$(mktemp -d)"
pushd "$extract_dir" &>/dev/null || return
execute ar x "$MCDEB"
execute ar x "$MC_DEB"
execute tar xJf "control.tar.xz"
# Remove minimum version specifiers from control file
sed -i 's/ ([^)]*)//g' "control"
@@ -866,8 +875,8 @@ installMCDEB() {
[[ $ID == "ubuntu" && ${VERSION_ID%.*} -le 16 ]] &&
sed -i 's/libva2/libva1/g' "control"
execute tar -cJf "control.tar.xz" "control" "postinst"
declare -g MCDEB="${MCDEB/.deb/.compat.deb}"
execute ar rcs "$MCDEB" "debian-binary" "control.tar.xz" "data.tar.xz"
declare -g MC_DEB="${MC_DEB/.deb/.compat.deb}"
execute ar rcs "$MC_DEB" "debian-binary" "control.tar.xz" "data.tar.xz"
popd &>/dev/null || return
execute rm -rf "$extract_dir"
fi
@@ -876,7 +885,7 @@ installMCDEB() {
--no-install-check \
--no-gpg-check \
--allow-downgrades \
"$MCDEB"
"$MC_DEB"
}
@@ -889,7 +898,7 @@ installMCRPM() {
# Install mesa-va-freeworld separately from the RPM for dnf swap
installMesa
installPackage --no-install-check --no-gpg-check --allow-downgrades "$MCRPM"
installPackage --no-install-check --no-gpg-check --allow-downgrades "$MC_RPM"
}
@@ -905,7 +914,7 @@ installMCGENERIC() {
declare extract_dir && extract_dir="$(mktemp -d)"
pushd "$extract_dir" &>/dev/null || return
execute ar x "$MCDEB"
execute ar x "$MC_DEB"
execute tar xJf "control.tar.xz"
echo "You must install the following dependencies manually:"
grep -i "Depends:" control
@@ -914,7 +923,6 @@ installMCGENERIC() {
for f in "${raw_files[@]/#./}"; do
echo "$f" >> "$SCRIPTDIR/.uninstall"
done
#echo "${raw_files[@]/#./}" >> "$SCRIPTDIR/.uninstall"
# Manually install files
for f in "${raw_files[@]}"; do
execute sudo cp -a "$f" "${f/#./}"
@@ -934,8 +942,8 @@ installMCARCH() {
[[ -d $OUTPUTDIR/PKGBUILD ]] || execute mkdir -p "$OUTPUTDIR/PKGBUILD"
cat <<-EOF > "$OUTPUTDIR/PKGBUILD/mediacenter.pkgbuild"
pkgname=mediacenter$MVERSION
pkgver=$MCVERSION
pkgname=mediacenter$MC_MVERSION
pkgver=$MC_VERSION
pkgrel=1
pkgdesc="The Most Comprehensive Media Software"
arch=('x86_64')
@@ -951,7 +959,7 @@ installMCARCH() {
'vorbis-tools: ogg vorbis support'
'musepack-tools: musepack support'
)
source=("http://files.jriver-cdn.com/mediacenter/channels/v$MVERSION/latest/MediaCenter-$MCVERSION-${USER_ARCH:-$ARCH}.deb")
source=("http://files.jriver-cdn.com/mediacenter/channels/v$MC_MVERSION/latest/MediaCenter-$MC_VERSION-${USER_ARCH:-$ARCH}.deb")
package() {
cd "\$srcdir"
@@ -1002,9 +1010,9 @@ runCreaterepo() {
fi
# Copy built rpms to webroot
if ! ( execute sudo cp -nf "$MCRPM" "$CREATEREPO_WEBROOT" &&
if ! ( execute sudo cp -nf "$MC_RPM" "$CREATEREPO_WEBROOT" &&
execute sudo chown -R "$CREATEREPO_USER:$CREATEREPO_USER" "$CREATEREPO_WEBROOT" ); then
err "Could not copy $MCRPM to $CREATEREPO_WEBROOT"
err "Could not copy $MC_RPM to $CREATEREPO_WEBROOT"
return 1
fi
@@ -1023,13 +1031,28 @@ runCreaterepo() {
}
#######################################
# Symlink MC stub
#######################################
symlinkStub() {
debug "Running: ${FUNCNAME[0]}"
if [[ -f $MC_STUB && ! -e $MC_STUB_TARGET ]]; then
if ! execute sudo ln -fs "$MC_STUB" "$MC_STUB_TARGET"; then
err "Symlinking $MC_STUB to $MC_STUB_TARGET failed"
return 1
fi
fi
}
#######################################
# Symlink certificates if they do not exist in default location
#######################################
symlinkCerts() {
debug "Running: ${FUNCNAME[0]}"
declare mc_cert_link="/usr/lib/jriver/MC$MVERSION/ca-certificates.crt"
declare mc_cert_link="$MC_ROOT/ca-certificates.crt"
declare target_cert f
declare -a source_certs=(
"/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem"
@@ -1040,7 +1063,7 @@ symlinkCerts() {
for f in "${source_certs[@]}"; do
if [[ -f $f ]]; then
if ! execute ln -fs "$f" "$mc_cert_link"; then
if ! execute sudo ln -fs "$f" "$mc_cert_link"; then
err "Symlinking certificate failed"
return 1
fi
@@ -1084,7 +1107,7 @@ restoreLicense() {
for f in "$RESTOREFILE" "$newest"; do
if [[ -f $f ]]; then
if execute "mediacenter$MVERSION" "/RestoreFromFile" "$f"; then
if execute "mediacenter$MC_MVERSION" "/RestoreFromFile" "$f"; then
return 0
fi
fi
@@ -1236,8 +1259,7 @@ setServiceVars() {
# TODO Ubuntu needs these in the service file, fedora (and others?) do not
case $ID in
ubuntu|debian)
DISPLAY_STRING="Environment=DISPLAY=$DISPLAY"
DISPLAY_STRING+=$'\n'"Environment=XAUTHORITY=$XAUTHORITY"
DISPLAY_STRING="Environment=XAUTHORITY=$XAUTHORITY"
;;
*)
DISPLAY_STRING=""
@@ -1272,19 +1294,19 @@ service_jriver-mediacenter() {
sudo bash -c "cat <<-EOF > $SERVICE_FNAME
[Unit]
Description=JRiver Media Center $MVERSION
Description=JRiver Media Center $MC_MVERSION
After=$GRAPHICAL_TARGET
[Service]
Type=simple
$USER_STRING
$DISPLAY_STRING
Type=simple
Environment=DISPLAY=$DISPLAY
Environment=XAUTHORITY=$XAUTHORITY
ExecStart=/usr/bin/mediacenter$MVERSION $*
ExecStart=/usr/bin/mediacenter$MC_MVERSION $*
KillMode=none
ExecStop=$MC_STUB_TARGET /MCC 20007
Restart=always
RestartSec=10
KillSignal=SIGHUP
TimeoutStopSec=30
[Install]
@@ -1331,7 +1353,7 @@ service_jriver-xvnc() {
-geometry 1440x900
-alwaysshared
-autokill
-xstartup "/usr/bin/mediacenter$MVERSION"
-xstartup "/usr/bin/mediacenter$MC_MVERSION"
)
if (( NOVNCAUTH )); then
@@ -1522,9 +1544,9 @@ service_jriver-createrepo() {
# add-pkg ca-certificates gnupg &&
# add-pkg --virtual build-dependencies wget &&
# wget -qO- http://dist.jriver.com/mediacenter@jriver.com.gpg.key | tee /etc/apt/trusted.gpg.d/jriver.asc &&
# wget -O /etc/apt/sources.list.d/mediacenter${MVERSION}.list http://dist.jriver.com/latest/mediacenter/mediacenter${MVERSION}.list &&
# wget -O /etc/apt/sources.list.d/mediacenter${MC_MVERSION}.list http://dist.jriver.com/latest/mediacenter/mediacenter${MC_MVERSION}.list &&
# apt update &&
# add-pkg mediacenter${MVERSION} &&
# add-pkg mediacenter${MC_MVERSION} &&
# del-pkg build-dependencies
# "
@@ -1533,14 +1555,14 @@ service_jriver-createrepo() {
# --label maintainer="$MAINTAINER" \
# --env TZ="$TZ" \
# --workingdir /app \
# --cmd "mediacenter$MVERSION"
# --cmd "mediacenter$MC_MVERSION"
# # EXPOSE 5800 5900 52100 52101 52199 1900/udp
# podman_create_cmd=(
# podman create
# --name "mediacenter$MVERSION"
# --name "mediacenter$MC_MVERSION"
# )
# podman_create_cmd+=(-v "$HOME/.jriver:/root/.jriver")
@@ -1569,11 +1591,11 @@ service_jriver-createrepo() {
# wget -q "http://dist.jriver.com/mediacenter@jriver.com.gpg.key" -O- | apt-key add - &>/dev/null
# EOF
# brc wget "http://dist.jriver.com/latest/mediacenter/mediacenter$MVERSION.list" -O "/etc/apt/sources.list.d/mediacenter$MVERSION.list"
# brc wget "http://dist.jriver.com/latest/mediacenter/mediacenter$MC_MVERSION.list" -O "/etc/apt/sources.list.d/mediacenter$MC_MVERSION.list"
# brc apt update -y -q0
# brc add-pkg "mediacenter$MVERSION"
# brc add-pkg "mediacenter$MC_MVERSION"
# brc del-pkg .build-deps
# }
@@ -1586,10 +1608,9 @@ disableCoW() {
debug "Running: ${FUNCNAME[0]}"
declare dir
declare mc_system_path="/usr/lib/jriver"
declare mc_user_path="$HOME/.jriver"
for dir in "$mc_system_path" "$mc_user_path"; do
for dir in "$MC_ROOT" "$mc_user_path"; do
[[ -d $dir ]] || execute mkdir -p "$dir"
if [[ $(stat -f -c %T "$dir") == "btrfs" ]] &&
! lsattr -d "$dir" | cut -f1 -d" " | grep -q C &&
@@ -1607,8 +1628,8 @@ migrateLibrary() {
debug "Running: ${FUNCNAME[0]}"
declare mc_user_path="$HOME/.jriver"
declare current_config_path="$mc_user_path/Media Center $MVERSION"
declare previous_config_path="$mc_user_path/Media Center $(( MVERSION - 1 ))"
declare current_config_path="$mc_user_path/Media Center $MC_MVERSION"
declare previous_config_path="$mc_user_path/Media Center $(( MC_MVERSION - 1 ))"
if [[ ! -d $current_config_path ]] &&
[[ -d $previous_config_path ]] &&
@@ -1671,11 +1692,11 @@ uninstall() {
fi
echo "Uninstalling JRiver Media Center package"
if "${PKG_REMOVE[@]}" "$MCPKG"; then
if "${PKG_REMOVE[@]}" "$MC_PKG"; then
echo "JRiver Media Center has been completely uninstalled"
echo "To remove your MC library: rm -rf $HOME/.jriver"
elif [[ $? -eq 100 ]]; then
err "JRiver Media Center package '$MCPKG' is not present and was not uninstalled"
err "JRiver Media Center package '$MC_PKG' is not present and was not uninstalled"
else
err "Could not remove Media Center package"
fi
@@ -1687,6 +1708,12 @@ uninstall() {
done < "$SCRIPTDIR/.uninstall"
mv "$SCRIPTDIR/.uninstall" "$SCRIPTDIR/.uninstall.bk"
fi
if [[ -e $MC_STUB_TARGET ]]; then
echo "Removing $MC_STUB_TARGET"
execute sudo rm -f "$MC_STUB_TARGET"
fi
return 0
}
@@ -1754,14 +1781,14 @@ main() {
if (( REPO_INSTALL_SWITCH )); then
echo "Installing JRiver Media Center from remote repository"
if installMCFromRepo; then
echo "JRiver Media Center installed successfully from repo"
echo "JRiver Media Center installed successfully from remote repository"
symlinkCerts
migrateLibrary
restoreLicense
openFirewall "jriver-mediacenter" "52100-52200/tcp" "1900/udp"
disableCoW
else
err "JRiver Media Center installation from repo failed"
err "JRiver Media Center installation from remote repository failed"
return 1
fi
fi