mirror of https://github.com/tteck/Proxmox
parent
93b998a06c
commit
b0540af12d
1 changed files with 282 additions and 0 deletions
@ -0,0 +1,282 @@ |
|||||||
|
#!/usr/bin/env bash |
||||||
|
|
||||||
|
set -e |
||||||
|
CROSS='\033[1;31m\xE2\x9D\x8C\033[0m' |
||||||
|
RD=`echo "\033[01;31m"` |
||||||
|
BL=`echo "\033[36m"` |
||||||
|
CM='\xE2\x9C\x94\033' |
||||||
|
GN=`echo "\033[1;92m"` |
||||||
|
CL=`echo "\033[m"` |
||||||
|
RETRY_NUM=5 |
||||||
|
RETRY_EVERY=3 |
||||||
|
NUM=$RETRY_NUM |
||||||
|
|
||||||
|
echo -en "${GN} Setting up Container OS... " |
||||||
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen |
||||||
|
locale-gen >/dev/null |
||||||
|
while [ "$(hostname -I)" = "" ]; do |
||||||
|
1>&2 echo -en "${CROSS}${RD} No Network! " |
||||||
|
sleep $RETRY_EVERY |
||||||
|
((NUM--)) |
||||||
|
if [ $NUM -eq 0 ] |
||||||
|
then |
||||||
|
1>&2 echo -e "${CROSS}${RD} No Network After $RETRY_NUM Tries${CL}" |
||||||
|
exit 1 |
||||||
|
fi |
||||||
|
done |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} " |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Updating Container OS... " |
||||||
|
apt update &>/dev/null |
||||||
|
apt-get -qqy upgrade &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Installing Dependencies... " |
||||||
|
apt-get install -y curl &>/dev/null |
||||||
|
apt-get install -y sudo &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Installing pip3... " |
||||||
|
apt-get install -y python3-pip &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Installing Docker... " |
||||||
|
DOCKER_CONFIG_PATH='/etc/docker/daemon.json' |
||||||
|
mkdir -p $(dirname $DOCKER_CONFIG_PATH) |
||||||
|
cat >$DOCKER_CONFIG_PATH <<'EOF' |
||||||
|
{ |
||||||
|
"log-driver": "journald" |
||||||
|
} |
||||||
|
EOF |
||||||
|
sh <(curl -sSL https://get.docker.com) &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Pulling Portainer Image... " |
||||||
|
docker pull portainer/portainer-ce:latest &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Installing Portainer Image... " |
||||||
|
docker volume create portainer_data >/dev/null |
||||||
|
docker run -d \ |
||||||
|
-p 8000:8000 \ |
||||||
|
-p 9000:9000 \ |
||||||
|
--name=portainer \ |
||||||
|
--restart=always \ |
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock \ |
||||||
|
-v portainer_data:/data \ |
||||||
|
portainer/portainer-ce:latest &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Pulling Home Assistant Image... " |
||||||
|
docker pull homeassistant/home-assistant:stable &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Installing Home Assistant Image... " |
||||||
|
docker volume create hass_config >/dev/null |
||||||
|
docker run -d \ |
||||||
|
--name homeassistant \ |
||||||
|
--privileged \ |
||||||
|
--restart unless-stopped \ |
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock \ |
||||||
|
-v /dev:/dev \ |
||||||
|
-v hass_config:/config \ |
||||||
|
-v /etc/localtime:/etc/localtime:ro \ |
||||||
|
--net=host \ |
||||||
|
homeassistant/home-assistant:stable &>/dev/null |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Creating Update Menu Script... " |
||||||
|
pip3 install runlike &>/dev/null |
||||||
|
UPDATE_PATH='/root/update' |
||||||
|
UPDATE_CONTAINERS_PATH='/root/update-containers.sh' |
||||||
|
cat >$UPDATE_PATH <<'EOF' |
||||||
|
#!/bin/sh |
||||||
|
set -o errexit |
||||||
|
show_menu(){ |
||||||
|
normal=`echo "\033[m"` |
||||||
|
safe=`echo "\033[32m"` |
||||||
|
menu=`echo "\033[36m"` |
||||||
|
number=`echo "\033[33m"` |
||||||
|
bgred=`echo "\033[41m"` |
||||||
|
fgred=`echo "\033[31m"` |
||||||
|
hostname -I |
||||||
|
printf "\n${menu}*********************************************${normal}\n" |
||||||
|
printf "${menu}**${number} 1)${safe} Switch to Stable Branch ${normal}\n" |
||||||
|
printf "${menu}**${number} 2)${number} Switch to Beta Branch ${normal}\n" |
||||||
|
printf "${menu}**${number} 3)${fgred} Switch to Dev Branch ${normal}\n" |
||||||
|
printf "${menu}**${number} 4)${safe} Backup Home Assistant Data (to root) ${normal}\n" |
||||||
|
printf "${menu}**${number} 5)${number} Restore Home Assistant Data ${normal}\n" |
||||||
|
printf "${menu}**${number} 6)${fgred} Edit Home Assistant Configuration ${normal}\n" |
||||||
|
printf "${menu}**${number} 7)${safe} Restart Home Assistant ${normal}\n" |
||||||
|
printf "${menu}**${number} 8)${safe} Just Update Containers ${normal}\n" |
||||||
|
printf "${menu}**${number} 9)${number} Remove Unused Images ${normal}\n" |
||||||
|
printf "${menu}**${number} 10)${safe} Update Host OS ${normal}\n" |
||||||
|
printf "${menu}**${number} 11)${safe} Reboot Host OS ${normal}\n" |
||||||
|
printf "${menu}*********************************************${normal}\n" |
||||||
|
printf "Please choose an option from the menu and enter or ${fgred}x to exit. ${normal}" |
||||||
|
read opt |
||||||
|
} |
||||||
|
option_picked(){ |
||||||
|
msgcolor=`echo "\033[01;31m"` |
||||||
|
normal=`echo "\033[00;00m"` |
||||||
|
message=${@:-"${normal}Error: No message passed"} |
||||||
|
printf "${msgcolor}${message}${normal}\n" |
||||||
|
} |
||||||
|
clear |
||||||
|
show_menu |
||||||
|
while [ $opt != '' ] |
||||||
|
do |
||||||
|
if [ $opt = '' ]; then |
||||||
|
exit; |
||||||
|
else |
||||||
|
case $opt in |
||||||
|
1) clear; |
||||||
|
option_picked "Switching to Stable Branch"; |
||||||
|
TAG=stable |
||||||
|
break; |
||||||
|
;; |
||||||
|
2) clear; |
||||||
|
option_picked "Switching to Beta Branch"; |
||||||
|
TAG=beta |
||||||
|
break; |
||||||
|
;; |
||||||
|
3) while true; do |
||||||
|
read -p "Are you sure you want to Switch to Dev Branch? Proceed(y/n)?" yn |
||||||
|
case $yn in |
||||||
|
[Yy]* ) break;; |
||||||
|
[Nn]* ) exit;; |
||||||
|
* ) echo "Please answer yes or no.";; |
||||||
|
esac |
||||||
|
done |
||||||
|
clear; |
||||||
|
option_picked "Switching to Dev Branch"; |
||||||
|
TAG=dev |
||||||
|
break; |
||||||
|
;; |
||||||
|
4) clear; |
||||||
|
option_picked "Backing up Home Assistant Data to root (hass_config)"; |
||||||
|
rm -r hass_config; |
||||||
|
cp -pR /var/lib/docker/volumes/hass_config/ /root/; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
5) while true; do |
||||||
|
read -p "Are you sure you want to Restore Home Assistant Data? Proceed(y/n)?" yn |
||||||
|
case $yn in |
||||||
|
[Yy]* ) break;; |
||||||
|
[Nn]* ) exit;; |
||||||
|
* ) echo "Please answer yes or no.";; |
||||||
|
esac |
||||||
|
done |
||||||
|
clear; |
||||||
|
option_picked "Restoring Home Assistant Data from root (hass_config)"; |
||||||
|
rm -r /var/lib/docker/volumes/hass_config/_data; |
||||||
|
cp -pR /root/hass_config/_data /var/lib/docker/volumes/hass_config/; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
6) while true; do |
||||||
|
read -p "Are you sure you want to Edit Home Assistant Configuration? Proceed(y/n)?" yn |
||||||
|
case $yn in |
||||||
|
[Yy]* ) break;; |
||||||
|
[Nn]* ) exit;; |
||||||
|
* ) echo "Please answer yes or no.";; |
||||||
|
esac |
||||||
|
done |
||||||
|
clear; |
||||||
|
option_picked "Editing Home Assistant Configuration"; |
||||||
|
nano /var/lib/docker/volumes/hass_config/_data/configuration.yaml; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
7) clear; |
||||||
|
option_picked "Restarting Home Assistant"; |
||||||
|
docker restart homeassistant; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
8) clear; |
||||||
|
option_picked "Just Updating Containers"; |
||||||
|
./update-containers.sh; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
9) clear; |
||||||
|
option_picked "Removing Unused Images"; |
||||||
|
docker image prune -af; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
10) clear; |
||||||
|
option_picked "Updating Host OS"; |
||||||
|
apt update && apt upgrade -y; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
11) clear; |
||||||
|
option_picked "Reboot Host OS"; |
||||||
|
reboot; |
||||||
|
exit; |
||||||
|
;; |
||||||
|
x)exit; |
||||||
|
;; |
||||||
|
\n)exit; |
||||||
|
;; |
||||||
|
*)clear; |
||||||
|
option_picked "Please choose an option from the menu"; |
||||||
|
show_menu; |
||||||
|
;; |
||||||
|
esac |
||||||
|
fi |
||||||
|
done |
||||||
|
docker pull homeassistant/home-assistant:$TAG |
||||||
|
docker rm --force homeassistant |
||||||
|
docker run -d \ |
||||||
|
--name homeassistant \ |
||||||
|
--privileged \ |
||||||
|
--restart unless-stopped \ |
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock \ |
||||||
|
-v /dev:/dev \ |
||||||
|
-v hass_config:/config \ |
||||||
|
-v /etc/localtime:/etc/localtime:ro \ |
||||||
|
-v /etc/timezone:/etc/timezone:ro \ |
||||||
|
--net=host \ |
||||||
|
homeassistant/home-assistant:$TAG |
||||||
|
EOF |
||||||
|
sudo chmod +x /root/update |
||||||
|
cat >$UPDATE_CONTAINERS_PATH <<'EOF' |
||||||
|
#!/bin/bash |
||||||
|
set -o errexit |
||||||
|
CONTAINER_LIST="${1:-$(docker ps -q)}" |
||||||
|
for container in ${CONTAINER_LIST}; do |
||||||
|
CONTAINER_IMAGE="$(docker inspect --format "{{.Config.Image}}" --type container ${container})" |
||||||
|
RUNNING_IMAGE="$(docker inspect --format "{{.Image}}" --type container "${container}")" |
||||||
|
docker pull "${CONTAINER_IMAGE}" |
||||||
|
LATEST_IMAGE="$(docker inspect --format "{{.Id}}" --type image "${CONTAINER_IMAGE}")" |
||||||
|
if [[ "${RUNNING_IMAGE}" != "${LATEST_IMAGE}" ]]; then |
||||||
|
echo "Updating ${container} image ${CONTAINER_IMAGE}" |
||||||
|
DOCKER_COMMAND="$(runlike "${container}")" |
||||||
|
docker rm --force "${container}" |
||||||
|
eval ${DOCKER_COMMAND} |
||||||
|
fi |
||||||
|
done |
||||||
|
EOF |
||||||
|
sudo chmod +x /root/update-containers.sh |
||||||
|
echo -e "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Customizing Container... " |
||||||
|
rm /etc/motd |
||||||
|
rm /etc/update-motd.d/10-uname |
||||||
|
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 "${CM}${CL} \r" |
||||||
|
|
||||||
|
echo -en "${GN} Cleanup... " |
||||||
|
apt-get autoremove >/dev/null |
||||||
|
apt-get autoclean >/dev/null |
||||||
|
rm -rf /var/{cache,log}/* /var/lib/apt/lists/* |
||||||
|
echo -e "${CM}${CL} \n" |
||||||
|
|
Loading…
Reference in new issue