mirror of
				https://github.com/community-scripts/ProxmoxVE.git
				synced 2025-11-04 10:22:50 +00:00 
			
		
		
		
	Tandoor v2 (#6635)
This commit is contained in:
		@@ -1,6 +1,6 @@
 | 
				
			|||||||
#!/usr/bin/env bash
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
					source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
				
			||||||
# Copyright (c) 2021-2025 tteck
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
# Author: MickLesk (Canbiz)
 | 
					# Author: MickLesk (Canbiz)
 | 
				
			||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
# Source: https://tandoor.dev/
 | 
					# Source: https://tandoor.dev/
 | 
				
			||||||
@@ -27,27 +27,57 @@ function update_script() {
 | 
				
			|||||||
    msg_error "No ${APP} Installation Found!"
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
    exit
 | 
					    exit
 | 
				
			||||||
  fi
 | 
					  fi
 | 
				
			||||||
  #if ! [[ $(dpkg -s python3-xmlsec 2>/dev/null) ]]; then
 | 
					
 | 
				
			||||||
    #$STD apt-get update
 | 
					  if [[ ! -f ~/.tandoor ]]; then
 | 
				
			||||||
    #$STD apt-get install -y python3-xmlsec
 | 
					    msg_error "v1 Installation found, please export your data and create an new LXC."
 | 
				
			||||||
  #fi
 | 
					    exit
 | 
				
			||||||
  #if cd /opt/tandoor && git pull | grep -q 'Already up to date'; then
 | 
					  fi
 | 
				
			||||||
    msg_ok "There is currently no update available."
 | 
					
 | 
				
			||||||
  #else
 | 
					  RELEASE=$(curl -fsSL https://api.github.com/repos/TandoorRecipes/recipes/releases/latest | jq -r '.tag_name' | sed 's/^v//')
 | 
				
			||||||
    #msg_info "Updating ${APP} (Patience)"
 | 
					  if [[ "${RELEASE}" != "$(cat ~/.tandoor 2>/dev/null)" ]] || [[ ! -f ~/.tandoor ]]; then
 | 
				
			||||||
    #export $(cat /opt/tandoor/.env | grep "^[^#]" | xargs)
 | 
					    msg_info "Stopping $APP"
 | 
				
			||||||
    #cd /opt/tandoor/
 | 
					    systemctl stop tandoor
 | 
				
			||||||
    #$STD pip3 install -r requirements.txt
 | 
					    msg_ok "Stopped $APP"
 | 
				
			||||||
    #$STD /usr/bin/python3 /opt/tandoor/manage.py migrate
 | 
					
 | 
				
			||||||
    #$STD /usr/bin/python3 /opt/tandoor/manage.py collectstatic --no-input
 | 
					    msg_info "Creating Backup"
 | 
				
			||||||
    #$STD /usr/bin/python3 /opt/tandoor/manage.py collectstatic_js_reverse
 | 
					    mv /opt/tandoor /opt/tandoor.bak
 | 
				
			||||||
    #cd /opt/tandoor/vue
 | 
					    msg_ok "Backup Created"
 | 
				
			||||||
    #$STD yarn install
 | 
					
 | 
				
			||||||
    #$STD yarn build
 | 
					    NODE_VERSION="20" NODE_MODULE="yarn" setup_nodejs
 | 
				
			||||||
    #cd /opt/tandoor
 | 
					    PYTHON_VERSION="3.13" setup_uv
 | 
				
			||||||
    #$STD python3 version.py
 | 
					    fetch_and_deploy_gh_release "tandoor" "TandoorRecipes/recipes" "tarball" "latest" "/opt/tandoor"
 | 
				
			||||||
    #systemctl restart gunicorn_tandoor
 | 
					
 | 
				
			||||||
    #msg_ok "Updated ${APP}"
 | 
					    msg_info "Updating $APP to ${RELEASE}"
 | 
				
			||||||
 | 
					    cp -r /opt/tandoor.bak/{config,api,mediafiles,staticfiles} /opt/tandoor/
 | 
				
			||||||
 | 
					    mv /opt/.env /opt/tandoor/.env
 | 
				
			||||||
 | 
					    cd /opt/tandoor
 | 
				
			||||||
 | 
					    $STD uv venv .venv --python=python3
 | 
				
			||||||
 | 
					    $STD uv pip install -r requirements.txt --python .venv/bin/python
 | 
				
			||||||
 | 
					    cd /opt/tandoor/vue3
 | 
				
			||||||
 | 
					    $STD yarn install
 | 
				
			||||||
 | 
					    $STD yarn build
 | 
				
			||||||
 | 
					    TANDOOR_VERSION="$(curl -fsSL https://api.github.com/repos/TandoorRecipes/recipes/releases/latest | jq -r .tag_name)"
 | 
				
			||||||
 | 
					    cat <<EOF >/opt/tandoor/cookbook/version_info.py
 | 
				
			||||||
 | 
					TANDOOR_VERSION = "$TANDOOR_VERSION"
 | 
				
			||||||
 | 
					TANDOOR_REF = "bare-metal"
 | 
				
			||||||
 | 
					VERSION_INFO = []
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					    cd /opt/tandoor
 | 
				
			||||||
 | 
					    $STD /opt/tandoor/.venv/bin/python manage.py migrate
 | 
				
			||||||
 | 
					    $STD /opt/tandoor/.venv/bin/python manage.py collectstatic --no-input
 | 
				
			||||||
 | 
					    msg_ok "Updated $APP to ${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting $APP"
 | 
				
			||||||
 | 
					    systemctl start tandoor
 | 
				
			||||||
 | 
					    systemctl reload nginx
 | 
				
			||||||
 | 
					    msg_ok "Started $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Cleaning Up"
 | 
				
			||||||
 | 
					    rm -rf /opt/tandoor.bak
 | 
				
			||||||
 | 
					    msg_ok "Cleanup Completed"
 | 
				
			||||||
 | 
					    msg_ok "Update Successful"
 | 
				
			||||||
 | 
					  else
 | 
				
			||||||
 | 
					    msg_ok "No update required. ${APP} is already at v${RELEASE}"
 | 
				
			||||||
  fi
 | 
					  fi
 | 
				
			||||||
  exit
 | 
					  exit
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,7 @@
 | 
				
			|||||||
#!/usr/bin/env bash
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Copyright (c) 2021-2025 tteck
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
# Author: tteck
 | 
					# Author: MickLesk (Canbiz)
 | 
				
			||||||
# Co-Author: MickLesk (Canbiz)
 | 
					 | 
				
			||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
# Source: https://tandoor.dev/
 | 
					# Source: https://tandoor.dev/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -17,6 +16,7 @@ update_os
 | 
				
			|||||||
msg_info "Installing Dependencies (Patience)"
 | 
					msg_info "Installing Dependencies (Patience)"
 | 
				
			||||||
$STD apt-get install -y --no-install-recommends \
 | 
					$STD apt-get install -y --no-install-recommends \
 | 
				
			||||||
  build-essential \
 | 
					  build-essential \
 | 
				
			||||||
 | 
					  python3 \
 | 
				
			||||||
  libpq-dev \
 | 
					  libpq-dev \
 | 
				
			||||||
  libmagic-dev \
 | 
					  libmagic-dev \
 | 
				
			||||||
  libzbar0 \
 | 
					  libzbar0 \
 | 
				
			||||||
@@ -24,72 +24,72 @@ $STD apt-get install -y --no-install-recommends \
 | 
				
			|||||||
  libsasl2-dev \
 | 
					  libsasl2-dev \
 | 
				
			||||||
  libldap2-dev \
 | 
					  libldap2-dev \
 | 
				
			||||||
  libssl-dev \
 | 
					  libssl-dev \
 | 
				
			||||||
  git \
 | 
					 | 
				
			||||||
  make \
 | 
					 | 
				
			||||||
  pkg-config \
 | 
					  pkg-config \
 | 
				
			||||||
  libxmlsec1-dev \
 | 
					  libxmlsec1-dev \
 | 
				
			||||||
  libxml2-dev \
 | 
					  libxml2-dev \
 | 
				
			||||||
  libxmlsec1-openssl
 | 
					  libxmlsec1-openssl
 | 
				
			||||||
msg_ok "Installed Dependencies"
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Setup Python3"
 | 
					NODE_VERSION="20" NODE_MODULE="yarn" setup_nodejs
 | 
				
			||||||
$STD apt-get install -y \
 | 
					fetch_and_deploy_gh_release "tandoor" "TandoorRecipes/recipes" "tarball" "latest" "/opt/tandoor"
 | 
				
			||||||
  python3 \
 | 
					PG_VERSION="16" setup_postgresql
 | 
				
			||||||
  python3-dev \
 | 
					PYTHON_VERSION="3.13" setup_uv
 | 
				
			||||||
  python3-setuptools \
 | 
					 | 
				
			||||||
  python3-pip \
 | 
					 | 
				
			||||||
  python3-xmlsec
 | 
					 | 
				
			||||||
rm -rf /usr/lib/python3.*/EXTERNALLY-MANAGED
 | 
					 | 
				
			||||||
msg_ok "Setup Python3"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
NODE_VERSION="20" NODE_MODULE="yarn@latest" setup_nodejs
 | 
					msg_info "Set up PostgreSQL Database"
 | 
				
			||||||
 | 
					 | 
				
			||||||
msg_info "Installing Tandoor (Patience)"
 | 
					 | 
				
			||||||
$STD git clone https://github.com/TandoorRecipes/recipes -b master /opt/tandoor
 | 
					 | 
				
			||||||
mkdir -p /opt/tandoor/{config,api,mediafiles,staticfiles}
 | 
					 | 
				
			||||||
$STD pip3 install -r /opt/tandoor/requirements.txt
 | 
					 | 
				
			||||||
cd /opt/tandoor/vue
 | 
					 | 
				
			||||||
$STD yarn install
 | 
					 | 
				
			||||||
$STD yarn build
 | 
					 | 
				
			||||||
curl -fsSL "https://raw.githubusercontent.com/TandoorRecipes/recipes/develop/.env.template" -o "/opt/tandoor/.env"
 | 
					 | 
				
			||||||
DB_NAME=db_recipes
 | 
					DB_NAME=db_recipes
 | 
				
			||||||
DB_USER=tandoor
 | 
					DB_USER=tandoor
 | 
				
			||||||
DB_ENCODING=utf8
 | 
					SECRET_KEY=$(openssl rand -base64 45 | sed 's/\//\\\//g')
 | 
				
			||||||
DB_TIMEZONE=UTC
 | 
					 | 
				
			||||||
secret_key=$(openssl rand -base64 45 | sed 's/\//\\\//g')
 | 
					 | 
				
			||||||
DB_PASS="$(openssl rand -base64 18 | cut -c1-13)"
 | 
					DB_PASS="$(openssl rand -base64 18 | cut -c1-13)"
 | 
				
			||||||
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
 | 
					 | 
				
			||||||
cd /opt/tandoor
 | 
					 | 
				
			||||||
$STD python3 version.py
 | 
					 | 
				
			||||||
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 ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';"
 | 
				
			||||||
$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER TEMPLATE template0;"
 | 
					$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER TEMPLATE template0;"
 | 
				
			||||||
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO 'utf8';"
 | 
					$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO 'utf8';"
 | 
				
			||||||
$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 default_transaction_isolation TO 'read committed';"
 | 
				
			||||||
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO 'UTC'"
 | 
					$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO 'UTC'"
 | 
				
			||||||
echo "" >>~/tandoor.creds
 | 
					{
 | 
				
			||||||
echo -e "Tandoor Database Name: \e[32m$DB_NAME\e[0m" >>~/tandoor.creds
 | 
					  echo "Tandoor-Credentials"
 | 
				
			||||||
echo -e "Tandoor Database User: \e[32m$DB_USER\e[0m" >>~/tandoor.creds
 | 
					  echo "Tandoor Database Name: $DB_NAME"
 | 
				
			||||||
echo -e "Tandoor Database Password: \e[32m$DB_PASS\e[0m" >>~/tandoor.creds
 | 
					  echo "Tandoor Database User: $DB_USER"
 | 
				
			||||||
export $(cat /opt/tandoor/.env | grep "^[^#]" | xargs)
 | 
					  echo "Tandoor Database Password: $DB_PASS"
 | 
				
			||||||
/usr/bin/python3 /opt/tandoor/manage.py migrate >/dev/null 2>&1
 | 
					} >>~/tandoor.creds
 | 
				
			||||||
/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_ok "Set up PostgreSQL Database"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setup Tandoor"
 | 
				
			||||||
 | 
					mkdir -p /opt/tandoor/{config,api,mediafiles,staticfiles}
 | 
				
			||||||
 | 
					cd /opt/tandoor
 | 
				
			||||||
 | 
					$STD uv venv .venv --python=python3
 | 
				
			||||||
 | 
					$STD uv pip install -r requirements.txt --python .venv/bin/python
 | 
				
			||||||
 | 
					cd /opt/tandoor/vue3
 | 
				
			||||||
 | 
					$STD yarn install
 | 
				
			||||||
 | 
					$STD yarn build
 | 
				
			||||||
 | 
					cat <<EOF >/opt/tandoor/.env
 | 
				
			||||||
 | 
					SECRET_KEY=$SECRET_KEY
 | 
				
			||||||
 | 
					TZ=Europe/Berlin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DB_ENGINE=django.db.backends.postgresql
 | 
				
			||||||
 | 
					POSTGRES_HOST=localhost
 | 
				
			||||||
 | 
					POSTGRES_DB=$DB_NAME
 | 
				
			||||||
 | 
					POSTGRES_PORT=5432
 | 
				
			||||||
 | 
					POSTGRES_USER=$DB_USER
 | 
				
			||||||
 | 
					POSTGRES_PASSWORD=$DB_PASS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					STATIC_URL=/staticfiles/
 | 
				
			||||||
 | 
					MEDIA_URL=/mediafiles/
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					TANDOOR_VERSION="$(curl -s https://api.github.com/repos/TandoorRecipes/recipes/releases/latest | jq -r .tag_name)"
 | 
				
			||||||
 | 
					cat <<EOF >/opt/tandoor/cookbook/version_info.py
 | 
				
			||||||
 | 
					TANDOOR_VERSION = "$TANDOOR_VERSION"
 | 
				
			||||||
 | 
					TANDOOR_REF = "bare-metal"
 | 
				
			||||||
 | 
					VERSION_INFO = []
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					cd /opt/tandoor
 | 
				
			||||||
 | 
					$STD /opt/tandoor/.venv/bin/python manage.py migrate
 | 
				
			||||||
 | 
					$STD /opt/tandoor/.venv/bin/python manage.py collectstatic --no-input
 | 
				
			||||||
 | 
					msg_ok "Installed Tandoor"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Creating Services"
 | 
					msg_info "Creating Services"
 | 
				
			||||||
cat <<EOF >/etc/systemd/system/gunicorn_tandoor.service
 | 
					cat <<EOF >/etc/systemd/system/tandoor.service
 | 
				
			||||||
[Unit]
 | 
					[Unit]
 | 
				
			||||||
Description=gunicorn daemon for tandoor
 | 
					Description=gunicorn daemon for tandoor
 | 
				
			||||||
After=network.target
 | 
					After=network.target
 | 
				
			||||||
@@ -100,7 +100,7 @@ Restart=always
 | 
				
			|||||||
RestartSec=3
 | 
					RestartSec=3
 | 
				
			||||||
WorkingDirectory=/opt/tandoor
 | 
					WorkingDirectory=/opt/tandoor
 | 
				
			||||||
EnvironmentFile=/opt/tandoor/.env
 | 
					EnvironmentFile=/opt/tandoor/.env
 | 
				
			||||||
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
 | 
					ExecStart=/opt/tandoor/.venv/bin/gunicorn --error-logfile /tmp/gunicorn_err.log --log-level debug --capture-output --bind unix:/opt/tandoor/tandoor.sock recipes.wsgi:application
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[Install]
 | 
					[Install]
 | 
				
			||||||
WantedBy=multi-user.target
 | 
					WantedBy=multi-user.target
 | 
				
			||||||
@@ -109,8 +109,8 @@ EOF
 | 
				
			|||||||
cat <<'EOF' >/etc/nginx/conf.d/tandoor.conf
 | 
					cat <<'EOF' >/etc/nginx/conf.d/tandoor.conf
 | 
				
			||||||
server {
 | 
					server {
 | 
				
			||||||
    listen 8002;
 | 
					    listen 8002;
 | 
				
			||||||
    #access_log /var/log/nginx/access.log;
 | 
					    access_log /var/log/nginx/access.log;
 | 
				
			||||||
    #error_log /var/log/nginx/error.log;
 | 
					    error_log /var/log/nginx/error.log;
 | 
				
			||||||
    client_max_body_size 128M;
 | 
					    client_max_body_size 128M;
 | 
				
			||||||
    # serve media files
 | 
					    # serve media files
 | 
				
			||||||
    location /static/ {
 | 
					    location /static/ {
 | 
				
			||||||
@@ -123,12 +123,15 @@ server {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    location / {
 | 
					    location / {
 | 
				
			||||||
        proxy_set_header Host $http_host;
 | 
					        proxy_set_header Host $http_host;
 | 
				
			||||||
 | 
					        proxy_set_header X-Real-IP $remote_addr;
 | 
				
			||||||
 | 
					        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 | 
				
			||||||
 | 
					        proxy_set_header X-Forwarded-Proto $scheme;
 | 
				
			||||||
        proxy_pass http://unix:/opt/tandoor/tandoor.sock;
 | 
					        proxy_pass http://unix:/opt/tandoor/tandoor.sock;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
EOF
 | 
					EOF
 | 
				
			||||||
systemctl reload nginx
 | 
					systemctl reload nginx
 | 
				
			||||||
systemctl enable -q --now gunicorn_tandoor
 | 
					systemctl enable -q --now tandoor
 | 
				
			||||||
msg_ok "Created Services"
 | 
					msg_ok "Created Services"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
motd_ssh
 | 
					motd_ssh
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user