ProxmoxHelperScripts/setup/plex_setup.sh

87 lines
2.6 KiB
Bash
Raw Normal View History

2022-01-19 00:40:40 +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'
2022-02-02 03:55:48 +01:00
CROSS='\033[1;31m\xE2\x9D\x8C\033[0m'
2022-01-19 00:40:40 +01:00
CHECKMARK='\033[0;32m\xE2\x9C\x94\033[0m'
2022-02-02 03:55:48 +01:00
RETRY_NUM=5
RETRY_EVERY=3
NUM=$RETRY_NUM
trap die ERR
2022-01-19 00:40:40 +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:55:48 +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-19 00:40:40 +01:00
echo -e "${CHECKMARK} \e[1;92m Updating Container OS... \e[0m"
2022-02-03 09:26:27 +01:00
apt-get update &>/dev/null
2022-01-19 00:40:40 +01:00
apt-get -qqy upgrade &>/dev/null
2022-01-27 14:59:09 +01:00
echo -e "${CHECKMARK} \e[1;92m Installing Dependencies... \e[0m"
2022-01-30 11:52:05 +01:00
apt-get update &>/dev/null
2022-01-19 00:40:40 +01:00
apt-get -qqy install \
curl \
sudo \
2022-01-27 14:59:09 +01:00
gnupg &>/dev/null
echo -e "${CHECKMARK} \e[1;92m Setting Up Hardware Acceleration... \e[0m"
apt-get -y install \
2022-01-25 02:20:48 +01:00
va-driver-all \
ocl-icd-libopencl1 \
beignet-opencl-icd &>/dev/null
2022-01-23 18:36:09 +01:00
/bin/chgrp video /dev/dri
/bin/chmod 755 /dev/dri
/bin/chmod 660 /dev/dri/*
2022-01-27 19:55:13 +01:00
echo -e "${CHECKMARK} \e[1;92m Setting Up Plex Media Server Repository... \e[0m"
wget -q https://downloads.plex.tv/plex-keys/PlexSign.key -O - | sudo apt-key add - &>/dev/null
echo "deb [arch=$( dpkg --print-architecture )] https://downloads.plex.tv/repo/deb/ public main" | tee /etc/apt/sources.list.d/plexmediaserver.list &>/dev/null
2022-01-19 00:40:40 +01:00
echo -e "${CHECKMARK} \e[1;92m Installing Plex Media Server... \e[0m"
2022-01-27 19:55:13 +01:00
apt-get update &>/dev/null
apt-get -o Dpkg::Options::="--force-confold" install -y plexmediaserver &>/dev/null
2022-01-19 00:40:40 +01:00
echo -e "${CHECKMARK} \e[1;92m Customizing Container... \e[0m"
2022-01-23 19:16:42 +01:00
chmod -x /etc/update-motd.d/*
2022-01-19 00:40:40 +01:00
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//')
echo -e "${CHECKMARK} \e[1;92m Cleanup... \e[0m"
2022-01-27 19:55:13 +01:00
rm -rf /plex_setup.sh /var/{cache,log}/* /var/lib/apt/lists/*