Merge branch 'imp/11.0/docker' into '11.0'

imp/11.0/docker into 11.0

See merge request hibou-io/hibou-odoo/suite!716
This commit is contained in:
Jared Kipe
2020-12-03 23:34:47 +00:00
4 changed files with 94 additions and 3 deletions

View File

@@ -4,6 +4,7 @@ services:
stages:
- build
- release
- trigger
variables:
@@ -15,7 +16,9 @@ variables:
before_script:
- RELEASE=$(echo $CI_COMMIT_REF_NAME | sed "s{.*\/\(.*\)\/.*{\1{g")
- RELEASE_DATE="$(date '+%Y-%m-%d')"
- IMAGE_TAG=$(echo $CI_COMMIT_REF_SLUG | sed "s/^\([[:digit:]][[:digit:]]\)-\([[:digit:]]\)/\1\.\2/g")
- IMAGE_TAG_DATE="${IMAGE_TAG}-${RELEASE_DATE}"
- docker login -u gitlab-ci-token -p $CI_JOB_TOKEN registry.gitlab.com
merge_request:
@@ -23,7 +26,7 @@ merge_request:
GIT_STRATEGY: none
stage: build
only:
- /(^new\/)|(^mig\/)|(^imp\/)|(^fix\/)/
- /(^add\/)|(^new\/)|(^mig\/)|(^imp\/)|(^fix\/)/i
script:
- docker pull registry.gitlab.com/hibou-io/hibou-odoo/flow
- docker tag registry.gitlab.com/hibou-io/hibou-odoo/flow flow
@@ -40,6 +43,20 @@ build:
- docker build --pull -t $CONTAINER_IMAGE:$IMAGE_TAG -f Dockerfile-GitLab .
- docker push $CONTAINER_IMAGE:$IMAGE_TAG
release:
stage: release
variables:
GIT_STRATEGY: none
script:
- apk add python3
- docker pull registry.gitlab.com/hibou-io/hibou-odoo/flow
- docker tag registry.gitlab.com/hibou-io/hibou-odoo/flow flow
- docker run -v "${PWD}/.local:/dest" flow self-install /dest
- cd .local/flow
- ./entrypoint.sh docker-release $CONTAINER_IMAGE:$IMAGE_TAG $CONTAINER_IMAGE:$IMAGE_TAG_DATE
only:
- /^\d+\.\d+$/
publish:
stage: build
script:

View File

@@ -1,6 +1,7 @@
FROM hibou/hibou-odoo:11.0
USER 104
COPY --from=hibou/flow /flow /flow
COPY --chown=104 entrypoint.sh /entrypoint.sh
COPY --chown=104 . /opt/odoo/hibou-suite
RUN rm /etc/odoo/odoo.conf \
&& cp /opt/odoo/hibou-suite/debian/odoo.conf /etc/odoo/odoo.conf \

View File

@@ -1,6 +1,7 @@
FROM registry.gitlab.com/hibou-io/hibou-odoo/odoo:RELEASE
USER 104
COPY --from=registry.gitlab.com/hibou-io/hibou-odoo/flow /flow /flow
COPY --chown=104 entrypoint.sh /entrypoint.sh
COPY --chown=104 . /opt/odoo/hibou-suite
RUN rm /etc/odoo/odoo.conf \
&& cp /opt/odoo/hibou-suite/debian/odoo.conf /etc/odoo/odoo.conf \

72
entrypoint.sh Executable file
View File

@@ -0,0 +1,72 @@
#!/bin/bash
set -e
# set the postgres database host, port, user and password according to the environment
# and pass them as arguments to the odoo process if not present in the config file
: ${HOST:=${DB_PORT_5432_TCP_ADDR:='db'}}
: ${PORT:=${DB_PORT_5432_TCP_PORT:=5432}}
: ${USER:=${DB_ENV_POSTGRES_USER:=${POSTGRES_USER:='odoo'}}}
: ${PASSWORD:=${DB_ENV_POSTGRES_PASSWORD:=${POSTGRES_PASSWORD:='odoo'}}}
DB_ARGS=()
function check_config() {
param="$1"
value="$2"
if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC" ; then
value=$(grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" |cut -d " " -f3|sed 's/["\n\r]//g')
fi;
DB_ARGS+=("--${param}")
DB_ARGS+=("${value}")
}
check_config "db_host" "$HOST"
check_config "db_port" "$PORT"
check_config "db_user" "$USER"
check_config "db_password" "$PASSWORD"
case "$1" in
flow)
shift
wait-for-psql.py ${DB_ARGS[@]} --timeout=60
: ${DB_NAME:='odoo'}
: ${DATA_DIR:='/var/lib/odoo'}
check_config "db_name" "$DB_NAME"
check_config "data_dir" "$DATA_DIR"
cd /flow
FLOW_ARGS=()
CONTINUE="1"
while [[ "$#" && $CONTINUE ]]; do
# We want the -- shifted, but not in the FLOW_ARGS
if [[ "$1" == "--" ]]; then
CONTINUE=""
shift
fi
if [[ "$1" && $CONTINUE ]]; then
FLOW_ARGS+=("$1")
shift
else
# if we shift too many times we exit...
CONTINUE=""
fi
done
/flow/entrypoint.sh ${FLOW_ARGS[@]} ${DB_ARGS[@]}
exec /entrypoint.sh "$@"
;;
-- | odoo)
shift
if [[ "$1" == "scaffold" ]] ; then
exec odoo "$@"
else
wait-for-psql.py ${DB_ARGS[@]} --timeout=30
exec odoo "$@" "${DB_ARGS[@]}"
fi
;;
-*)
wait-for-psql.py ${DB_ARGS[@]} --timeout=30
exec odoo "$@" "${DB_ARGS[@]}"
;;
*)
exec "$@"
esac
exit 1