mirror of https://github.com/tteck/Proxmox.git
commit
efb555914a
19
CHANGELOG.MD
19
CHANGELOG.MD
|
@ -5,12 +5,29 @@ All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
### ⚠️ [IMPORTANT NOTICE](https://github.com/tteck/Proxmox/issues/71#issue-1169207591)
|
### ⚠️ [IMPORTANT NOTICE](https://github.com/tteck/Proxmox/issues/71#issue-1169207591)
|
||||||
|
|
||||||
|
## 2022-04-18
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- **Adguard LXC**
|
||||||
|
- New [V3 Install Script](https://github.com/tteck/Proxmox/issues/162)
|
||||||
|
- **Homebridge LXC**
|
||||||
|
- New V3 Install Script
|
||||||
|
- **Uptime Kuma LXC**
|
||||||
|
- New V3 Install Script
|
||||||
|
- **Vaultwarden LXC**
|
||||||
|
- New V3 Install Script
|
||||||
|
- **Motioneye LXC**
|
||||||
|
- New V3 Install Script
|
||||||
|
- **Nginx Proxy Manager LXC**
|
||||||
|
- New V3 Install Script
|
||||||
|
|
||||||
## 2022-04-17
|
## 2022-04-17
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- **Zigbee2MQTT LXC**
|
- **Zigbee2MQTT LXC**
|
||||||
- New [V3 Install Script](https://github.com/tteck/Proxmox/issues/162)
|
- New V3 Install Script
|
||||||
- **Zwavejs2MQTT LXC**
|
- **Zwavejs2MQTT LXC**
|
||||||
- New V3 Install Script
|
- New V3 Install Script
|
||||||
- **ESPHome LXC**
|
- **ESPHome LXC**
|
||||||
|
|
36
README.md
36
README.md
|
@ -271,17 +271,17 @@ ________________________________________________________________________________
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary markdown="span"> Homebridge LXC</summary>
|
<summary markdown="span"> 🔸Homebridge LXC</summary>
|
||||||
|
|
||||||
<p align="center"><img src="https://external-content.duckduckgo.com/iu/?u=https%3A%2F%2Fwww.dingz.ch%2Fadmin%2Fdata%2Ffiles%2Fintegration%2Flogo%2F20%2F200514-em-logo-homebridge_logo.png%3Flm%3D1589459081&f=1&nofb=1" height="100"/></p>
|
<p align="center"><img src="https://external-content.duckduckgo.com/iu/?u=https%3A%2F%2Fwww.dingz.ch%2Fadmin%2Fdata%2Ffiles%2Fintegration%2Flogo%2F20%2F200514-em-logo-homebridge_logo.png%3Flm%3D1589459081&f=1&nofb=1" height="100"/></p>
|
||||||
|
|
||||||
<h1 align="center" id="heading"> Homebridge LXC </h1>
|
<h1 align="center" id="heading"> Homebridge LXC </h1>
|
||||||
Homebridge allows you to integrate with smart home devices that do not natively support HomeKit
|
Homebridge allows you to integrate with smart home devices that do not natively support HomeKit
|
||||||
|
|
||||||
To create a new Proxmox Homebridge LXC, run the following in the Proxmox Shell (V2).
|
To create a new Proxmox Homebridge LXC, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/homebridge.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/homebridge-v3.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
<h3 align="center" id="heading">⚡ Default Settings: 1GB RAM - 4GB Storage - 1vCPU ⚡</h3>
|
<h3 align="center" id="heading">⚡ Default Settings: 1GB RAM - 4GB Storage - 1vCPU ⚡</h3>
|
||||||
|
@ -357,17 +357,17 @@ ________________________________________________________________________________
|
||||||
|
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary markdown="span"> Nginx Proxy Manager LXC </summary>
|
<summary markdown="span"> 🔸Nginx Proxy Manager LXC </summary>
|
||||||
|
|
||||||
<p align="center"><img src="https://nginxproxymanager.com/logo.png" alt="hero" height="100"/></p>
|
<p align="center"><img src="https://nginxproxymanager.com/logo.png" alt="hero" height="100"/></p>
|
||||||
|
|
||||||
|
|
||||||
<h1 align="center" id="heading"> Nginx Proxy Manager LXC </h1>
|
<h1 align="center" id="heading"> Nginx Proxy Manager LXC </h1>
|
||||||
|
|
||||||
To create a new Proxmox Nginx Proxy Manager LXC Container, run the following in the Proxmox Shell (V2).
|
To create a new Proxmox Nginx Proxy Manager LXC Container, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/nginx-proxy-manager.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/nginx-proxy-manager-v3.sh)"
|
||||||
```
|
```
|
||||||
<h3 align="center" id="heading">⚡ Default Settings: 1GB RAM - 3GB Storage - 1vCPU ⚡</h3>
|
<h3 align="center" id="heading">⚡ Default Settings: 1GB RAM - 3GB Storage - 1vCPU ⚡</h3>
|
||||||
|
|
||||||
|
@ -1138,16 +1138,16 @@ ________________________________________________________________________________
|
||||||
|
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary markdown="span"> AdGuard Home LXC</summary>
|
<summary markdown="span"> 🔸AdGuard Home LXC</summary>
|
||||||
|
|
||||||
<p align="center"><img src="https://github.com/home-assistant/brands/blob/master/core_integrations/adguard/icon.png?raw=true" height="100"/></p>
|
<p align="center"><img src="https://github.com/home-assistant/brands/blob/master/core_integrations/adguard/icon.png?raw=true" height="100"/></p>
|
||||||
|
|
||||||
<h1 align="center" id="heading"> AdGuard Home LXC </h1>
|
<h1 align="center" id="heading"> AdGuard Home LXC </h1>
|
||||||
|
|
||||||
To create a new Proxmox AdGuard Home LXC, run the following in the Proxmox Shell (V2).
|
To create a new Proxmox AdGuard Home LXC, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/adguard.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/adguard-v3.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
<h3 align="center" id="heading">⚡ Default Settings: 512MiB RAM - 2GB Storage - 1vCPU ⚡</h3>
|
<h3 align="center" id="heading">⚡ Default Settings: 512MiB RAM - 2GB Storage - 1vCPU ⚡</h3>
|
||||||
|
@ -1174,16 +1174,14 @@ ________________________________________________________________________________
|
||||||
|
|
||||||
Uptime Kuma is a self-hosted, open source, fancy uptime monitoring and alerting system. It can monitor HTTP(s) / TCP / HTTP(s) Keyword / Ping / DNS Record / Push / Steam Game Server.
|
Uptime Kuma is a self-hosted, open source, fancy uptime monitoring and alerting system. It can monitor HTTP(s) / TCP / HTTP(s) Keyword / Ping / DNS Record / Push / Steam Game Server.
|
||||||
|
|
||||||
To create a new Proxmox Uptime Kuma LXC, run the following in the Proxmox Shell (V2).
|
To create a new Proxmox Uptime Kuma LXC, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/uptimekuma.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/uptimekuma-v3.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
<h3 align="center" id="heading">⚡ Default Settings: 512MiB RAM - 2GB Storage - 1vCPU ⚡</h3>
|
<h3 align="center" id="heading">⚡ Default Settings: 512MiB RAM - 2GB Storage - 1vCPU ⚡</h3>
|
||||||
|
|
||||||
After the script completes, If you're dissatisfied with the default settings, click on the LXC, then on the **_Resources_** tab and change the settings to what you desire. Changes are immediate.
|
|
||||||
|
|
||||||
**Uptime Kuma Interface - IP:3001**
|
**Uptime Kuma Interface - IP:3001**
|
||||||
|
|
||||||
⚙️ **To Update**
|
⚙️ **To Update**
|
||||||
|
@ -1328,22 +1326,20 @@ ________________________________________________________________________________
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary markdown="span"> MotionEye VMS LXC </summary>
|
<summary markdown="span"> 🔸MotionEye VMS LXC </summary>
|
||||||
|
|
||||||
<p align="center"><img src="https://github.com/home-assistant/brands/blob/master/core_integrations/motioneye/icon.png?raw=true" height="100"/></p>
|
<p align="center"><img src="https://github.com/home-assistant/brands/blob/master/core_integrations/motioneye/icon.png?raw=true" height="100"/></p>
|
||||||
|
|
||||||
<h1 align="center" id="heading"> MotionEye VMS LXC </h1>
|
<h1 align="center" id="heading"> MotionEye VMS LXC </h1>
|
||||||
|
|
||||||
To create a new Proxmox MotionEye VMS LXC, run the following in the Proxmox Shell (V2).
|
To create a new Proxmox MotionEye VMS LXC, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```
|
```
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/motioneye.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/motioneye-v3.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
<h3 align="center" id="heading">⚡ Default Settings: 2GB RAM - 8GB Storage - 2vCPU ⚡</h3>
|
<h3 align="center" id="heading">⚡ Default Settings: 2GB RAM - 8GB Storage - 2vCPU ⚡</h3>
|
||||||
|
|
||||||
After the script completes, If you're dissatisfied with the default settings, click on the LXC, then on the **_Resources_** tab and change the settings to what you desire. Changes are immediate.
|
|
||||||
|
|
||||||
**MotionEye Interface - IP:8765**
|
**MotionEye Interface - IP:8765**
|
||||||
|
|
||||||
⚙️ **Initial Login**
|
⚙️ **Initial Login**
|
||||||
|
@ -1470,7 +1466,7 @@ ________________________________________________________________________________
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary markdown="span"> Vaultwarden LXC</summary>
|
<summary markdown="span"> 🔸Vaultwarden LXC</summary>
|
||||||
|
|
||||||
<p align="center"><img src="https://raw.githubusercontent.com/dani-garcia/vaultwarden/main/resources/vaultwarden-icon-white.svg" width="100" height="100"/></p>
|
<p align="center"><img src="https://raw.githubusercontent.com/dani-garcia/vaultwarden/main/resources/vaultwarden-icon-white.svg" width="100" height="100"/></p>
|
||||||
|
|
||||||
|
@ -1479,7 +1475,7 @@ ________________________________________________________________________________
|
||||||
To create a new Proxmox Vaultwarden LXC, run the following in the Proxmox Shell.
|
To create a new Proxmox Vaultwarden LXC, run the following in the Proxmox Shell.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/vaultwarden.sh)"
|
bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/vaultwarden-v3.sh)"
|
||||||
```
|
```
|
||||||
⚠️ Vaultwarden needs to be behind a proxy (Nginx Proxy Manager) to obtain HTTPS and to allow clients to connect.
|
⚠️ Vaultwarden needs to be behind a proxy (Nginx Proxy Manager) to obtain HTTPS and to allow clients to connect.
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,317 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Adguard"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${GN}
|
||||||
|
_ _
|
||||||
|
/\ | | | |
|
||||||
|
/ \ __| | __ _ _ _ __ _ _ __ __| |
|
||||||
|
/ /\ \ / _ |/ _ | | | |/ _ | __/ _ |
|
||||||
|
/ ____ \ (_| | (_| | |_| | (_| | | | (_| |
|
||||||
|
/_/ \_\__,_|\__, |\__,_|\__,_|_| \__,_|
|
||||||
|
v3__/ |
|
||||||
|
|___/
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}2GB${CL}"
|
||||||
|
DISK_SIZE="2"
|
||||||
|
echo -e "${DGN}Using ${BGN}1vCPU${CL}"
|
||||||
|
CORE_COUNT="1"
|
||||||
|
echo -e "${DGN}Using ${BGN}512MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="512"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 2Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="2"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 1 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="1"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 512 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="512"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/adguard-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "Adguard Setup should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:3000${CL} \n"
|
|
@ -302,11 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg_info "Starting LXC Container"
|
msg_info "Starting LXC Container"
|
||||||
pct start $CTID
|
pct start $CTID
|
||||||
msg_ok "Started LXC Container"
|
msg_ok "Started LXC Container"
|
||||||
|
|
|
@ -302,10 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
||||||
cat <<EOF >> $LXC_CONFIG
|
cat <<EOF >> $LXC_CONFIG
|
||||||
lxc.cgroup2.devices.allow: a
|
lxc.cgroup2.devices.allow: a
|
||||||
|
|
|
@ -302,11 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg_info "Starting LXC Container"
|
msg_info "Starting LXC Container"
|
||||||
pct start $CTID
|
pct start $CTID
|
||||||
msg_ok "Started LXC Container"
|
msg_ok "Started LXC Container"
|
||||||
|
|
|
@ -302,10 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
||||||
cat <<EOF >> $LXC_CONFIG
|
cat <<EOF >> $LXC_CONFIG
|
||||||
lxc.cgroup2.devices.allow: a
|
lxc.cgroup2.devices.allow: a
|
||||||
|
|
|
@ -0,0 +1,315 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Homebridge"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${YW}
|
||||||
|
_ _ ____ __ __ ______ ____ _____ _____ _____ _____ ______
|
||||||
|
| | | |/ __ \| \/ | ____| _ \| __ \|_ _| __ \ / ____| ____|
|
||||||
|
| |__| | | | | \ / | |__ | |_) | |__) | | | | | | | | __| |__
|
||||||
|
| __ | | | | |\/| | __| | _ <| _ / | | | | | | | |_ | __|
|
||||||
|
| | | | |__| | | | | |____| |_) | | \ \ _| |_| |__| | |__| | |____
|
||||||
|
|_|v3|_|\____/|_| |_|______|____/|_| \_\_____|_____/ \_____|______|
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}4GB${CL}"
|
||||||
|
DISK_SIZE="4"
|
||||||
|
echo -e "${DGN}Using ${BGN}1vCPU${CL}"
|
||||||
|
CORE_COUNT="1"
|
||||||
|
echo -e "${DGN}Using ${BGN}1024MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="1024"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 4Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="4"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 1 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="1"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 1024 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="1024"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/homebridge-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "Homebridge should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:8581${CL} \n"
|
|
@ -0,0 +1,315 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Motioneye"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${BL}
|
||||||
|
__ __ ____ _______ _____ ____ _ _ ________ ________
|
||||||
|
| \/ |/ __ \__ __|_ _/ __ \| \ | | ____\ \ / / ____|
|
||||||
|
| \ / | | | | | | | || | | | \| | |__ \ \_/ /| |__
|
||||||
|
| |\/| | | | | | | | || | | | | __| \ / | __|
|
||||||
|
| | | | |__| | | | v3_| || |__| | |\ | |____ | | | |____
|
||||||
|
|_| |_|\____/ |_| |_____\____/|_| \_|______| |_| |______|
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}8GB${CL}"
|
||||||
|
DISK_SIZE="8"
|
||||||
|
echo -e "${DGN}Using ${BGN}2vCPU${CL}"
|
||||||
|
CORE_COUNT="2"
|
||||||
|
echo -e "${DGN}Using ${BGN}2048MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="2048"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 8Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="8"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 2 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="2"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 2048 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="2048"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/motioneye-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "${APP} should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:8765${CL} \n"
|
|
@ -0,0 +1,315 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Nginx Proxy Manager"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${RD}
|
||||||
|
_ _ _____ __ __
|
||||||
|
| \ | | __ \| \/ |
|
||||||
|
| \| | |__) | \ / |
|
||||||
|
| | ___/| |\/| |
|
||||||
|
| |\ | | | | | |
|
||||||
|
|_| \_|_| v3 |_| |_|
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}3GB${CL}"
|
||||||
|
DISK_SIZE="3"
|
||||||
|
echo -e "${DGN}Using ${BGN}1vCPU${CL}"
|
||||||
|
CORE_COUNT="1"
|
||||||
|
echo -e "${DGN}Using ${BGN}1024MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="1024"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 3Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="3"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 1 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="1"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 1024 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="1024"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/nginx-proxy-manager-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "${APP} should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:81${CL} \n"
|
|
@ -302,11 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg_info "Starting LXC Container"
|
msg_info "Starting LXC Container"
|
||||||
pct start $CTID
|
pct start $CTID
|
||||||
msg_ok "Started LXC Container"
|
msg_ok "Started LXC Container"
|
||||||
|
|
|
@ -307,10 +307,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
||||||
cat <<EOF >> $LXC_CONFIG
|
cat <<EOF >> $LXC_CONFIG
|
||||||
lxc.cgroup2.devices.allow: a
|
lxc.cgroup2.devices.allow: a
|
||||||
|
|
|
@ -302,11 +302,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg_info "Starting LXC Container"
|
msg_info "Starting LXC Container"
|
||||||
pct start $CTID
|
pct start $CTID
|
||||||
msg_ok "Started LXC Container"
|
msg_ok "Started LXC Container"
|
||||||
|
|
|
@ -0,0 +1,317 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Uptime Kuma"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${DGN}
|
||||||
|
_ _ _ _ _ __
|
||||||
|
| | | | | | (_) | |/ /
|
||||||
|
| | | |_v3_ | |_ _ _ __ ___ ___ | ' /_ _ _ __ ___ __ _
|
||||||
|
| | | | _ \| __| | _ _ \ / _ \ | <| | | | _ _ \ / _ |
|
||||||
|
| |__| | |_) | |_| | | | | | | __/ | . \ |_| | | | | | | (_| |
|
||||||
|
\____/| .__/ \__|_|_| |_| |_|\___| |_|\_\__,_|_| |_| |_|\__,_|
|
||||||
|
| |
|
||||||
|
|_|
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}2GB${CL}"
|
||||||
|
DISK_SIZE="2"
|
||||||
|
echo -e "${DGN}Using ${BGN}1vCPU${CL}"
|
||||||
|
CORE_COUNT="1"
|
||||||
|
echo -e "${DGN}Using ${BGN}512MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="512"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 2Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="2"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 1 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="1"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 512 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="512"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/uptimekuma-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "${APP} should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:3001${CL}\n"
|
|
@ -0,0 +1,315 @@
|
||||||
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
|
shopt -s inherit_errexit nullglob
|
||||||
|
|
||||||
|
NEXTID=$(pvesh get /cluster/nextid)
|
||||||
|
INTEGER='^[0-9]+$'
|
||||||
|
YW=`echo "\033[33m"`
|
||||||
|
BL=`echo "\033[36m"`
|
||||||
|
RD=`echo "\033[01;31m"`
|
||||||
|
BGN=`echo "\033[4;92m"`
|
||||||
|
GN=`echo "\033[1;92m"`
|
||||||
|
DGN=`echo "\033[32m"`
|
||||||
|
CL=`echo "\033[m"`
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
APP="Vaultwarden"
|
||||||
|
NSAPP=$(echo ${APP,,} | tr -d ' ')
|
||||||
|
while true; do
|
||||||
|
read -p "This will create a New ${APP} LXC. Proceed(y/n)?" yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) break;;
|
||||||
|
[Nn]* ) exit;;
|
||||||
|
* ) echo "Please answer yes or no.";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
clear
|
||||||
|
function header_info {
|
||||||
|
echo -e "${RD}
|
||||||
|
__ __ _ _ _
|
||||||
|
\ \ v3 / / | | | | |
|
||||||
|
\ \ / /_ _ _ _| | |___ ____ _ _ __ __| | ___ _ __
|
||||||
|
\ \/ / _ | | | | | __\ \ /\ / / _ | __/ _ |/ _ \ _ \
|
||||||
|
\ / (_| | |_| | | |_ \ V V / (_| | | | (_| | __/ | | |
|
||||||
|
\/ \__,_|\__,_|_|\__| \_/\_/ \__,_|_| \__,_|\___|_| |_|
|
||||||
|
${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
header_info
|
||||||
|
|
||||||
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function PVE_CHECK() {
|
||||||
|
PVE=$(pveversion | grep "pve-manager/7" | wc -l)
|
||||||
|
|
||||||
|
if [[ $PVE != 1 ]]; then
|
||||||
|
echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
|
||||||
|
echo -e "Exiting..."
|
||||||
|
sleep 2
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function default_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${BL}Using Default Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}Unprivileged${CL} ${RD}NO DEVICE PASSTHROUGH${CL}"
|
||||||
|
CT_TYPE="1"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}Automatic Login${CL}"
|
||||||
|
PW=" "
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$NEXTID${CL}"
|
||||||
|
CT_ID=$NEXTID
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$NSAPP${CL}"
|
||||||
|
HN=$NSAPP
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}8GB${CL}"
|
||||||
|
DISK_SIZE="8"
|
||||||
|
echo -e "${DGN}Using ${BGN}4vCPU${CL}"
|
||||||
|
CORE_COUNT="4"
|
||||||
|
echo -e "${DGN}Using ${BGN}4096MiB${CL}${DGN} RAM${CL}"
|
||||||
|
RAM_SIZE="4096"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}DHCP${CL}"
|
||||||
|
NET=dhcp
|
||||||
|
echo -e "${DGN}Using Gateway Address ${BGN}NONE${CL}"
|
||||||
|
GATE=" "
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}NONE${CL}"
|
||||||
|
VLAN=" "
|
||||||
|
}
|
||||||
|
|
||||||
|
function advanced_settings() {
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${YW}Type Privileged, or Press [ENTER] for Default: Unprivileged (${RD}NO DEVICE PASSTHROUGH${CL}${YW})"
|
||||||
|
read CT_TYPE1
|
||||||
|
if [ -z $CT_TYPE1 ]; then CT_TYPE1="Unprivileged" CT_TYPE="1";
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}$CT_TYPE1${CL}"
|
||||||
|
else
|
||||||
|
CT_TYPE1="Privileged"
|
||||||
|
CT_TYPE="0"
|
||||||
|
echo -en "${DGN}Set CT Type ${BL}Privileged${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${YW}Set Password, or Press [ENTER] for Default: Automatic Login "
|
||||||
|
read PW1
|
||||||
|
if [ -z $PW1 ]; then PW1="Automatic Login" PW=" ";
|
||||||
|
echo -en "${DGN}Set CT ${BL}$PW1${CL}"
|
||||||
|
else
|
||||||
|
PW="-password $PW1"
|
||||||
|
echo -en "${DGN}Set CT Password ${BL}$PW1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${YW}Enter the CT ID, or Press [ENTER] to automatically generate (${NEXTID}) "
|
||||||
|
read CT_ID
|
||||||
|
if [ -z $CT_ID ]; then CT_ID=$NEXTID; fi;
|
||||||
|
echo -en "${DGN}Set CT ID To ${BL}$CT_ID${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${YW}Enter CT Name (no-spaces), or Press [ENTER] for Default: $NSAPP "
|
||||||
|
read CT_NAME
|
||||||
|
if [ -z $CT_NAME ]; then
|
||||||
|
HN=$NSAPP
|
||||||
|
else
|
||||||
|
HN=$(echo ${CT_NAME,,} | tr -d ' ')
|
||||||
|
fi
|
||||||
|
echo -en "${DGN}Set CT Name To ${BL}$HN${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${YW}Enter a Disk Size, or Press [ENTER] for Default: 8Gb "
|
||||||
|
read DISK_SIZE
|
||||||
|
if [ -z $DISK_SIZE ]; then DISK_SIZE="8"; fi;
|
||||||
|
if ! [[ $DISK_SIZE =~ $INTEGER ]] ; then echo "ERROR! DISK SIZE MUST HAVE INTEGER NUMBER!"; exit; fi;
|
||||||
|
echo -en "${DGN}Set Disk Size To ${BL}$DISK_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${YW}Allocate CPU cores, or Press [ENTER] for Default: 4 "
|
||||||
|
read CORE_COUNT
|
||||||
|
if [ -z $CORE_COUNT ]; then CORE_COUNT="4"; fi;
|
||||||
|
echo -en "${DGN}Set Cores To ${BL}$CORE_COUNT${CL}"
|
||||||
|
echo -e " ${CM}${CL} \r"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${YW}Allocate RAM in MiB, or Press [ENTER] for Default: 4096 "
|
||||||
|
read RAM_SIZE
|
||||||
|
if [ -z $RAM_SIZE ]; then RAM_SIZE="4096"; fi;
|
||||||
|
echo -en "${DGN}Set RAM To ${BL}$RAM_SIZE${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${YW}Enter a Static IP Address, or Press [ENTER] for Default: DHCP "
|
||||||
|
read NET
|
||||||
|
if [ -z $NET ]; then NET="dhcp"; fi;
|
||||||
|
echo -en "${DGN}Set Static IP Address To ${BL}$NET${CL}"
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${YW}Enter a Gateway IP, or Press [ENTER] for Default: NONE "
|
||||||
|
read GATE1
|
||||||
|
if [ -z $GATE1 ]; then GATE1="NONE" GATE=" ";
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
else
|
||||||
|
GATE=",gw=$GATE1"
|
||||||
|
echo -en "${DGN}Set Gateway IP To ${BL}$GATE1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${YW}Enter a VLAN Tag, or Press [ENTER] for Default: NONE "
|
||||||
|
read VLAN1
|
||||||
|
if [ -z $VLAN1 ]; then VLAN1="NONE" VLAN=" ";
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
else
|
||||||
|
VLAN=",tag=$VLAN1"
|
||||||
|
echo -en "${DGN}Set VLAN Tag To ${BL}$VLAN1${CL}"
|
||||||
|
fi;
|
||||||
|
echo -e " ${CM}${CL} \n"
|
||||||
|
sleep 1
|
||||||
|
clear
|
||||||
|
header_info
|
||||||
|
echo -e "${RD}Using Advanced Settings${CL}"
|
||||||
|
echo -e "${DGN}Using CT Type ${BGN}$CT_TYPE1${CL}"
|
||||||
|
echo -e "${DGN}Using CT Password ${BGN}$PW1${CL}"
|
||||||
|
echo -e "${DGN}Using CT ID ${BGN}$CT_ID${CL}"
|
||||||
|
echo -e "${DGN}Using CT Name ${BGN}$HN${CL}"
|
||||||
|
echo -e "${DGN}Using Disk Size ${BGN}$DISK_SIZE${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${CORE_COUNT}vCPU${CL}"
|
||||||
|
echo -e "${DGN}Using ${BGN}${RAM_SIZE}MiB${CL}${DGN} RAM${CL}"
|
||||||
|
echo -e "${DGN}Using Static IP Address ${BGN}$NET${CL}"
|
||||||
|
echo -e "${DGN}Using Gateway IP Address ${BGN}$GATE1${CL}"
|
||||||
|
echo -e "${DGN}Using VLAN Tag ${BGN}$VLAN1${CL}"
|
||||||
|
|
||||||
|
read -p "Are these settings correct(y/n)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ ! $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
advanced_settings
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function start_script() {
|
||||||
|
echo -e "${YW}Type Advanced, or Press [ENTER] for Default Settings "
|
||||||
|
read SETTINGS
|
||||||
|
if [ -z $SETTINGS ]; then default_settings;
|
||||||
|
else
|
||||||
|
advanced_settings
|
||||||
|
fi;
|
||||||
|
}
|
||||||
|
|
||||||
|
start_script
|
||||||
|
|
||||||
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
FEATURES="nesting=1,keyctl=1"
|
||||||
|
else
|
||||||
|
FEATURES="nesting=1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
pushd $TEMP_DIR >/dev/null
|
||||||
|
|
||||||
|
export CTID=$CT_ID
|
||||||
|
export PCT_OSTYPE=debian
|
||||||
|
export PCT_OSVERSION=11
|
||||||
|
export PCT_DISK_SIZE=$DISK_SIZE
|
||||||
|
export PCT_OPTIONS="
|
||||||
|
-features $FEATURES
|
||||||
|
-hostname $HN
|
||||||
|
-net0 name=eth0,bridge=vmbr0,ip=$NET$GATE$VLAN
|
||||||
|
-onboot 1
|
||||||
|
-cores $CORE_COUNT
|
||||||
|
-memory $RAM_SIZE
|
||||||
|
-unprivileged $CT_TYPE
|
||||||
|
$PW
|
||||||
|
"
|
||||||
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
|
msg_info "Starting LXC Container"
|
||||||
|
pct start $CTID
|
||||||
|
msg_ok "Started LXC Container"
|
||||||
|
|
||||||
|
lxc-attach -n $CTID -- bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/setup/vaultwarden-install.sh)" || exit
|
||||||
|
|
||||||
|
IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "${APP} should be reachable by going to the following URL.
|
||||||
|
${BL}http://${IP}:8000${CL} \n"
|
|
@ -275,6 +275,7 @@ function start_script() {
|
||||||
fi;
|
fi;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PVE_CHECK
|
||||||
start_script
|
start_script
|
||||||
|
|
||||||
if [ "$CT_TYPE" == "1" ]; then
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
@ -302,11 +303,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
||||||
cat <<EOF >> $LXC_CONFIG
|
cat <<EOF >> $LXC_CONFIG
|
||||||
lxc.cgroup2.devices.allow: a
|
lxc.cgroup2.devices.allow: a
|
||||||
|
|
|
@ -275,6 +275,7 @@ function start_script() {
|
||||||
fi;
|
fi;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PVE_CHECK
|
||||||
start_script
|
start_script
|
||||||
|
|
||||||
if [ "$CT_TYPE" == "1" ]; then
|
if [ "$CT_TYPE" == "1" ]; then
|
||||||
|
@ -302,10 +303,6 @@ export PCT_OPTIONS="
|
||||||
"
|
"
|
||||||
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
bash -c "$(wget -qLO - https://raw.githubusercontent.com/tteck/Proxmox/main/ct/create_lxc.sh)" || exit
|
||||||
|
|
||||||
STORAGE_TYPE=$(pvesm status -storage $(pct config $CTID | grep rootfs | awk -F ":" '{print $2}') | awk 'NR>1 {print $2}')
|
|
||||||
if [ "$STORAGE_TYPE" == "zfspool" ]; then
|
|
||||||
echo -e "${RD}Some applications may not work properly due to ZFS not supporting 'fallocate'.${CL}"
|
|
||||||
fi
|
|
||||||
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
LXC_CONFIG=/etc/pve/lxc/${CTID}.conf
|
||||||
cat <<EOF >> $LXC_CONFIG
|
cat <<EOF >> $LXC_CONFIG
|
||||||
lxc.cgroup2.devices.allow: a
|
lxc.cgroup2.devices.allow: a
|
||||||
|
|
|
@ -1,38 +1,30 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
set -o errexit
|
shopt -s inherit_errexit nullglob
|
||||||
set -o errtrace
|
YW=`echo "\033[33m"`
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
shopt -s expand_aliases
|
|
||||||
alias die='EXIT=$? LINE=$LINENO error_exit'
|
|
||||||
trap die ERR
|
|
||||||
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"
|
|
||||||
}
|
|
||||||
|
|
||||||
RD=`echo "\033[01;31m"`
|
RD=`echo "\033[01;31m"`
|
||||||
BL=`echo "\033[36m"`
|
BL=`echo "\033[36m"`
|
||||||
GN=`echo "\033[1;92m"`
|
GN=`echo "\033[1;92m"`
|
||||||
CL=`echo "\033[m"`
|
CL=`echo "\033[m"`
|
||||||
CM="${GN}✓${CL}"
|
|
||||||
CROSS="${RD}✗${CL}"
|
|
||||||
RETRY_NUM=10
|
RETRY_NUM=10
|
||||||
RETRY_EVERY=3
|
RETRY_EVERY=3
|
||||||
NUM=$RETRY_NUM
|
NUM=$RETRY_NUM
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
CROSS="${RD}✗${CL}"
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Container OS... "
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_info "Setting up Container OS "
|
||||||
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
||||||
locale-gen >/dev/null
|
locale-gen >/dev/null
|
||||||
while [ "$(hostname -I)" = "" ]; do
|
while [ "$(hostname -I)" = "" ]; do
|
||||||
|
@ -45,27 +37,26 @@ while [ "$(hostname -I)" = "" ]; do
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Container OS"
|
||||||
echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} "
|
msg_ok "Network Connected: ${BL}$(hostname -I)"
|
||||||
echo -e "${CM}${CL} \r"
|
|
||||||
|
|
||||||
echo -en "${GN} Updating Container OS... "
|
msg_info "Updating Container OS"
|
||||||
apt update &>/dev/null
|
apt update &>/dev/null
|
||||||
apt-get -qqy upgrade &>/dev/null
|
apt-get -qqy upgrade &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Updated Container OS"
|
||||||
|
|
||||||
echo -en "${GN} Installing Dependencies... "
|
msg_info "Installing Dependencies"
|
||||||
apt-get install -y curl &>/dev/null
|
apt-get install -y curl &>/dev/null
|
||||||
apt-get install -y sudo &>/dev/null
|
apt-get install -y sudo &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
echo -en "${GN} Installing AdGuard Home... "
|
msg_info "Installing AdGuard Home"
|
||||||
curl -sSL https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh &>/dev/null
|
curl -sSL https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed AdGuard Home"
|
||||||
|
|
||||||
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
||||||
if [[ $PASS != $ ]]; then
|
if [[ $PASS != $ ]]; then
|
||||||
echo -en "${GN} Customizing Container... "
|
msg_info "Customizing Container"
|
||||||
rm /etc/motd
|
rm /etc/motd
|
||||||
rm /etc/update-motd.d/10-uname
|
rm /etc/update-motd.d/10-uname
|
||||||
touch ~/.hushlogin
|
touch ~/.hushlogin
|
||||||
|
@ -78,11 +69,11 @@ ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,3840
|
||||||
EOF
|
EOF
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Customized Container"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -en "${GN} Cleanup... "
|
msg_info "Cleaning up"
|
||||||
apt-get autoremove >/dev/null
|
apt-get autoremove >/dev/null
|
||||||
apt-get autoclean >/dev/null
|
apt-get autoclean >/dev/null
|
||||||
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
||||||
echo -e "${CM}${CL} \n"
|
msg_ok "Cleaned"
|
||||||
|
|
|
@ -1,38 +1,30 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
set -o errexit
|
shopt -s inherit_errexit nullglob
|
||||||
set -o errtrace
|
YW=`echo "\033[33m"`
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
shopt -s expand_aliases
|
|
||||||
alias die='EXIT=$? LINE=$LINENO error_exit'
|
|
||||||
trap die ERR
|
|
||||||
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"
|
|
||||||
}
|
|
||||||
|
|
||||||
RD=`echo "\033[01;31m"`
|
RD=`echo "\033[01;31m"`
|
||||||
BL=`echo "\033[36m"`
|
BL=`echo "\033[36m"`
|
||||||
GN=`echo "\033[1;92m"`
|
GN=`echo "\033[1;92m"`
|
||||||
CL=`echo "\033[m"`
|
CL=`echo "\033[m"`
|
||||||
CM="${GN}✓${CL}"
|
|
||||||
CROSS="${RD}✗${CL}"
|
|
||||||
RETRY_NUM=10
|
RETRY_NUM=10
|
||||||
RETRY_EVERY=3
|
RETRY_EVERY=3
|
||||||
NUM=$RETRY_NUM
|
NUM=$RETRY_NUM
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
CROSS="${RD}✗${CL}"
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Container OS... "
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_info "Setting up Container OS "
|
||||||
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
||||||
locale-gen >/dev/null
|
locale-gen >/dev/null
|
||||||
while [ "$(hostname -I)" = "" ]; do
|
while [ "$(hostname -I)" = "" ]; do
|
||||||
|
@ -45,16 +37,18 @@ while [ "$(hostname -I)" = "" ]; do
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Container OS"
|
||||||
echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} "
|
msg_ok "Network Connected: ${BL}$(hostname -I)"
|
||||||
echo -e "${CM}${CL} \r"
|
|
||||||
|
|
||||||
echo -en "${GN} Installing Dependencies... "
|
msg_info "Updating Container OS"
|
||||||
apt-get update &>/dev/null
|
apt update &>/dev/null
|
||||||
apt-get -qqy install \
|
apt-get -qqy upgrade &>/dev/null
|
||||||
curl \
|
msg_ok "Updated Container OS"
|
||||||
sudo &>/dev/null
|
|
||||||
echo -e "${CM}${CL} \r"
|
msg_info "Installing Dependencies"
|
||||||
|
apt-get install -y curl &>/dev/null
|
||||||
|
apt-get install -y sudo &>/dev/null
|
||||||
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
echo -en "${GN} Installing Motion... "
|
echo -en "${GN} Installing Motion... "
|
||||||
apt-get install motion -y &>/dev/null
|
apt-get install motion -y &>/dev/null
|
||||||
|
@ -62,36 +56,36 @@ echo -en "${GN} Installing Motion... "
|
||||||
systemctl disable motion &>/dev/null
|
systemctl disable motion &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
echo -e "${CM}${CL} \r"
|
||||||
|
|
||||||
echo -en "${GN} Installing FFmpeg... "
|
msg_info "Installing FFmpeg"
|
||||||
apt-get install ffmpeg v4l-utils -y &>/dev/null
|
apt-get install ffmpeg v4l-utils -y &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed FFmpeg"
|
||||||
|
|
||||||
echo -en "${GN} Installing Python... "
|
msg_info "Installing Python"
|
||||||
apt-get update &>/dev/null
|
apt-get update &>/dev/null
|
||||||
apt-get install python2 -y &>/dev/null
|
apt-get install python2 -y &>/dev/null
|
||||||
curl https://bootstrap.pypa.io/pip/2.7/get-pip.py --output get-pip.py &>/dev/null
|
curl https://bootstrap.pypa.io/pip/2.7/get-pip.py --output get-pip.py &>/dev/null
|
||||||
python2 get-pip.py &>/dev/null
|
python2 get-pip.py &>/dev/null
|
||||||
apt-get install libffi-dev libzbar-dev libzbar0 -y &>/dev/null
|
apt-get install libffi-dev libzbar-dev libzbar0 -y &>/dev/null
|
||||||
apt-get install python2-dev libssl-dev libcurl4-openssl-dev libjpeg-dev -y &>/dev/null
|
apt-get install python2-dev libssl-dev libcurl4-openssl-dev libjpeg-dev -y &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Python"
|
||||||
|
|
||||||
echo -en "${GN} Installing MotionEye... "
|
msg_info "Installing MotionEye"
|
||||||
apt-get update &>/dev/null
|
apt-get update &>/dev/null
|
||||||
sudo pip install motioneye &>/dev/null
|
sudo pip install motioneye &>/dev/null
|
||||||
mkdir -p /etc/motioneye
|
mkdir -p /etc/motioneye
|
||||||
cp /usr/local/share/motioneye/extra/motioneye.conf.sample /etc/motioneye/motioneye.conf
|
cp /usr/local/share/motioneye/extra/motioneye.conf.sample /etc/motioneye/motioneye.conf
|
||||||
mkdir -p /var/lib/motioneye
|
mkdir -p /var/lib/motioneye
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed MotionEye"
|
||||||
|
|
||||||
echo -en "${GN} Creating Service file motioneye.service... "
|
msg_info "Creating Service"
|
||||||
cp /usr/local/share/motioneye/extra/motioneye.systemd-unit-local /etc/systemd/system/motioneye.service &>/dev/null
|
cp /usr/local/share/motioneye/extra/motioneye.systemd-unit-local /etc/systemd/system/motioneye.service &>/dev/null
|
||||||
systemctl enable motioneye &>/dev/null
|
systemctl enable motioneye &>/dev/null
|
||||||
systemctl start motioneye
|
systemctl start motioneye
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Created Service"
|
||||||
|
|
||||||
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
||||||
if [[ $PASS != $ ]]; then
|
if [[ $PASS != $ ]]; then
|
||||||
echo -en "${GN} Customizing Container... "
|
msg_info "Customizing Container"
|
||||||
rm /etc/motd
|
rm /etc/motd
|
||||||
rm /etc/update-motd.d/10-uname
|
rm /etc/update-motd.d/10-uname
|
||||||
touch ~/.hushlogin
|
touch ~/.hushlogin
|
||||||
|
@ -104,11 +98,11 @@ ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,3840
|
||||||
EOF
|
EOF
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Customized Container"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -en "${GN} Cleanup... "
|
msg_info "Cleaning up"
|
||||||
apt-get autoremove >/dev/null
|
apt-get autoremove >/dev/null
|
||||||
apt-get autoclean >/dev/null
|
apt-get autoclean >/dev/null
|
||||||
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
||||||
echo -e "${CM}${CL} \n"
|
msg_ok "Cleaned"
|
||||||
|
|
|
@ -1,38 +1,30 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
set -o errexit
|
shopt -s inherit_errexit nullglob
|
||||||
set -o errtrace
|
YW=`echo "\033[33m"`
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
shopt -s expand_aliases
|
|
||||||
alias die='EXIT=$? LINE=$LINENO error_exit'
|
|
||||||
trap die ERR
|
|
||||||
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"
|
|
||||||
}
|
|
||||||
|
|
||||||
RD=`echo "\033[01;31m"`
|
RD=`echo "\033[01;31m"`
|
||||||
BL=`echo "\033[36m"`
|
BL=`echo "\033[36m"`
|
||||||
GN=`echo "\033[1;92m"`
|
GN=`echo "\033[1;92m"`
|
||||||
CL=`echo "\033[m"`
|
CL=`echo "\033[m"`
|
||||||
CM="${GN}✓${CL}"
|
|
||||||
CROSS="${RD}✗${CL}"
|
|
||||||
RETRY_NUM=10
|
RETRY_NUM=10
|
||||||
RETRY_EVERY=3
|
RETRY_EVERY=3
|
||||||
NUM=$RETRY_NUM
|
NUM=$RETRY_NUM
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
CROSS="${RD}✗${CL}"
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Container OS... "
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_info "Setting up Container OS "
|
||||||
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
||||||
locale-gen >/dev/null
|
locale-gen >/dev/null
|
||||||
while [ "$(hostname -I)" = "" ]; do
|
while [ "$(hostname -I)" = "" ]; do
|
||||||
|
@ -45,16 +37,15 @@ while [ "$(hostname -I)" = "" ]; do
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Container OS"
|
||||||
echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} "
|
msg_ok "Network Connected: ${BL}$(hostname -I)"
|
||||||
echo -e "${CM}${CL} \r"
|
|
||||||
|
|
||||||
echo -en "${GN} Updating Container OS... "
|
msg_info "Updating Container OS"
|
||||||
apt update &>/dev/null
|
apt update &>/dev/null
|
||||||
apt-get -qqy upgrade &>/dev/null
|
apt-get -qqy upgrade &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Updated Container OS"
|
||||||
|
|
||||||
echo -en "${GN} Installing Dependencies... "
|
msg_info "Installing Dependencies"
|
||||||
apt-get update &>/dev/null
|
apt-get update &>/dev/null
|
||||||
apt-get -qqy install \
|
apt-get -qqy install \
|
||||||
sudo \
|
sudo \
|
||||||
|
@ -69,9 +60,9 @@ apt-get -qqy install \
|
||||||
python3-dev \
|
python3-dev \
|
||||||
git \
|
git \
|
||||||
lsb-release &>/dev/null
|
lsb-release &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
echo -en "${GN} Installing Python... "
|
msg_info "Installing Dependencies"
|
||||||
apt-get install -y -q --no-install-recommends python3 python3-pip python3-venv &>/dev/null
|
apt-get install -y -q --no-install-recommends python3 python3-pip python3-venv &>/dev/null
|
||||||
pip3 install --upgrade setuptools &>/dev/null
|
pip3 install --upgrade setuptools &>/dev/null
|
||||||
pip3 install --upgrade pip &>/dev/null
|
pip3 install --upgrade pip &>/dev/null
|
||||||
|
@ -80,38 +71,38 @@ echo -e "${CM}${CL} \r"
|
||||||
python3 -m pip install --no-cache-dir -U cryptography==3.3.2 &>/dev/null
|
python3 -m pip install --no-cache-dir -U cryptography==3.3.2 &>/dev/null
|
||||||
fi
|
fi
|
||||||
python3 -m pip install --no-cache-dir cffi certbot &>/dev/null
|
python3 -m pip install --no-cache-dir cffi certbot &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
echo -en "${GN} Installing Openresty... "
|
msg_info "Installing Openresty"
|
||||||
wget -q -O - https://openresty.org/package/pubkey.gpg | apt-key add - &>/dev/null
|
wget -q -O - https://openresty.org/package/pubkey.gpg | apt-key add - &>/dev/null
|
||||||
codename=`grep -Po 'VERSION="[0-9]+ \(\K[^)]+' /etc/os-release` &>/dev/null
|
codename=`grep -Po 'VERSION="[0-9]+ \(\K[^)]+' /etc/os-release` &>/dev/null
|
||||||
echo "deb http://openresty.org/package/debian $codename openresty" | tee /etc/apt/sources.list.d/openresty.list &>/dev/null
|
echo "deb http://openresty.org/package/debian $codename openresty" | tee /etc/apt/sources.list.d/openresty.list &>/dev/null
|
||||||
apt-get -y update &>/dev/null
|
apt-get -y update &>/dev/null
|
||||||
apt-get -y install --no-install-recommends openresty &>/dev/null
|
apt-get -y install --no-install-recommends openresty &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Openresty"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Node.js Repository... "
|
msg_info "Setting up Node.js Repository"
|
||||||
sudo curl -sL https://deb.nodesource.com/setup_16.x | sudo -E bash - &>/dev/null
|
sudo curl -sL https://deb.nodesource.com/setup_16.x | sudo -E bash - &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Node.js Repository"
|
||||||
|
|
||||||
echo -en "${GN} Installing Node.js... "
|
msg_info "Installing Node.js"
|
||||||
sudo apt-get install -y nodejs git make g++ gcc &>/dev/null
|
sudo apt-get install -y nodejs git make g++ gcc &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Node.js"
|
||||||
|
|
||||||
echo -en "${GN} Installing Yarn... "
|
msg_info "Installing Yarn"
|
||||||
npm install --global yarn &>/dev/null
|
npm install --global yarn &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Yarn"
|
||||||
|
|
||||||
RELEASE=$(curl -s https://api.github.com/repos/NginxProxyManager/nginx-proxy-manager/releases/latest \
|
RELEASE=$(curl -s https://api.github.com/repos/NginxProxyManager/nginx-proxy-manager/releases/latest \
|
||||||
| grep "tag_name" \
|
| grep "tag_name" \
|
||||||
| awk '{print substr($2, 3, length($2)-4) }') \
|
| awk '{print substr($2, 3, length($2)-4) }') \
|
||||||
|
|
||||||
echo -en "${GN} Downloading NPM v${RELEASE}... "
|
msg_info "Downloading Nginx Proxy Manager v${RELEASE}"
|
||||||
wget -q https://codeload.github.com/NginxProxyManager/nginx-proxy-manager/tar.gz/v${RELEASE} -O - | tar -xz &>/dev/null
|
wget -q https://codeload.github.com/NginxProxyManager/nginx-proxy-manager/tar.gz/v${RELEASE} -O - | tar -xz &>/dev/null
|
||||||
cd ./nginx-proxy-manager-${RELEASE}
|
cd ./nginx-proxy-manager-${RELEASE}
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Downloaded Nginx Proxy Manager v${RELEASE}"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Enviroment... "
|
msg_info "Setting up Enviroment"
|
||||||
ln -sf /usr/bin/python3 /usr/bin/python
|
ln -sf /usr/bin/python3 /usr/bin/python
|
||||||
ln -sf /usr/bin/certbot /opt/certbot/bin/certbot
|
ln -sf /usr/bin/certbot /opt/certbot/bin/certbot
|
||||||
ln -sf /usr/local/openresty/nginx/sbin/nginx /usr/sbin/nginx
|
ln -sf /usr/local/openresty/nginx/sbin/nginx /usr/sbin/nginx
|
||||||
|
@ -155,7 +146,7 @@ chmod -R 777 /var/cache/nginx
|
||||||
chown root /tmp/nginx
|
chown root /tmp/nginx
|
||||||
|
|
||||||
echo resolver "$(awk 'BEGIN{ORS=" "} $1=="nameserver" {print ($2 ~ ":")? "["$2"]": $2}' /etc/resolv.conf);" > /etc/nginx/conf.d/include/resolvers.conf
|
echo resolver "$(awk 'BEGIN{ORS=" "} $1=="nameserver" {print ($2 ~ ":")? "["$2"]": $2}' /etc/resolv.conf);" > /etc/nginx/conf.d/include/resolvers.conf
|
||||||
echo -e "${CM}${CL} \r"
|
|
||||||
if [ ! -f /data/nginx/dummycert.pem ] || [ ! -f /data/nginx/dummykey.pem ]; then
|
if [ ! -f /data/nginx/dummycert.pem ] || [ ! -f /data/nginx/dummykey.pem ]; then
|
||||||
echo -en "${GN} Generating dummy SSL Certificate... "
|
echo -en "${GN} Generating dummy SSL Certificate... "
|
||||||
openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -subj "/O=Nginx Proxy Manager/OU=Dummy Certificate/CN=localhost" -keyout /data/nginx/dummykey.pem -out /data/nginx/dummycert.pem &>/dev/null
|
openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -subj "/O=Nginx Proxy Manager/OU=Dummy Certificate/CN=localhost" -keyout /data/nginx/dummykey.pem -out /data/nginx/dummycert.pem &>/dev/null
|
||||||
|
@ -164,18 +155,18 @@ fi
|
||||||
mkdir -p /app/global /app/frontend/images
|
mkdir -p /app/global /app/frontend/images
|
||||||
cp -r backend/* /app
|
cp -r backend/* /app
|
||||||
cp -r global/* /app/global
|
cp -r global/* /app/global
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Enviroment"
|
||||||
|
|
||||||
echo -en "${GN} Building Frontend... "
|
msg_info "Building Frontend"
|
||||||
cd ./frontend
|
cd ./frontend
|
||||||
export NODE_ENV=development
|
export NODE_ENV=development
|
||||||
yarn install --network-timeout=30000 &>/dev/null
|
yarn install --network-timeout=30000 &>/dev/null
|
||||||
yarn build &>/dev/null
|
yarn build &>/dev/null
|
||||||
cp -r dist/* /app/frontend
|
cp -r dist/* /app/frontend
|
||||||
cp -r app-images/* /app/frontend/images
|
cp -r app-images/* /app/frontend/images
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Built Frontend"
|
||||||
|
|
||||||
echo -en "${GN} Initializing Backend... "
|
msg_info "Initializing Backend"
|
||||||
rm -rf /app/config/default.json &>/dev/null
|
rm -rf /app/config/default.json &>/dev/null
|
||||||
if [ ! -f /app/config/production.json ]; then
|
if [ ! -f /app/config/production.json ]; then
|
||||||
cat << 'EOF' > /app/config/production.json
|
cat << 'EOF' > /app/config/production.json
|
||||||
|
@ -195,9 +186,9 @@ fi
|
||||||
cd /app
|
cd /app
|
||||||
export NODE_ENV=development
|
export NODE_ENV=development
|
||||||
yarn install --network-timeout=30000 &>/dev/null
|
yarn install --network-timeout=30000 &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Initialized Backend"
|
||||||
|
|
||||||
echo -en "${GN} Creating NPM Service... "
|
msg_info "Creating Service"
|
||||||
cat << 'EOF' > /lib/systemd/system/npm.service
|
cat << 'EOF' > /lib/systemd/system/npm.service
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Nginx Proxy Manager
|
Description=Nginx Proxy Manager
|
||||||
|
@ -215,11 +206,11 @@ Restart=on-failure
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Created Service"
|
||||||
|
|
||||||
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
||||||
if [[ $PASS != $ ]]; then
|
if [[ $PASS != $ ]]; then
|
||||||
echo -en "${GN} Customizing Container... "
|
msg_info "Customizing Container"
|
||||||
rm /etc/motd
|
rm /etc/motd
|
||||||
rm /etc/update-motd.d/10-uname
|
rm /etc/update-motd.d/10-uname
|
||||||
touch ~/.hushlogin
|
touch ~/.hushlogin
|
||||||
|
@ -232,17 +223,17 @@ ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,3840
|
||||||
EOF
|
EOF
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Customized Container"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -en "${GN} Starting Services... "
|
msg_info "Starting Services"
|
||||||
systemctl enable npm &>/dev/null
|
systemctl enable npm &>/dev/null
|
||||||
systemctl start openresty
|
systemctl start openresty
|
||||||
systemctl start npm
|
systemctl start npm
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Started Services"
|
||||||
|
|
||||||
echo -en "${GN} Cleanup... "
|
msg_info "Cleaning up"
|
||||||
apt-get autoremove >/dev/null
|
apt-get autoremove >/dev/null
|
||||||
apt-get autoclean >/dev/null
|
apt-get autoclean >/dev/null
|
||||||
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
||||||
echo -e "${CM}${CL} \n"
|
msg_ok "Cleaned"
|
||||||
|
|
|
@ -1,38 +1,30 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash -ex
|
||||||
|
set -euo pipefail
|
||||||
set -o errexit
|
shopt -s inherit_errexit nullglob
|
||||||
set -o errtrace
|
YW=`echo "\033[33m"`
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
shopt -s expand_aliases
|
|
||||||
alias die='EXIT=$? LINE=$LINENO error_exit'
|
|
||||||
trap die ERR
|
|
||||||
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"
|
|
||||||
}
|
|
||||||
|
|
||||||
RD=`echo "\033[01;31m"`
|
RD=`echo "\033[01;31m"`
|
||||||
BL=`echo "\033[36m"`
|
BL=`echo "\033[36m"`
|
||||||
GN=`echo "\033[1;92m"`
|
GN=`echo "\033[1;92m"`
|
||||||
CL=`echo "\033[m"`
|
CL=`echo "\033[m"`
|
||||||
CM="${GN}✓${CL}"
|
|
||||||
CROSS="${RD}✗${CL}"
|
|
||||||
RETRY_NUM=10
|
RETRY_NUM=10
|
||||||
RETRY_EVERY=3
|
RETRY_EVERY=3
|
||||||
NUM=$RETRY_NUM
|
NUM=$RETRY_NUM
|
||||||
|
CM="${GN}✓${CL}"
|
||||||
|
CROSS="${RD}✗${CL}"
|
||||||
|
BFR="\\r\\033[K"
|
||||||
|
HOLD="-"
|
||||||
|
|
||||||
echo -en "${GN} Setting up Container OS... "
|
function msg_info() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -ne " ${HOLD} ${YW}${msg}..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_ok() {
|
||||||
|
local msg="$1"
|
||||||
|
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_info "Setting up Container OS "
|
||||||
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
||||||
locale-gen >/dev/null
|
locale-gen >/dev/null
|
||||||
while [ "$(hostname -I)" = "" ]; do
|
while [ "$(hostname -I)" = "" ]; do
|
||||||
|
@ -45,16 +37,15 @@ while [ "$(hostname -I)" = "" ]; do
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Set up Container OS"
|
||||||
echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} "
|
msg_ok "Network Connected: ${BL}$(hostname -I)"
|
||||||
echo -e "${CM}${CL} \r"
|
|
||||||
|
|
||||||
echo -en "${GN} Updating Container OS... "
|
msg_info "Updating Container OS"
|
||||||
apt-get update &>/dev/null
|
apt update &>/dev/null
|
||||||
apt-get -qqy upgrade &>/dev/null
|
apt-get -qqy upgrade &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Updated Container OS"
|
||||||
|
|
||||||
echo -en "${GN} Installing Dependencies... "
|
msg_info "Installing Dependencies"
|
||||||
apt-get update &>/dev/null
|
apt-get update &>/dev/null
|
||||||
apt-get -qqy install \
|
apt-get -qqy install \
|
||||||
git \
|
git \
|
||||||
|
@ -67,36 +58,36 @@ apt-get -qqy install \
|
||||||
libssl-dev \
|
libssl-dev \
|
||||||
curl \
|
curl \
|
||||||
sudo &>/dev/null
|
sudo &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
echo -en "${GN} Installing Build Essentials... "
|
msg_info "Installing Build Essentials"
|
||||||
apt-get install -y build-essential &>/dev/null
|
apt-get install -y build-essential &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Build Essentials"
|
||||||
|
|
||||||
echo -en "${GN} Installing Rust... "
|
msg_info "Installing Rust"
|
||||||
curl https://sh.rustup.rs -sSf | sh -s -- -y &>/dev/null
|
curl https://sh.rustup.rs -sSf | sh -s -- -y &>/dev/null
|
||||||
echo 'export PATH=~/.cargo/bin:$PATH' >> ~/.bashrc &>/dev/null
|
echo 'export PATH=~/.cargo/bin:$PATH' >> ~/.bashrc &>/dev/null
|
||||||
export PATH=~/.cargo/bin:$PATH &>/dev/null
|
export PATH=~/.cargo/bin:$PATH &>/dev/null
|
||||||
which rustc &>/dev/null
|
which rustc &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Rust"
|
||||||
|
|
||||||
echo -en "${GN} Installing Node.js... "
|
msg_info "Installing Node.js"
|
||||||
curl -fsSL https://deb.nodesource.com/setup_16.x | bash - &>/dev/null
|
curl -fsSL https://deb.nodesource.com/setup_16.x | bash - &>/dev/null
|
||||||
apt-get install -y nodejs &>/dev/null
|
apt-get install -y nodejs &>/dev/null
|
||||||
npm -g install npm@7 &>/dev/null
|
npm -g install npm@7 &>/dev/null
|
||||||
which npm &>/dev/null
|
which npm &>/dev/null
|
||||||
npm i npm@latest -g &>/dev/null
|
npm i npm@latest -g &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Installed Node.js"
|
||||||
|
|
||||||
echo -en "${GN} Building Vaultwarden (Patience)... "
|
msg_info "Building Vaultwarden (Patience)"
|
||||||
git clone https://github.com/dani-garcia/vaultwarden &>/dev/null
|
git clone https://github.com/dani-garcia/vaultwarden &>/dev/null
|
||||||
pushd vaultwarden &>/dev/null
|
pushd vaultwarden &>/dev/null
|
||||||
cargo clean &>/dev/null
|
cargo clean &>/dev/null
|
||||||
cargo build --features sqlite --release &>/dev/null
|
cargo build --features sqlite --release &>/dev/null
|
||||||
file target/release/vaultwarden &>/dev/null
|
file target/release/vaultwarden &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Built Vaultwarden"
|
||||||
|
|
||||||
echo -en "${GN} Building Web-Vault... "
|
msg_info "Building Web-Vault"
|
||||||
pushd target/release/ &>/dev/null
|
pushd target/release/ &>/dev/null
|
||||||
git clone --recurse-submodules https://github.com/bitwarden/web.git web-vault.git &>/dev/null
|
git clone --recurse-submodules https://github.com/bitwarden/web.git web-vault.git &>/dev/null
|
||||||
cd web-vault.git &>/dev/null
|
cd web-vault.git &>/dev/null
|
||||||
|
@ -110,9 +101,9 @@ npm run --silent dist:oss:selfhost &>/dev/null
|
||||||
cp -a build ../web-vault &>/dev/null
|
cp -a build ../web-vault &>/dev/null
|
||||||
cd ..
|
cd ..
|
||||||
mkdir data
|
mkdir data
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Built Web-Vault"
|
||||||
|
|
||||||
echo -en "${GN} Create Systemd Service... "
|
msg_info "Creating Service"
|
||||||
cp ../../.env.template /etc/vaultwarden.env &>/dev/null
|
cp ../../.env.template /etc/vaultwarden.env &>/dev/null
|
||||||
cp vaultwarden /usr/bin/vaultwarden &>/dev/null
|
cp vaultwarden /usr/bin/vaultwarden &>/dev/null
|
||||||
chmod +x /usr/bin/vaultwarden &>/dev/null
|
chmod +x /usr/bin/vaultwarden &>/dev/null
|
||||||
|
@ -145,11 +136,11 @@ WantedBy=multi-user.target" > $service_path
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl enable vaultwarden.service &>/dev/null
|
systemctl enable vaultwarden.service &>/dev/null
|
||||||
systemctl start vaultwarden.service &>/dev/null
|
systemctl start vaultwarden.service &>/dev/null
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Created Service"
|
||||||
|
|
||||||
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
PASS=$(grep -w "root" /etc/shadow | cut -b6);
|
||||||
if [[ $PASS != $ ]]; then
|
if [[ $PASS != $ ]]; then
|
||||||
echo -en "${GN} Customizing Container... "
|
msg_info "Customizing Container"
|
||||||
rm /etc/motd
|
rm /etc/motd
|
||||||
rm /etc/update-motd.d/10-uname
|
rm /etc/update-motd.d/10-uname
|
||||||
touch ~/.hushlogin
|
touch ~/.hushlogin
|
||||||
|
@ -162,11 +153,11 @@ ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,3840
|
||||||
EOF
|
EOF
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
||||||
echo -e "${CM}${CL} \r"
|
msg_ok "Customized Container"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -en "${GN} Cleanup... "
|
msg_info "Cleaning up"
|
||||||
apt-get autoremove >/dev/null
|
apt-get autoremove >/dev/null
|
||||||
apt-get autoclean >/dev/null
|
apt-get autoclean >/dev/null
|
||||||
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
|
||||||
echo -e "${CM}${CL} \n"
|
msg_ok "Cleaned"
|
||||||
|
|
Loading…
Reference in New Issue