19 Commits
16.0 ... main

Author SHA1 Message Date
Yhael S
53f235a619 Merge pull request #22 from norlinhenrik/main-readme-prod-env
[IMP] README.md: production: Update .env SERVICES and ACME_CA_URI
2024-07-15 21:54:19 -06:00
Henrik Norlin
4f1132afef [IMP] README.md: Quick Setup Guide: cd odoocker 2024-06-02 12:17:02 +02:00
Henrik Norlin
faa6cf6b4c [IMP] README.md: production: Update .env SERVICES and ACME_CA_URI 2024-06-02 11:19:08 +02:00
yhaelopez
7568dbc44f cleanup 2023-12-24 12:55:39 -07:00
yhaelopez
77edc03b91 refactored enterprise + third party addons clonning process 2023-12-24 12:22:16 -07:00
yhaelopez
6fd07e113a cleanup 2023-12-19 21:04:12 -07:00
yhaelopez
bf51474d47 cleanup 2023-12-19 19:37:24 -07:00
yhaelopez
137e653d7f fixed pgadmin 2023-12-19 03:01:15 -07:00
yhaelopez
f2be28ff3e upgrade: third party public and private addons are now dynamically cloned and extensible with a handy format 2023-12-19 02:17:56 -07:00
yhaelopez
f9a6d5c1ab fixed urllib3 to 1.26.5 2023-12-18 17:15:10 -07:00
yhaelopez
d3e819b4b6 cleanup 2023-12-18 17:01:04 -07:00
yhaelopez
1a191383fa cleanup 2023-12-18 16:51:49 -07:00
yhaelopez
f29066cc16 cleanup 2023-12-18 16:50:26 -07:00
yhaelopez
649c51cc9c Merge branch '17.0' 2023-12-15 17:37:01 -07:00
yhaelopez
ecac58a89e cleanup 2023-12-15 17:21:02 -07:00
yhaelopez
c677cdd69e cleanup 2023-12-15 17:00:05 -07:00
yhaelopez
fa93ecd4f4 cleanup 2023-12-15 16:58:19 -07:00
yhaelopez
2076c8ddfa upgrade 2023-12-15 16:55:25 -07:00
yhaelopez
98b94b6f86 version 17 first release 2023-12-12 21:40:17 -07:00
17 changed files with 204 additions and 170 deletions

View File

@@ -8,9 +8,10 @@ UPDATE=
LOAD=base,web LOAD=base,web
ROOT_PATH=/usr/lib/python3/dist-packages/odoo ROOT_PATH=/usr/lib/python3/dist-packages/odoo
WORKERS=0 WORKERS=0
DEV_MODE=reload,xml
DOMAIN=erp.odoocker.test DOMAIN=erp.odoocker.test
ADMIN_PASSWD=odoo ADMIN_PASSWD=odoo
# Use reload,xml to enable hot reload in python and xml files
DEV_MODE=
# Services # Services
PROJECT_NAME=odoocker PROJECT_NAME=odoocker
@@ -22,10 +23,14 @@ USE_S3=false
USE_SENTRY=false USE_SENTRY=false
USE_PGADMIN=false USE_PGADMIN=false
# Enterprise # GitHub user and access token to clone private repositories
GITHUB_USER= GITHUB_USER=
GITHUB_ACCESS_TOKEN= GITHUB_ACCESS_TOKEN=
# GitHub user and access token to clone Enterprise repository
ENTERPRISE_USER=${GITHUB_USER}
ENTERPRISE_ACCESS_TOKEN=${GITHUB_ACCESS_TOKEN}
# Database # Database
DB_HOST=postgres DB_HOST=postgres
DB_PORT=5432 DB_PORT=5432
@@ -114,6 +119,7 @@ PGADMIN_DB_HOST="'postgresql://${PGADMING_DB_USER}:${PGADMIN_DB_PASSWORD}@${DB_H
PGADMIN_EMAIL=pgadmin@example.com PGADMIN_EMAIL=pgadmin@example.com
PGADMIN_PASSWORD=pgadmin PGADMIN_PASSWORD=pgadmin
# To import servers use /pgadmin4/servers.json on first build, then remove.
PGADMIN_SERVERS_JSON= PGADMIN_SERVERS_JSON=
PGADMIN_CONFIG_SERVER_MODE=True PGADMIN_CONFIG_SERVER_MODE=True
@@ -144,14 +150,14 @@ MINIO_PROFILES="minio"
PGADMIN_PROFILES="pgadmin" PGADMIN_PROFILES="pgadmin"
# Containers' Tags # Containers' Tags
ODOO_TAG=16.0 ODOO_TAG=17.0
POSTGRES_TAG=16.1 POSTGRES_TAG=16.1
KEYDB_TAG=latest KEYDB_TAG=latest
MINIO_TAG=latest MINIO_TAG=latest
NGINX_TAG=1.25.3 NGINX_TAG=1.25.3
NGINX_PROXY_TAG=1.4.0 NGINX_PROXY_TAG=1.4.0
ACME_COMPANION_TAG=2.2.9 ACME_COMPANION_TAG=2.2.9
PGADMIN_TAG=8.0 PGADMIN_TAG=8.1
# Odoocker paths # Odoocker paths
COMMUNITY_ADDONS=${ROOT_PATH}/addons COMMUNITY_ADDONS=${ROOT_PATH}/addons

View File

@@ -43,6 +43,7 @@ In essence, Odoocker isn't just another tool, it's a philosophy. So, whether you
1. **Clone and Configure**: 1. **Clone and Configure**:
``` ```
git clone git@github.com:odoocker/odoocker.git git clone git@github.com:odoocker/odoocker.git
cd odoocker
cp .env.example .env && cp docker-compose.override.local.yml docker-compose.override.yml cp .env.example .env && cp docker-compose.override.local.yml docker-compose.override.yml
``` ```
2. **Hosts & Domains**: To ensure everything runs smoothly, remember to add the necessary domains to your hosts file. 2. **Hosts & Domains**: To ensure everything runs smoothly, remember to add the necessary domains to your hosts file.
@@ -155,6 +156,7 @@ docker-compose down
``` ```
cp docker-compose.override.production.yml docker-compose.override.yml cp docker-compose.override.production.yml docker-compose.override.yml
``` ```
- Update .env `SERVICES` (add `acme`) and `ACME_CA_URI` (use production link).
- Make sure the DNS record of your `DOMAIN` is pointing to your server. - Make sure the DNS record of your `DOMAIN` is pointing to your server.
- Rebuild the containers - Rebuild the containers
``` ```

View File

@@ -20,3 +20,15 @@ services:
ports: ports:
- 80:80 - 80:80
- 443:443 - 443:443
letsencrypt:
restart: 'no'
redis:
restart: 'no'
s3:
restart: 'no'
pgadmin:
restart: 'no'

View File

@@ -20,3 +20,15 @@ services:
ports: ports:
- 80:80 - 80:80
- 443:443 - 443:443
letsencrypt:
restart: unless-stopped
redis:
restart: unless-stopped
s3:
restart: unless-stopped
pgadmin:
restart: unless-stopped

View File

@@ -7,9 +7,11 @@ services:
- ODOO_TAG - ODOO_TAG
- ODOO_RC - ODOO_RC
- ROOT_PATH - ROOT_PATH
- ENTERPRISE_USER
- ENTERPRISE_ACCESS_TOKEN
- ENTERPRISE_ADDONS
- GITHUB_USER - GITHUB_USER
- GITHUB_ACCESS_TOKEN - GITHUB_ACCESS_TOKEN
- ENTERPRISE_ADDONS
- THIRD_PARTY_ADDONS - THIRD_PARTY_ADDONS
- LOG_PATH - LOG_PATH
- USE_REDIS - USE_REDIS
@@ -58,7 +60,6 @@ services:
dockerfile: ./postgres/Dockerfile dockerfile: ./postgres/Dockerfile
args: args:
- POSTGRES_TAG - POSTGRES_TAG
restart: unless-stopped
tty: true tty: true
volumes: volumes:
- pg-data:${PGDATA} - pg-data:${PGDATA}
@@ -82,7 +83,6 @@ services:
image: nginx:${NGINX_TAG} image: nginx:${NGINX_TAG}
depends_on: depends_on:
- odoo - odoo
restart: unless-stopped
tty: true tty: true
expose: expose:
- 80/tcp - 80/tcp
@@ -102,7 +102,6 @@ services:
image: nginxproxy/nginx-proxy:${NGINX_PROXY_TAG} image: nginxproxy/nginx-proxy:${NGINX_PROXY_TAG}
depends_on: depends_on:
- nginx - nginx
restart: unless-stopped
tty: true tty: true
volumes: volumes:
- ./nginx-proxy/nginx.conf:${NGINX_CONF} - ./nginx-proxy/nginx.conf:${NGINX_CONF}
@@ -118,12 +117,29 @@ services:
- internal - internal
profiles: [$NGINX_PROXY_PROFILES] profiles: [$NGINX_PROXY_PROFILES]
letsencrypt:
image: nginxproxy/acme-companion:${ACME_COMPANION_TAG}
depends_on:
- nginx-proxy
volumes_from:
- nginx-proxy:rw
volumes:
- certs:${NGINX_CERTS}:rw
- acme:${NGINX_ACME}
- ${DOCKER_SOCK}:${DOCKER_SOCK}:ro
environment:
- ACME_CA_URI
- CERTS_UPDATE_INTERVAL
- DEFAULT_EMAIL
networks:
- internal
profiles: [$ACME_COMPANION_PROFILES]
redis: redis:
image: eqalpha/keydb:${KEYDB_TAG} image: eqalpha/keydb:${KEYDB_TAG}
platform: linux/amd64 platform: linux/amd64
ports: ports:
- ${KEYDB_PORT}:${KEYDB_PORT} - ${KEYDB_PORT}:${KEYDB_PORT}
restart: unless-stopped
volumes: volumes:
- redis-data:${KEYDB_DATA} - redis-data:${KEYDB_DATA}
networks: networks:
@@ -148,32 +164,14 @@ services:
- internal - internal
profiles: [$MINIO_PROFILES] profiles: [$MINIO_PROFILES]
letsencrypt:
image: nginxproxy/acme-companion:${ACME_COMPANION_TAG}
depends_on:
- nginx-proxy
restart: unless-stopped
volumes_from:
- nginx-proxy:rw
volumes:
- certs:${NGINX_CERTS}:rw
- acme:${NGINX_ACME}
- ${DOCKER_SOCK}:${DOCKER_SOCK}:ro
environment:
- ACME_CA_URI
- CERTS_UPDATE_INTERVAL
- DEFAULT_EMAIL
networks:
- internal
profiles: [$ACME_COMPANION_PROFILES]
pgadmin: pgadmin:
build: build:
context: ./ context: ./
dockerfile: ./pgadmin/Dockerfile dockerfile: ./pgadmin/Dockerfile
args: args:
- PGADMIN_TAG - PGADMIN_TAG
restart: 'no' depends_on:
- nginx-proxy
expose: expose:
- 80 - 80
volumes: volumes:

View File

@@ -11,9 +11,11 @@ USER root
ARG ODOO_TAG ARG ODOO_TAG
ARG ROOT_PATH ARG ROOT_PATH
ARG LOG_PATH ARG LOG_PATH
ARG ENTERPRISE_USER
ARG ENTERPRISE_ACCESS_TOKEN
ARG ENTERPRISE_ADDONS
ARG GITHUB_USER ARG GITHUB_USER
ARG GITHUB_ACCESS_TOKEN ARG GITHUB_ACCESS_TOKEN
ARG ENTERPRISE_ADDONS
ARG THIRD_PARTY_ADDONS ARG THIRD_PARTY_ADDONS
ARG ODOO_RC ARG ODOO_RC
ARG USE_REDIS ARG USE_REDIS
@@ -22,80 +24,67 @@ ARG USE_SENTRY
ENV ODOO_TAG=${ODOO_TAG} \ ENV ODOO_TAG=${ODOO_TAG} \
LOG_PATH=${LOG_PATH} \ LOG_PATH=${LOG_PATH} \
ENTERPRISE_USER=${ENTERPRISE_USER} \
ENTERPRISE_ACCESS_TOKEN=${ENTERPRISE_ACCESS_TOKEN} \
ENTERPRISE_ADDONS=${ENTERPRISE_ADDONS} \
GITHUB_USER=${GITHUB_USER} \ GITHUB_USER=${GITHUB_USER} \
GITHUB_ACCESS_TOKEN=${GITHUB_ACCESS_TOKEN} \ GITHUB_ACCESS_TOKEN=${GITHUB_ACCESS_TOKEN} \
ENTERPRISE_ADDONS=${ENTERPRISE_ADDONS} \
THIRD_PARTY_ADDONS=${THIRD_PARTY_ADDONS} \ THIRD_PARTY_ADDONS=${THIRD_PARTY_ADDONS} \
ODOO_RC=${ODOO_RC} \ ODOO_RC=${ODOO_RC} \
USE_REDIS=${USE_REDIS} \ USE_REDIS=${USE_REDIS} \
USE_S3=${USE_S3} \ USE_S3=${USE_S3} \
USE_SENTRY=${USE_SENTRY} USE_SENTRY=${USE_SENTRY}
#---------------------#
# Logging #
#---------------------#
# Create odoo.log file
RUN touch ${LOG_PATH} && chown odoo:odoo ${LOG_PATH}
#------------------------# #------------------------#
# APT Dependencies # # APT Dependencies #
#------------------------# #------------------------#
# Install Odoocker image dependencies
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \
apt-utils \ # `zip` and `unzip` for filestore management
zip \
unzip \
# `git` required packages
git \ git \
git-man \ git-man \
less \ less \
libcbor0 \ libcbor0.8 \
libcurl3-gnutls \ libcurl3-gnutls \
libedit2 \ libedit2 \
liberror-perl \ liberror-perl \
libfido2-1 \
libxmuu1 \ libxmuu1 \
openssh-client \ openssh-client \
patch \ patch \
xauth \ xauth \
# Clean up the apt cache to reduce the image size # Remove apt lists
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
#---------------------# #---------------------#
# PIP Dependecies # # PIP Dependecies #
#---------------------# #---------------------#
# Upgrade pip
RUN pip3 install --upgrade pip
# Copy & Install PIP requirements # Copy & Install PIP requirements
COPY --chown=odoo:odoo ./odoo/requirements.txt /tmp/requirements.txt COPY --chown=odoo:odoo ./odoo/requirements.txt /tmp/requirements.txt
RUN python3 -m pip install -r /tmp/requirements.txt && \ RUN python3 -m pip install -r /tmp/requirements.txt && \
rm /tmp/requirements.txt rm /tmp/requirements.txt
#-----------------------# #--------------------------------------------#
# Odoo Enterprise # # Odoo Enterprise + Third Party Addons #
#-----------------------# #--------------------------------------------#
# Create third-party-addons directory and clone them
# Create Enterprise addons directory COPY --chown=odoo:odoo ./odoo/clone-addons.sh /
RUN mkdir -p ${ENTERPRISE_ADDONS} && \ COPY --chown=odoo:odoo ./odoo/third-party-addons.txt /
chown odoo:odoo -R ${ENTERPRISE_ADDONS} RUN /clone-addons.sh
# Clone Enterprise addons if user and token are present
RUN if [ -n "$GITHUB_USER" ] && [ -n "$GITHUB_ACCESS_TOKEN" ]; then \
git clone https://${GITHUB_USER}:${GITHUB_ACCESS_TOKEN}@github.com/odoo/enterprise.git ${ENTERPRISE_ADDONS} --depth 1 --branch ${ODOO_TAG} --single-branch --no-tags; \
fi
#-------------------------#
# Odoo Extra Addons #
#-------------------------#
RUN mkdir -p ${THIRD_PARTY_ADDONS} && chown odoo:odoo -R ${THIRD_PARTY_ADDONS}
COPY --chown=odoo:odoo ./odoo/fix-manifest.py /
COPY --chown=odoo:odoo ./odoo/third-party-addons.sh /
RUN /third-party-addons.sh && chown odoo:odoo -R ${THIRD_PARTY_ADDONS}
#---------------------#
# Logging #
#---------------------#
# Create odoo.log file
RUN touch ${LOG_PATH} && chown odoo:odoo ${LOG_PATH}
#-----------------------# #-----------------------#
# Odoo Conf # # Odoo Conf #
#-----------------------# #-----------------------#
# Copy environment variables & script to generate odoo.conf # Copy environment variables & script to generate odoo.conf
COPY --chown=odoo:odoo ./.env / COPY --chown=odoo:odoo ./.env /
COPY --chown=odoo:odoo ./odoo/odoo.conf / COPY --chown=odoo:odoo ./odoo/odoo.conf /

91
odoo/clone-addons.sh Executable file
View File

@@ -0,0 +1,91 @@
#!/bin/bash
set -e
# Function to construct the clone command
construct_clone_command() {
local repo_type=$1
local repo_url=$2
case $repo_type in
private) echo "git clone https://${GITHUB_USER}:${GITHUB_ACCESS_TOKEN}@${repo_url#https://}" ;;
enterprise) echo "git clone https://${ENTERPRISE_USER}:${ENTERPRISE_ACCESS_TOKEN}@${repo_url#https://} ${ENTERPRISE_ADDONS}" ;;
public) echo "git clone $repo_url" ;;
esac
}
# Function to clone and copy modules based on conditions
clone_and_copy_modules() {
local repo_type=$1
local repo_url=$2
local clone_cmd=$(construct_clone_command $repo_type $repo_url)
local repo_name=$(basename -s .git "$repo_url")
shift 2
local modules_conditions=("$@")
# Clone and copy logic for enterprise repository
if [[ $repo_type == "enterprise" ]]; then
if [ -n "$GITHUB_USER" ] && [ -n "$GITHUB_ACCESS_TOKEN" ]; then
$clone_cmd --depth 1 --branch ${ODOO_TAG} --single-branch --no-tags
fi
else
# Determine if any module has a true condition
local should_clone=false
if [[ ${#modules_conditions[@]} -eq 1 ]]; then
[[ ${modules_conditions[0]} == true ]] && should_clone=true
else
for (( i=1; i<${#modules_conditions[@]}; i+=2 )); do
if [[ ${modules_conditions[i]} == true ]]; then
should_clone=true
break
fi
done
fi
# Clone the repo if should_clone is true and it's not already cloned
if [[ $should_clone == true && ! -d "$repo_name" ]]; then
$clone_cmd --depth 1 --branch ${ODOO_TAG} --single-branch --no-tags
fi
# Copy the modules if the condition is true
if [[ $should_clone == true ]]; then
for (( i=0; i<${#modules_conditions[@]}; i+=2 )); do
local module=${modules_conditions[i]}
local condition=${modules_conditions[i+1]}
if [[ $condition == true ]]; then
echo "Copying ${module} from ${repo_name} into ${THIRD_PARTY_ADDONS}"
cp -r /${repo_name}/${module} ${THIRD_PARTY_ADDONS}/${module}
fi
done
fi
fi
}
# Function to manually expand environment variables in a string
expand_env_vars() {
while IFS=' ' read -r -a words; do
for word in "${words[@]}"; do
if [[ $word == \$\{* ]]; then
# Remove the leading '${' and the trailing '}' from the word
varname=${word:2:-1}
# Check if the variable is set and not empty
if [ -n "${!varname+x}" ]; then
echo -n "${!varname} " # Substitute with its value
else
echo -n "false " # Default to false if not set
fi
else
echo -n "$word "
fi
done
echo
done <<< "$1"
}
# Read the configuration file and process each line
while IFS= read -r line; do
mkdir -p ${ENTERPRISE_ADDONS}
mkdir -p ${THIRD_PARTY_ADDONS}
[[ -z "$line" || "$line" == \#* ]] && continue
clone_and_copy_modules $(expand_env_vars "$line")
done < "third-party-addons.txt"

View File

@@ -1 +1 @@
Delete me once you add your first custom addon :) Delete me once you add your first custom addon :)

View File

@@ -71,14 +71,14 @@ case "$1" in
# Automagically upgrade all addons and install new ones. Ideal for deployment process. # Automagically upgrade all addons and install new ones. Ideal for deployment process.
echo odoo --config ${ODOO_RC} --database=${DB_NAME} --init=${INIT} --update=all --load=${LOAD} --log-level=${LOG_LEVEL} --load-language=${LOAD_LANGUAGE} --limit-time-cpu=3600 --limit-time-real=7200 --dev= echo odoo --config ${ODOO_RC} --database=${DB_NAME} --init=${INIT} --update=all --load=${LOAD} --log-level=${LOG_LEVEL} --load-language=${LOAD_LANGUAGE} --limit-time-cpu=3600 --limit-time-real=7200 --dev=
exec odoo --config ${ODOO_RC} --update=all --without-demo=all --workers=0 --limit-time-cpu=3600 --limit-time-real=7200 --dev= exec odoo --config ${ODOO_RC} --database=${DB_NAME} --init=${INIT} --update=all --without-demo=all --workers=0 --limit-time-cpu=3600 --limit-time-real=7200 --dev=
fi fi
if [ ${APP_ENV} = 'production' ] ; then if [ ${APP_ENV} = 'production' ] ; then
# Bring up Odoo ready for production. # Bring up Odoo ready for production.
echo odoo --config ${ODOO_RC} --database=${DB_NAME} --init=${INIT} --update=${UPDATE} --load=${LOAD} --workers=${WORKERS} --log-level=${LOG_LEVEL} --without-demo=${WITHOUT_DEMO} --load-language= --dev= echo odoo --config ${ODOO_RC} --database= --init=${INIT} --update=${UPDATE} --load=${LOAD} --workers=${WORKERS} --log-level=${LOG_LEVEL} --without-demo=${WITHOUT_DEMO} --load-language= --dev=
exec odoo --config ${ODOO_RC} --init=${INIT} --update=${UPDATE} --load-language= --dev= exec odoo --config ${ODOO_RC} --database= --init=${INIT} --update=${UPDATE} --load-language= --dev=
fi fi
fi fi
;; ;;

View File

@@ -0,0 +1,2 @@
Delete me once you add your first extra addon :)
This folder is made for addons that are not clonable via GitHub.

View File

@@ -1,24 +0,0 @@
{
'name': 'Odoocker Base',
'summary': 'Supercharge Odoo with Odoocker',
'description': '''
Some Odoocker dependencies require to some custom values that we cover with this Addon for you.
''',
'version': '1.0.0',
'category': 'Technical',
'license': 'LGPL-3',
'author': 'Odoocker',
'maintainer': 'Odoocker',
'contributors': [
'Yhael S <yhaelopez@gmail.com>'
],
'depends': [
'base'
],
'data': [
'data/ir_config_parameter.xml'
],
'application': False,
'installable': True,
'auto_install': True
}

View File

@@ -1,14 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- When initializing Odoo through Docker this parameter is missing. -->
<record id="report_url" model="ir.config_parameter">
<field name="key">report.url</field>
<field name="value">http://127.0.0.1:8069</field>
</record>
<!-- When initializing Odoo with S3 storage. -->
<record id="ir_attachment_location" model="ir.config_parameter">
<field name="key">ir_attachment.location</field>
<field name="value">s3</field>
</record>
</odoo>

View File

@@ -1,34 +0,0 @@
import sys
# Define the path to the manifest file
manifest_file_path = sys.argv[1]
# Read the file content
with open(manifest_file_path, 'r') as file:
lines = file.readlines()
# Find the start and end index of the manifest dictionary
start_index = next(i for i, line in enumerate(lines) if line.strip().startswith('{'))
end_index = next(i for i, line in enumerate(lines) if line.strip().endswith('}'))
# Construct and evaluate the manifest dictionary
manifest_dict = eval(''.join(lines[start_index:end_index + 1]))
# Modify the manifest dictionary
manifest_dict['installable'] = True
manifest_dict['auto_install'] = True
# Construct the modified manifest string
modified_manifest_lines = ['{\n']
for key, value in manifest_dict.items():
modified_manifest_lines.append(f" '{key}': {repr(value)},\n")
modified_manifest_lines.append('}\n')
# Replace the manifest dictionary string in the content
lines[start_index:end_index + 1] = modified_manifest_lines
# Write the modified content back to the file
with open(manifest_file_path, 'w') as file:
file.writelines(lines)
print(f"Modified {manifest_file_path}")

View File

@@ -64,7 +64,7 @@ xmlrpcs_interface = ${XMLRPCS_INTERFACE}
; --xmlrpcs-port ; --xmlrpcs-port
xmlrpcs_port = ${XMLRPCS_PORT} xmlrpcs_port = ${XMLRPCS_PORT}
; --gevent-port | --longpolling-port (deprecated) ; --gevent-port
gevent_port = ${GEVENT_PORT} gevent_port = ${GEVENT_PORT}
; --no-http | --no-xmlrpc ; --no-http | --no-xmlrpc
@@ -226,7 +226,7 @@ stop_after_init = ${STOP_AFTER_INIT}
; --osv-memory-count-limit ; --osv-memory-count-limit
osv_memory_count_limit = ${OSV_MEMORY_COUNT_LIMIT} osv_memory_count_limit = ${OSV_MEMORY_COUNT_LIMIT}
; --transient-age-limit | --osv-memory-age-limit (deprecated) ; --transient-age-limit
transient_age_limit = ${TRANSIENT_AGE_LIMIT} transient_age_limit = ${TRANSIENT_AGE_LIMIT}
; --max-cron-threads ; --max-cron-threads

View File

@@ -2,4 +2,4 @@ debugpy
websocket-client websocket-client
redis redis
boto3 boto3
sentry-sdk sentry-sdk==1.9.0 # Fixed because Odoo depends on urllib3==1.26.5

View File

@@ -1,24 +0,0 @@
#!/bin/bash
set -e
# Check if the repository directory exists and either Redis or S3 is to be used
if [[ ${USE_REDIS} == "true" || ${USE_S3} == "true" ]]; then
git clone https://github.com/odoocker/odoo-cloud-platform.git --depth 1 --branch ${ODOO_TAG} --single-branch --no-tags;
fi
if [[ ${USE_REDIS} == "true" ]]; then
cp -r odoo-cloud-platform/session_redis ${THIRD_PARTY_ADDONS}/session_redis
fi
# Check the USE_S3 variable to decide whether to copy S3 directories
if [[ ${USE_S3} == "true" ]]; then
cp -r odoo-cloud-platform/base_attachment_object_storage ${THIRD_PARTY_ADDONS}/base_attachment_object_storage
cp -r odoo-cloud-platform/attachment_s3 ${THIRD_PARTY_ADDONS}/attachment_s3
fi
# Check if the repository directory exists and Sentry is to be used
if [[ ${USE_SENTRY} == "true" ]]; then
git clone https://github.com/odoocker/server-tools.git --depth 1 --branch ${ODOO_TAG} --single-branch --no-tags;
cp -r server-tools/sentry ${THIRD_PARTY_ADDONS}/sentry
fi

View File

@@ -0,0 +1,18 @@
# This file is read by clone-addons.sh
# Enterprise addons
enterprise https://github.com/odoo/enterprise true
# Odoocker repositories
public https://github.com/odoocker/odoocker-modules.git odoocker_base true
public https://github.com/odoocker/odoo-cloud-platform.git session_redis ${USE_REDIS} base_attachment_object_storage ${USE_S3} attachment_s3 ${USE_S3}
public https://github.com/odoocker/server-tools.git sentry ${USE_SENTRY}
# Add repositories with the following format:
# <public|private> <repo_url> <true|false>
# or
# <public|private> <repo_url> <module1> <true|false> <module2> <true|false> ...
# Public repositories
# Private repositories