diff --git a/CHANGELOG.md b/CHANGELOG.md index 0f956a7d..9e6952e6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,13 @@ - All LXC instances created using this repository come pre-installed with Midnight Commander, which is a command-line tool (`mc`) that offers a user-friendly file and directory management interface for the terminal environment. - 🚨 **The scripts in the repository will no longer provide support for Proxmox VE 7 starting from July 2024 (scripts will not execute on PVE7). Subsequent Proxmox VE - Support Lifecycle** +## 2024-02-23 + +### Changed + +- **Tandoor Recipes LXC** + - NEW Script (Thanks @MickLesk) + ## 2024-02-21 ### Changed diff --git a/ct/tandoor.sh b/ct/tandoor.sh index 9cefeeea..3dba8b02 100644 --- a/ct/tandoor.sh +++ b/ct/tandoor.sh @@ -1,27 +1,28 @@ #!/usr/bin/env bash source <(curl -s https://raw.githubusercontent.com/tteck/Proxmox/main/misc/build.func) # Copyright (c) 2021-2024 tteck -# Author: MickLesk (Canbiz) +# Author: tteck +# Co-Author: MickLesk (Canbiz) # License: MIT # https://github.com/tteck/Proxmox/raw/main/LICENSE function header_info { clear cat <<"EOF" - ______ __ - /_ __/___ _____ ____/ /___ ____ _____ - / / / __ `/ __ \/ __ / __ \/ __ \/ ___/ - / / / /_/ / / / / /_/ / /_/ / /_/ / / -/_/ \__,_/_/ /_/\__,_/\____/\____/_/ - + ______ __ ____ _ + /_ __/___ _____ ____/ /___ ____ _____ / __ \___ _____(_)___ ___ _____ + / / / __ `/ __ \/ __ / __ \/ __ \/ ___/ / /_/ / _ \/ ___/ / __ \/ _ \/ ___/ + / / / /_/ / / / / /_/ / /_/ / /_/ / / / _, _/ __/ /__/ / /_/ / __(__ ) +/_/ \__,_/_/ /_/\__,_/\____/\____/_/ /_/ |_|\___/\___/_/ .___/\___/____/ + /_/ EOF } header_info echo -e "Loading..." APP="Tandoor" var_disk="10" -var_cpu="2" -var_ram="1024" +var_cpu="4" +var_ram="4096" var_os="debian" var_version="12" variables @@ -79,6 +80,11 @@ start build_container description +msg_info "Setting Container to Normal Resources" +pct set $CTID -memory 2048 +pct set $CTID -cores 2 +msg_ok "Set Container to Normal Resources" + msg_ok "Completed Successfully!\n" echo -e "${APP} Setup should be reachable by going to the following URL. - ${BL}http://${IP}:8002${CL} \n" \ No newline at end of file + ${BL}http://${IP}:8002${CL} \n" diff --git a/install/tandoor-install.sh b/install/tandoor-install.sh index 37845700..509121e4 100644 --- a/install/tandoor-install.sh +++ b/install/tandoor-install.sh @@ -1,7 +1,8 @@ #!/usr/bin/env bash # Copyright (c) 2021-2024 tteck -# Author: MickLesk (Canbiz) +# Author: tteck +# Co-Author: MickLesk (Canbiz) # License: MIT # https://github.com/tteck/Proxmox/raw/main/LICENSE @@ -15,11 +16,6 @@ update_os msg_info "Installing Dependencies (Patience)" $STD apt-get install -y --no-install-recommends \ - postgresql \ - python3 \ - python3-dev \ - python3-setuptools \ - python3-venv \ build-essential \ libpq-dev \ libmagic-dev \ @@ -28,6 +24,7 @@ $STD apt-get install -y --no-install-recommends \ libsasl2-dev \ libldap2-dev \ libssl-dev \ + gpg \ curl \ sudo \ git \ @@ -35,64 +32,66 @@ $STD apt-get install -y --no-install-recommends \ mc msg_ok "Installed Dependencies" -msg_info "Setup Tandoor (Patience)" -sudo useradd tandoor -cd /opt -git clone https://github.com/vabene1111/recipes.git -b master >/dev/null 2>&1 -mv recipes tandoor >/dev/null 2>&1 -chown -R tandoor:www-data /opt/tandoor >/dev/null 2>&1 -python3 -m venv /opt/tandoor >/dev/null 2>&1 -source /opt/tandoor/bin/activate >/dev/null 2>&1 -curl -fsSL https://deb.nodesource.com/setup_lts.x | bash - >/dev/null 2>&1 -apt install -y nodejs >/dev/null 2>&1 -sudo npm install --global yarn >/dev/null 2>&1 -/opt/tandoor/bin/pip3 install -r /opt/tandoor/requirements.txt >/dev/null 2>&1 +msg_info "Updating Python3" +$STD apt-get install -y \ + python3 \ + python3-dev \ + python3-setuptools \ + python3-pip +msg_ok "Updated Python3" + +msg_info "Setting up Node.js Repository" +mkdir -p /etc/apt/keyrings +curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg +echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_20.x nodistro main" >/etc/apt/sources.list.d/nodesource.list +msg_ok "Set up Node.js Repository" + +msg_info "Installing Node.js" +$STD apt-get update +$STD apt-get install -y nodejs +$STD npm install -g yarn +msg_ok "Installed Node.js" + +msg_info "Installing Tandoor (Patience)" +$STD git clone https://github.com/vabene1111/recipes.git -b master /opt/tandoor +mkdir -p /opt/tandoor/{config,api,mediafiles,staticfiles} +$STD pip3 install -r /opt/tandoor/requirements.txt cd /opt/tandoor/vue -yarn install --silent >/dev/null 2>&1 -yarn build --silent >/dev/null 2>&1 -cd /opt/tandoor -sudo mkdir -p config api mediafiles staticfiles >/dev/null 2>&1 -msg_ok "Initial Setup complete" - -msg_info "Setting up Database" -DB_NAME=djangodb -DB_USER=djangouser +$STD yarn install +$STD yarn build +wget -q https://raw.githubusercontent.com/vabene1111/recipes/develop/.env.template -O /opt/tandoor/.env +DB_NAME=db_recipes +DB_USER=tandoor DB_ENCODING=utf8 DB_TIMEZONE=UTC +secret_key=$(openssl rand -base64 45 | sed 's/\//\\\//g') DB_PASS="$(openssl rand -base64 18 | cut -c1-13)" -$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME;" -$STD sudo -u postgres psql -c "CREATE USER $DB_USER WITH PASSWORD '$DB_PASS';" -$STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" -$STD sudo -u postgres psql -c "ALTER DATABASE $DB_NAME OWNER TO $DB_USER;" -$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO $DB_ENCODING;" -$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET default_transaction_isolation TO 'read committed';" -$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO $DB_TIMEZONE;" -$STD sudo -u postgres psql -c "ALTER USER $DB_USER WITH SUPERUSER;" +sed -i -e "s|SECRET_KEY=.*|SECRET_KEY=$secret_key|g" \ + -e "s|POSTGRES_HOST=.*|POSTGRES_HOST=localhost|g" \ + -e "s|POSTGRES_PASSWORD=.*|POSTGRES_PASSWORD=$DB_PASS|g" \ + -e "s|POSTGRES_DB=.*|POSTGRES_DB=$DB_NAME|g" \ + -e "s|POSTGRES_USER=.*|POSTGRES_USER=$DB_USER|g" \ + -e "\$a\STATIC_URL=/staticfiles/" /opt/tandoor/.env +msg_ok "Installed Tandoor" + +msg_info "Install/Set up PostgreSQL Database" +curl -fsSL https://www.postgresql.org/media/keys/ACCC4CF8.asc|gpg --dearmor -o /etc/apt/trusted.gpg.d/postgresql.gpg +echo "deb https://apt.postgresql.org/pub/repos/apt bookworm-pgdg main" >/etc/apt/sources.list.d/pgdg.list +$STD apt-get update +$STD apt-get install -y postgresql-16 +$STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';" +$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER TEMPLATE template0;" echo "" >>~/tandoor.creds +echo -e "Tandoor Database Name: \e[32m$DB_NAME\e[0m" >>~/tandoor.creds echo -e "Tandoor Database User: \e[32m$DB_USER\e[0m" >>~/tandoor.creds echo -e "Tandoor Database Password: \e[32m$DB_PASS\e[0m" >>~/tandoor.creds -echo -e "Tandoor Database Name: \e[32m$DB_NAME\e[0m" >>~/tandoor.creds -msg_ok "Set up PostgreSQL database" - -msg_info "Setting up Tandoor Env" -wget https://raw.githubusercontent.com/vabene1111/recipes/develop/.env.template -O /opt/tandoor/.env >/dev/null 2>&1 -secret_key=$(openssl rand -base64 45 | sed 's/\//\\\//g') >/dev/null 2>&1 -sudo sed -i "s/SECRET_KEY=.*/SECRET_KEY=$secret_key/" /opt/tandoor/.env -sudo sed -i 's/POSTGRES_HOST=.*/POSTGRES_HOST=127.0.0.1/' /opt/tandoor/.env -sudo sed -i "s/POSTGRES_PASSWORD=.*/POSTGRES_PASSWORD=$DB_PASS/" /opt/tandoor/.env -sudo sed -i 's/STATIC_URL=.*/STATIC_URL=\/staticfiles\//' /opt/tandoor/.env -sudo sed -i 's/MEDIA_URL=.*/MEDIA_URL=\/mediafiles\//' /opt/tandoor/.env -msg_ok "Tandoor successfully set up" - -msg_info "Initialize Application" -export $(cat /opt/tandoor/.env |grep "^[^#]" | xargs) >/dev/null 2>&1 -/opt/tandoor/bin/python3 /opt/tandoor/manage.py migrate >/dev/null 2>&1 -$STD sudo -u postgres psql -c "ALTER USER $DB_USER WITH NOSUPERUSER;" -/opt/tandoor/bin/python3 /opt/tandoor/manage.py collectstatic --no-input >/dev/null 2>&1 -/opt/tandoor/bin/python3 /opt/tandoor/manage.py collectstatic_js_reverse >/dev/null 2>&1 -msg_ok "Application Initialized" - -msg_info "Set up web services" +export $(cat /opt/tandoor/.env |grep "^[^#]" | xargs) +/usr/bin/python3 /opt/tandoor/manage.py migrate >/dev/null 2>&1 +/usr/bin/python3 /opt/tandoor/manage.py collectstatic --no-input >/dev/null 2>&1 +/usr/bin/python3 /opt/tandoor/manage.py collectstatic_js_reverse >/dev/null 2>&1 +msg_ok "Set up PostgreSQL Database" + +msg_info "Creating Services" cat </etc/systemd/system/gunicorn_tandoor.service [Unit] Description=gunicorn daemon for tandoor @@ -102,18 +101,14 @@ After=network.target Type=simple Restart=always RestartSec=3 -User=tandoor -Group=www-data WorkingDirectory=/opt/tandoor EnvironmentFile=/opt/tandoor/.env -ExecStart=/opt/tandoor/bin/gunicorn --error-logfile /tmp/gunicorn_err.log --log-level debug --capture-output --bind unix:/opt/tandoor/tandoor.sock recipes.wsgi:application +ExecStart=/usr/local/bin/gunicorn --error-logfile /tmp/gunicorn_err.log --log-level debug --capture-output --bind unix:/opt/tandoor/tandoor.sock recipes.wsgi:application [Install] WantedBy=multi-user.target EOF -$STD sudo systemctl enable --now gunicorn_tandoor - cat << 'EOF' >/etc/nginx/conf.d/tandoor.conf server { listen 8002; @@ -136,8 +131,8 @@ server { } } EOF - -$STD sudo systemctl reload nginx +systemctl reload nginx +systemctl enable -q --now gunicorn_tandoor msg_ok "Created Services" motd_ssh diff --git a/misc/build.func b/misc/build.func index 968cb83e..604b0468 100644 --- a/misc/build.func +++ b/misc/build.func @@ -119,14 +119,13 @@ arch_check() { # This function checks if the script is running through SSH and prompts the user to confirm if they want to proceed or exit. ssh_check() { - if command -v pveversion >/dev/null 2>&1; then - if [ -n "${SSH_CLIENT:+x}" ]; then - if whiptail --backtitle "Proxmox VE Helper Scripts" --defaultno --title "SSH DETECTED" --yesno "It's suggested to use the Proxmox shell instead of SSH, since SSH can create issues while gathering variables. Would you like to proceed with using SSH?" 10 62; then - echo "you've been warned" - else - clear - exit - fi + if command -v pveversion >/dev/null 2>&1 && [ -n "${SSH_CLIENT:+x}" ]; then + if whiptail --backtitle "Proxmox VE Helper Scripts" --defaultno --title "SSH DETECTED" --yesno "It's advisable to utilize the Proxmox shell rather than SSH, as there may be potential complications with variable retrieval. Proceed using SSH?" 10 72; then + whiptail --backtitle "Proxmox VE Helper Scripts" --msgbox --title "Proceed using SSH" "You've chosen to proceed using SSH. If any issues arise, please run the script in the Proxmox shell before creating a repository issue." 10 72 + else + clear + echo "Exiting due to SSH usage. Please consider using the Proxmox shell." + exit fi fi }