Proxmox/setup/jellyfin_setup.sh

124 lines
3.3 KiB
Bash
Raw Normal View History

2022-01-26 02:26:35 +01:00
#!/usr/bin/env bash
set -o errexit
set -o errtrace
set -o nounset
set -o pipefail
shopt -s expand_aliases
alias die='EXIT=$? LINE=$LINENO error_exit'
trap die ERR
2022-02-02 03:50:02 +01:00
CROSS='\033[1;31m\xE2\x9D\x8C\033[0m'
2022-01-26 02:26:35 +01:00
CHECKMARK='\033[0;32m\xE2\x9C\x94\033[0m'
2022-02-02 03:50:02 +01:00
RETRY_NUM=5
RETRY_EVERY=3
NUM=$RETRY_NUM
2022-01-26 02:26:35 +01:00
trap 'die "Script interrupted."' INT
function error_exit() {
trap - ERR
local DEFAULT='Unknown failure occured.'
local REASON="\e[97m${1:-$DEFAULT}\e[39m"
local FLAG="\e[91m[ERROR:LXC] \e[93m$EXIT@$LINE"
msg "$FLAG $REASON"
exit $EXIT
}
function msg() {
local TEXT="$1"
echo -e "$TEXT"
}
echo -e "${CHECKMARK} \e[1;92m Setting up Container OS... \e[0m"
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
locale-gen >/dev/null
2022-02-02 03:50:02 +01:00
while [ "$(hostname -I)" = "" ]; do
1>&2 echo -e "${CROSS} \e[1;31m No Network: \e[0m $(date)"
sleep $RETRY_EVERY
((NUM--))
if [ $NUM -eq 0 ]
then
1>&2 echo -e "${CROSS} \e[1;31m No Network After $RETRY_NUM Tries \e[0m"
exit 1
fi
done
echo -e "${CHECKMARK} \e[1;92m Network Connected: \e[0m $(hostname -I)"
2022-01-26 02:26:35 +01:00
echo -e "${CHECKMARK} \e[1;92m Updating Container OS... \e[0m"
2022-02-03 09:24:17 +01:00
apt-get update &>/dev/null
2022-01-26 02:26:35 +01:00
apt-get -qqy upgrade &>/dev/null
2022-01-26 02:50:30 +01:00
echo -e "${CHECKMARK} \e[1;92m Installing Dependencies... \e[0m"
2022-01-30 11:49:19 +01:00
apt-get update &>/dev/null
2022-01-26 02:26:35 +01:00
apt-get -qqy install \
curl \
2022-02-09 00:03:05 +01:00
sudo &>/dev/null
2022-01-27 15:16:31 +01:00
echo -e "${CHECKMARK} \e[1;92m Setting Up Hardware Acceleration... \e[0m"
apt-get -y install \
va-driver-all \
ocl-icd-libopencl1 \
beignet-opencl-icd &>/dev/null
2022-01-26 02:26:35 +01:00
/bin/chgrp video /dev/dri
/bin/chmod 755 /dev/dri
/bin/chmod 660 /dev/dri/*
echo -e "${CHECKMARK} \e[1;92m Installing Jellyfin... \e[0m"
2022-02-09 02:06:26 +01:00
sudo mkdir /opt/jellyfin
cd /opt/jellyfin
2022-02-09 02:22:43 +01:00
sudo wget https://repo.jellyfin.org/releases/server/linux/stable/combined/jellyfin_10.7.7_amd64.tar.gz
2022-02-09 02:06:26 +01:00
sudo tar xvzf jellyfin_10.7.7_amd64.tar.gz
sudo ln -s jellyfin_10.7.7 jellyfin
sudo mkdir data cache config log
2022-02-09 02:22:43 +01:00
echo -e "${CHECKMARK} \e[1;92m Installing FFmpeg... \e[0m"
2022-02-09 02:30:23 +01:00
apt-get update
apt-get -y install ffmpeg
2022-02-09 02:22:43 +01:00
echo -e "${CHECKMARK} \e[1;92m Creating Service file jellyfin.service... \e[0m"
FILE_PATH="/opt/jellyfin/jellyfin.sh"
cat >&FILE_PATH <<'EOF'
2022-02-09 02:06:26 +01:00
#!/bin/bash
JELLYFINDIR="/opt/jellyfin"
FFMPEGDIR="/usr/share/jellyfin-ffmpeg"
$JELLYFINDIR/jellyfin/jellyfin \
-d $JELLYFINDIR/data \
-C $JELLYFINDIR/cache \
-c $JELLYFINDIR/config \
-l $JELLYFINDIR/log \
--ffmpeg $FFMPEGDIR/ffmpeg
EOF
sudo chmod +x jellyfin.sh
service_path="/etc/systemd/system/jellyfin.service"
echo "[Unit]
Description=Jellyfin
After=network.target
[Service]
Type=simple
User=root
Restart=always
ExecStart=/opt/jellyfin/jellyfin.sh
[Install]
WantedBy=multi-user.target > $service_path
sudo chmod 644 /etc/systemd/system/jellyfin.service
2022-01-26 02:26:35 +01:00
echo -e "${CHECKMARK} \e[1;92m Customizing Container... \e[0m"
chmod -x /etc/update-motd.d/*
touch ~/.hushlogin
GETTY_OVERRIDE="/etc/systemd/system/container-getty@1.service.d/override.conf"
mkdir -p $(dirname $GETTY_OVERRIDE)
cat << EOF > $GETTY_OVERRIDE
[Service]
ExecStart=
ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,38400,9600 \$TERM
EOF
systemctl daemon-reload
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
2022-02-09 02:06:26 +01:00
sudo systemctl enable jellyfin.service &>/dev/null
sudo systemctl start jellyfin.service &>/dev/null
2022-01-26 02:26:35 +01:00
echo -e "${CHECKMARK} \e[1;92m Cleanup... \e[0m"
rm -rf /jellyfin_setup.sh /var/{cache,log}/* /var/lib/apt/lists/*