From 09c46d4a8c686ffe57dd5dd209e5a879a6d95ac6 Mon Sep 17 00:00:00 2001 From: Oliver Date: Fri, 10 Oct 2025 07:35:27 -0300 Subject: [PATCH] add ODOO 18 --- .gitignore | 1 + app/sbin/start/ODOO_18 | 112 ++++++++++++++++++++++++++++++++++++++++ app/sbin/startContainer | 5 ++ docker-compose.yaml | 1 + 4 files changed, 119 insertions(+) create mode 100755 app/sbin/start/ODOO_18 diff --git a/.gitignore b/.gitignore index 3fec32c..702ef98 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ tmp/ +exchange/ diff --git a/app/sbin/start/ODOO_18 b/app/sbin/start/ODOO_18 new file mode 100755 index 0000000..b532e33 --- /dev/null +++ b/app/sbin/start/ODOO_18 @@ -0,0 +1,112 @@ +#!/bin/bash + +# Load functions +source /4server/sbin/ODOO_19/ODOO_19.lib +source /4server/sbin/helpers +get_contract_info + +# Config variables +UUID="${UUID:-default}" +BRANCH="${BRANCH:-release}" + +ODOO_DB_USER="${UUID}" +export ODOO_DB_PASSWORD=$(echo "$SECRET" | jq -r '.psql') + + +echo "ENV: $HDD $DOMAIN_COUNT $BACKUP_SLOTS $CONTAINERDBID" +echo "DBID: $CONTAINERDBID" + +BASEURL="${BASEURL:-/4server/data/$UUID}" +DATA_DIR="$BASEURL/odoo/" +CUSTOM_DIR="$BASEURL/git/$UUID/custom/" +ENTERPRISE_DIR="$BASEURL/git/$UUID/enterprise/" +LOGS_DIR="$BASEURL/logs/" +CONFIG_DIR="$BASEURL/config/" +CC_DIR="$BASEURL/cc/" +BACKUP_DIR="/BACKUP/$UUID" +GIT_DIR="$BASEURL/git-server/" +INSTALL_DIR="$BASEURL/install/" +SSH_DIR="$BASEURL/.ssh/" +ETC_DIR="$BASEURL/etc/" + +SERVER_IP=$(ip -4 addr show eth0 | awk '/inet/ {print $2}' | cut -d/ -f1 | head -n1) + +LABEL_DOMAINS=("$UUID.odoo4projects.com") +if [ -f "$BASEURL/etc/domain" ]; then + while IFS= read -r domain || [[ -n $domain ]]; do + [ -z "$domain" ] && continue + LABEL_DOMAINS+=("$domain") + done < "$BASEURL/etc/domain" +else + echo "[DEBUG] No additional domain file found at $BASEURL/etc/domain" +fi + +RULE="" +for d in "${LABEL_DOMAINS[@]}"; do + RESOLVED_IP=$(nslookup "$d" 2>/dev/null | awk '/^Address: / { print $2 }' | head -n1 || true) + if [ -z "$RESOLVED_IP" ]; then + echo "[DEBUG] Could not resolve $d, skipping" + continue + fi + if [ "$RESOLVED_IP" = "$SERVER_IP" ]; then + RULE+=" || Host(\`$d\`)" + else + echo "[DEBUG] Skipping $d (does not match SERVER_IP $SERVER_IP)" + fi +done +RULE="${RULE# || }" +DOMAIN_LABEL="traefik.http.routers.$UUID.rule=$RULE" +echo "[DEBUG] Final Traefik label: $DOMAIN_LABEL" + + + +doas find "$BASEURL" -type d -exec chmod 777 {} \; +PORT=$((CONTAINERDBID + 2200)) +echo "PORT $PORT" +echo "git clone \"ssh://git@${UUID}.odoo4projects.com:${PORT}/git-server/repos/odoo.git\"" > "${ETC_DIR}/gitpath" + + +doas docker stop "$UUID" 2>/dev/null +doas docker rm "$UUID" 2>/dev/null + +EXTRA_DOCKER_PARAMETER="" + +doas docker run -d --name "$UUID" \ + --network 4server_4projects \ + --restart=always \ + $EXTRA_DOCKER_PARAMETER \ + -v "$DATA_DIR/odoo-web-data:/home/odoo/.local/share/Odoo" \ + -v "$CUSTOM_DIR:/mnt/addons/custom" \ + -v "$ENTERPRISE_DIR:/mnt/addons/enterprise" \ + -v "$LOGS_DIR:/mnt/logs" \ + -v "$CC_DIR:/mnt/cc" \ + -v "$BACKUP_DIR:/mnt/backup" \ + -v "$GIT_DIR:/git-server" \ + -v "$INSTALL_DIR:/mnt/install" \ + -v "$SSH_DIR:/etc/sshkey" \ + -v "$ETC_DIR:/mnt/etc" \ + -p "$PORT:22" \ + -e HOST="beedb" \ + -e USER="$ODOO_DB_USER" \ + -e PASSWORD="$ODOO_DB_PASSWORD" \ + -e UUID="$UUID" \ + -e HDD="$HDD" \ + -e DOMAIN_COUNT="$DOMAIN_COUNT" \ + -e BACKUP_SLOTS="$BACKUP_SLOTS" \ + -e WORKER="$WORKER" \ + -e GIT="$GIT" \ + --label "$DOMAIN_LABEL" \ + --label "traefik.http.services.$UUID.loadbalancer.server.port=8069" \ + --label "traefic.http.routers.$UUID.entrypoints=web, websecure" \ + --label "traefik.http.routers.$UUID.tls.certresolver=production" \ + --label "traefik.http.routers.$UUID.tls=true" \ + --label "traefik.http.routers.$UUID.service=$UUID" \ + docker.odoo4projects.com/4projects/odoo_18:$BRANCH + + +doas docker exec $UUID chown -R odoo:odoo /home/odoo/.local +doas docker exec $UUID chown -R odoo:odoo /mnt/* + + + +check_and_create_db diff --git a/app/sbin/startContainer b/app/sbin/startContainer index 43d0fd2..e89bb36 100755 --- a/app/sbin/startContainer +++ b/app/sbin/startContainer @@ -25,6 +25,11 @@ case "$SECOND_PART" in 001) "$BIN_PATH/start/n8n" ;; + 002) + "$BIN_PATH/start/odoo_18" + ;; + + 003) "$BIN_PATH/start/ODOO_19" ;; diff --git a/docker-compose.yaml b/docker-compose.yaml index 2ab41c0..ff99ace 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -4,6 +4,7 @@ services: context: ./alpine volumes: - ./app:/app + - ./exchange:/app/exchange tty: true privileged: true extra_hosts: