From 7c94648686b21ab09315689db0015543a9a23eff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20-=20Le=20Filament?= <remi@le-filament.com> Date: Fri, 3 Nov 2023 15:59:39 +0100 Subject: [PATCH] [ADD] version 17.0 --- .gitlab-ci.yml | 12 ++++ 16.0.Dockerfile | 146 ------------------------------------------------ 17.0.Dockerfile | 146 ++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 158 insertions(+), 146 deletions(-) delete mode 100644 16.0.Dockerfile create mode 100644 17.0.Dockerfile diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index e6e46ac..05f8e10 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -80,3 +80,15 @@ docker-build-16.0: # - docker push "$CI_REGISTRY_IMAGE:16.0-scratch" # only: # - '16.0' +docker-build-17.0: + image: docker:24 + stage: build + services: + - docker:24-dind + before_script: + - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY + script: + - docker build --pull -f 17.0.Dockerfile -t "$CI_REGISTRY_IMAGE:17.0" . + - docker push "$CI_REGISTRY_IMAGE:17.0" + only: + - '17.0' diff --git a/16.0.Dockerfile b/16.0.Dockerfile deleted file mode 100644 index c2366c6..0000000 --- a/16.0.Dockerfile +++ /dev/null @@ -1,146 +0,0 @@ -FROM python:3.11-slim-bullseye AS builder -RUN set -x; \ - apt-get update &&\ - apt-get install -y --no-install-recommends build-essential libldap2-dev libpq-dev libsasl2-dev &&\ - pip install wheel &&\ - pip wheel --wheel-dir=/svc/wheels -r https://raw.githubusercontent.com/oca/OCB/16.0/requirements.txt &&\ - # astor required by base_view_inheritance_extension - # openupgradelib required for OCA module migration from one version to another - # phonenumbers required by phone_validation - # python-stdnum>=1.18 required by l10n_fr_siret and l10n_fr_siret_lookup - # PyYAML required by custom scripts for adding modules (https://sources.le-filament.com/lefilament/ansible-roles/docker_odoo/-/tree/master/templates) - # zxcvbn required by password_security - pip wheel --wheel-dir=/svc/wheels astor openupgradelib phonenumbers python-stdnum>=1.18 PyYAML zxcvbn - - -FROM python:3.11-slim-bullseye AS final -ENV LANG=C.UTF-8 \ - LC_ALL=C.UTF-8 \ - PGDATABASE=odoo - -RUN set -x; \ - apt-get update &&\ - apt-get install -y --no-install-recommends \ - curl \ - git \ - gnupg \ - openssh-client \ - xmlsec1 &&\ - echo 'deb http://apt.postgresql.org/pub/repos/apt/ bullseye-pgdg main' >> /etc/apt/sources.list.d/postgresql.list &&\ - curl -SL https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add - &&\ - curl -o wkhtmltox.deb -SL https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6.1-2/wkhtmltox_0.12.6.1-2.bullseye_amd64.deb &&\ - echo 'cecbf5a6abbd68d324a7cd6c51ec843d71e98951 wkhtmltox.deb' | sha1sum -c - &&\ - apt-get update &&\ - apt-get install -y --no-install-recommends ./wkhtmltox.deb &&\ - apt-get install -y --no-install-recommends postgresql-client &&\ - apt-get -y autoremove &&\ - rm -rf /var/lib/apt/lists/* wkhtmltox.deb - -COPY --from=builder /svc /svc -RUN pip3 install --no-index --find-links=/svc/wheels -r https://raw.githubusercontent.com/oca/OCB/16.0/requirements.txt &&\ - pip3 install -U --no-index --find-links=/svc/wheels astor openupgradelib phonenumbers python-stdnum>=1.18 PyYAML zxcvbn - -# Add Git Known Hosts -COPY ./ssh_known_git_hosts /root/.ssh/known_hosts - -# Install Odoo and remove not French translations and .git directory to limit amount of data used by container -RUN set -x; \ - useradd --create-home --home-dir /opt/odoo --no-log-init odoo &&\ - /bin/bash -c "mkdir -p /opt/odoo/{etc,odoo,additional_addons,private_addons,data,private}" &&\ - curl -L https://github.com/OCA/OCB/tarball/16.0 | tar -xzC /opt/odoo/odoo --strip-components 1 &&\ - find /opt/odoo/odoo/addons/*/i18n/ /opt/odoo/odoo/odoo/addons/base/i18n/ -type f -not -name 'fr.po' -delete &&\ - chown -R odoo:odoo /opt/odoo - -# Install Odoo OCA default dependencies - Commented modules do not exist yet -RUN set -x; \ - mkdir -p /tmp/oca-repos/ &&\ - curl -L https://github.com/OCA/account-financial-tools/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-financial-tools" --strip-components 1 &&\ - mv /tmp/oca-repos/account-financial-tools/account_lock_date_update \ - /tmp/oca-repos/account-financial-tools/account_move_name_sequence \ -# /tmp/oca-repos/account-financial-tools/account_reconcile_show_boolean \ - /tmp/oca-repos/account-financial-tools/account_usability \ - /opt/odoo/additional_addons/ &&\ -# https://github.com/OCA/account-invoicing/pull/1419 -# curl -L https://github.com/OCA/account-invoicing/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-invoicing" --strip-components 1 &&\ -# mv /tmp/oca-repos/account-invoicing/sale_timesheet_invoice_description \ -# /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/account-reconcile/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-reconcile" --strip-components 1 &&\ - mv /tmp/oca-repos/account-reconcile/account_statement_base \ - /tmp/oca-repos/account-reconcile/account_reconcile_oca \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/bank-statement-import/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="bank-statement-import" --strip-components 1 &&\ - mv /tmp/oca-repos/bank-statement-import/account_statement_import_base \ - /tmp/oca-repos/bank-statement-import/account_statement_import_file \ - /tmp/oca-repos/bank-statement-import/account_statement_import_ofx \ - /opt/odoo/additional_addons/ &&\ -# curl -L https://github.com/OCA/crm/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="crm" --strip-components 1 &&\ -# mv /tmp/oca-repos/crm/crm_stage_probability /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/l10n-france/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="l10n-france" --strip-components 1 &&\ - mv /tmp/oca-repos/l10n-france/l10n_fr_siret \ - /tmp/oca-repos/l10n-france/l10n_fr_siret_lookup \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/partner-contact/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="partner-contact" --strip-components 1 &&\ - mv /tmp/oca-repos/partner-contact/partner_disable_gravatar \ - /tmp/oca-repos/partner-contact/partner_firstname \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/project/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="project" --strip-components 1 &&\ - mv /tmp/oca-repos/project/project_task_default_stage \ - /tmp/oca-repos/project/project_template \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/server-auth/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-auth" --strip-components 1 &&\ - mv /tmp/oca-repos/server-auth/password_security \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/server-brand/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-brand" --strip-components 1 &&\ - mv /tmp/oca-repos/server-brand/disable_odoo_online \ - /tmp/oca-repos/server-brand/portal_odoo_debranding \ - /tmp/oca-repos/server-brand/remove_odoo_enterprise \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/server-tools/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-tools" --strip-components 1 &&\ - mv /tmp/oca-repos/server-tools/base_view_inheritance_extension \ - /tmp/oca-repos/server-tools/module_change_auto_install \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/server-ux/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-ux" --strip-components 1 &&\ - mv /tmp/oca-repos/server-ux/server_action_mass_edit \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/social/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="social" --strip-components 1 &&\ - mv /tmp/oca-repos/social/mail_debrand \ - /tmp/oca-repos/social/mail_tracking \ - /opt/odoo/additional_addons/ &&\ - curl -L https://github.com/OCA/web/tarball/16.0 | tar -xzC /tmp/oca-repos/ --one-top-level="web" --strip-components 1 &&\ - mv /tmp/oca-repos/web/web_chatter_position \ - /tmp/oca-repos/web/web_environment_ribbon \ - /tmp/oca-repos/web/web_refresher \ - /tmp/oca-repos/web/web_responsive \ - /tmp/oca-repos/web/web_no_bubble \ - /tmp/oca-repos/web/web_theme_classic \ - /opt/odoo/additional_addons/ &&\ - rm -rf /tmp/oca-repos/ &&\ - find /opt/odoo/additional_addons/*/i18n/ -type f -not -name 'fr.po' -delete &&\ - # Install Le Filament default dependency - git clone -b 16.0 --depth 1 https://sources.le-filament.com/lefilament/remove_login_links.git /opt/odoo/private_addons/remove_login_links &&\ - git clone -b 16.0 --depth 1 https://sources.le-filament.com/lefilament/lefilament_release_agent.git /opt/odoo/private_addons/lefilament_release_agent &&\ - chown -R odoo:odoo /opt/odoo - -# Copy entrypoint script and Odoo configuration file -COPY ./entrypoint.sh / -COPY ./odoo.conf /opt/odoo/etc/odoo.conf -RUN chown odoo:odoo /opt/odoo/etc/odoo.conf - -# Mount /opt/odoo/data to allow restoring filestore -VOLUME ["/opt/odoo/data/"] - -# Expose Odoo services -EXPOSE 8069 - -# Set default user when running the container -USER odoo - -# Start -ENTRYPOINT ["/entrypoint.sh"] -CMD ["odoo"] - -# Metadata -LABEL org.label-schema.schema-version="16.0" \ - org.label-schema.vendor=LeFilament \ - org.label-schema.license=Apache-2.0 \ - org.label-schema.vcs-url="https://sources.le-filament.com/lefilament/odoo_docker" diff --git a/17.0.Dockerfile b/17.0.Dockerfile new file mode 100644 index 0000000..6fe75b4 --- /dev/null +++ b/17.0.Dockerfile @@ -0,0 +1,146 @@ +FROM python:3.12-slim-bookworm AS builder +RUN set -x; \ + apt-get update &&\ + apt-get install -y --no-install-recommends build-essential libldap2-dev libpq-dev libsasl2-dev &&\ + pip install wheel &&\ + pip wheel --wheel-dir=/svc/wheels -r https://raw.githubusercontent.com/oca/OCB/17.0/requirements.txt &&\ + # astor required by base_view_inheritance_extension + # openupgradelib required for OCA module migration from one version to another + # phonenumbers required by phone_validation + # python-stdnum>=1.18 required by l10n_fr_siret and l10n_fr_siret_lookup + # PyYAML required by custom scripts for adding modules (https://sources.le-filament.com/lefilament/ansible-roles/docker_odoo/-/tree/master/templates) + # zxcvbn required by password_security + pip wheel --wheel-dir=/svc/wheels astor openupgradelib phonenumbers python-stdnum>=1.18 PyYAML zxcvbn + + +FROM python:3.12-slim-bookworm AS final +ENV LANG=C.UTF-8 \ + LC_ALL=C.UTF-8 \ + PGDATABASE=odoo + +RUN set -x; \ + apt-get update &&\ + apt-get install -y --no-install-recommends \ + curl \ + git \ + gnupg \ + openssh-client \ + xmlsec1 &&\ + echo 'deb http://apt.postgresql.org/pub/repos/apt/ bullseye-pgdg main' >> /etc/apt/sources.list.d/postgresql.list &&\ + curl -SL https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add - &&\ + curl -o wkhtmltox.deb -SL https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6.1-2/wkhtmltox_0.12.6.1-2.bullseye_amd64.deb &&\ + echo 'cecbf5a6abbd68d324a7cd6c51ec843d71e98951 wkhtmltox.deb' | sha1sum -c - &&\ + apt-get update &&\ + apt-get install -y --no-install-recommends ./wkhtmltox.deb &&\ + apt-get install -y --no-install-recommends postgresql-client &&\ + apt-get -y autoremove &&\ + rm -rf /var/lib/apt/lists/* wkhtmltox.deb + +COPY --from=builder /svc /svc +RUN pip3 install --no-index --find-links=/svc/wheels -r https://raw.githubusercontent.com/oca/OCB/17.0/requirements.txt &&\ + pip3 install -U --no-index --find-links=/svc/wheels astor openupgradelib phonenumbers python-stdnum>=1.18 PyYAML zxcvbn + +# Add Git Known Hosts +COPY ./ssh_known_git_hosts /root/.ssh/known_hosts + +# Install Odoo and remove not French translations and .git directory to limit amount of data used by container +RUN set -x; \ + useradd --create-home --home-dir /opt/odoo --no-log-init odoo &&\ + /bin/bash -c "mkdir -p /opt/odoo/{etc,odoo,additional_addons,private_addons,data,private}" &&\ + curl -L https://github.com/OCA/OCB/tarball/17.0 | tar -xzC /opt/odoo/odoo --strip-components 1 &&\ + find /opt/odoo/odoo/addons/*/i18n/ /opt/odoo/odoo/odoo/addons/base/i18n/ -type f -not -name 'fr.po' -delete &&\ + chown -R odoo:odoo /opt/odoo + +# Install Odoo OCA default dependencies - Commented modules do not exist yet +# RUN set -x; \ +# mkdir -p /tmp/oca-repos/ &&\ +# curl -L https://github.com/OCA/account-financial-tools/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-financial-tools" --strip-components 1 &&\ +# mv /tmp/oca-repos/account-financial-tools/account_lock_date_update \ +# /tmp/oca-repos/account-financial-tools/account_move_name_sequence \ +# /tmp/oca-repos/account-financial-tools/account_reconcile_show_boolean \ +# /tmp/oca-repos/account-financial-tools/account_usability \ +# /opt/odoo/additional_addons/ &&\ +# https://github.com/OCA/account-invoicing/pull/1419 +# curl -L https://github.com/OCA/account-invoicing/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-invoicing" --strip-components 1 &&\ +# mv /tmp/oca-repos/account-invoicing/sale_timesheet_invoice_description \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/account-reconcile/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="account-reconcile" --strip-components 1 &&\ +# mv /tmp/oca-repos/account-reconcile/account_statement_base \ +# /tmp/oca-repos/account-reconcile/account_reconcile_oca \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/bank-statement-import/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="bank-statement-import" --strip-components 1 &&\ +# mv /tmp/oca-repos/bank-statement-import/account_statement_import_base \ +# /tmp/oca-repos/bank-statement-import/account_statement_import_file \ +# /tmp/oca-repos/bank-statement-import/account_statement_import_ofx \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/crm/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="crm" --strip-components 1 &&\ +# mv /tmp/oca-repos/crm/crm_stage_probability /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/l10n-france/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="l10n-france" --strip-components 1 &&\ +# mv /tmp/oca-repos/l10n-france/l10n_fr_siret \ +# /tmp/oca-repos/l10n-france/l10n_fr_siret_lookup \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/partner-contact/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="partner-contact" --strip-components 1 &&\ +# mv /tmp/oca-repos/partner-contact/partner_disable_gravatar \ +# /tmp/oca-repos/partner-contact/partner_firstname \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/project/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="project" --strip-components 1 &&\ +# mv /tmp/oca-repos/project/project_task_default_stage \ +# /tmp/oca-repos/project/project_template \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/server-auth/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-auth" --strip-components 1 &&\ +# mv /tmp/oca-repos/server-auth/password_security \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/server-brand/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-brand" --strip-components 1 &&\ +# mv /tmp/oca-repos/server-brand/disable_odoo_online \ +# /tmp/oca-repos/server-brand/portal_odoo_debranding \ +# /tmp/oca-repos/server-brand/remove_odoo_enterprise \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/server-tools/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-tools" --strip-components 1 &&\ +# mv /tmp/oca-repos/server-tools/base_view_inheritance_extension \ +# /tmp/oca-repos/server-tools/module_change_auto_install \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/server-ux/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="server-ux" --strip-components 1 &&\ +# mv /tmp/oca-repos/server-ux/server_action_mass_edit \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/social/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="social" --strip-components 1 &&\ +# mv /tmp/oca-repos/social/mail_debrand \ +# /tmp/oca-repos/social/mail_tracking \ +# /opt/odoo/additional_addons/ &&\ +# curl -L https://github.com/OCA/web/tarball/17.0 | tar -xzC /tmp/oca-repos/ --one-top-level="web" --strip-components 1 &&\ +# mv /tmp/oca-repos/web/web_chatter_position \ +# /tmp/oca-repos/web/web_environment_ribbon \ +# /tmp/oca-repos/web/web_refresher \ +# /tmp/oca-repos/web/web_responsive \ +# /tmp/oca-repos/web/web_no_bubble \ +# /tmp/oca-repos/web/web_theme_classic \ +# /opt/odoo/additional_addons/ &&\ +# rm -rf /tmp/oca-repos/ &&\ +# find /opt/odoo/additional_addons/*/i18n/ -type f -not -name 'fr.po' -delete &&\ +# # Install Le Filament default dependency +# git clone -b 17.0 --depth 1 https://sources.le-filament.com/lefilament/remove_login_links.git /opt/odoo/private_addons/remove_login_links &&\ +# git clone -b 17.0 --depth 1 https://sources.le-filament.com/lefilament/lefilament_release_agent.git /opt/odoo/private_addons/lefilament_release_agent &&\ +# chown -R odoo:odoo /opt/odoo + +# Copy entrypoint script and Odoo configuration file +COPY ./entrypoint.sh / +COPY ./odoo.conf /opt/odoo/etc/odoo.conf +RUN chown odoo:odoo /opt/odoo/etc/odoo.conf + +# Mount /opt/odoo/data to allow restoring filestore +VOLUME ["/opt/odoo/data/"] + +# Expose Odoo services +EXPOSE 8069 + +# Set default user when running the container +USER odoo + +# Start +ENTRYPOINT ["/entrypoint.sh"] +CMD ["odoo"] + +# Metadata +LABEL org.label-schema.schema-version="17.0" \ + org.label-schema.vendor=LeFilament \ + org.label-schema.license=Apache-2.0 \ + org.label-schema.vcs-url="https://sources.le-filament.com/lefilament/odoo_docker" -- GitLab