fix: migrate to woodpecker v3 list syntax, fix env generation
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed

This commit is contained in:
syoul
2026-03-17 13:39:27 +01:00
parent d51d96f04c
commit aeb3f46e2c

View File

@@ -1,11 +1,11 @@
when: when:
branch: main - branch: main
event: push event: push
steps: steps:
# Etape 1 : Validation syntaxique du docker-compose.yml # Etape 1 : Validation syntaxique du docker-compose.yml
validate: - name: validate
image: docker:27-cli image: docker:27-cli
volumes: volumes:
- /var/run/docker.sock:/var/run/docker.sock - /var/run/docker.sock:/var/run/docker.sock
@@ -21,7 +21,7 @@ steps:
- echo "docker-compose.yml valide" - echo "docker-compose.yml valide"
# Etape 2 : Verifications de securite # Etape 2 : Verifications de securite
security-check: - name: security-check
image: alpine:3.20 image: alpine:3.20
commands: commands:
- | - |
@@ -33,7 +33,7 @@ steps:
- echo "Verifications de securite OK" - echo "Verifications de securite OK"
# Etape 3 : Deploiement sur sonic via Docker socket # Etape 3 : Deploiement sur sonic via Docker socket
deploy: - name: deploy
image: docker:27-cli image: docker:27-cli
environment: environment:
PS_DOMAIN: PS_DOMAIN:
@@ -53,16 +53,7 @@ steps:
- /opt/prestashop:/opt/prestashop - /opt/prestashop:/opt/prestashop
commands: commands:
# Generer le .env sur le serveur a partir des secrets Woodpecker # Generer le .env sur le serveur a partir des secrets Woodpecker
# Woodpecker est la source de verite unique pour tous les secrets - printf 'PS_DOMAIN=%s\nPS_ADMIN_FOLDER=%s\nPRESTASHOP_ADMIN_EMAIL=%s\nPRESTASHOP_ADMIN_PASSWORD=%s\nDB_ROOT_PASSWORD=%s\nDB_PASSWORD=%s\n' "${PS_DOMAIN}" "${PS_ADMIN_FOLDER}" "${PRESTASHOP_ADMIN_EMAIL}" "${PRESTASHOP_ADMIN_PASSWORD}" "${DB_ROOT_PASSWORD}" "${DB_PASSWORD}" > /opt/prestashop/.env
- |
cat > /opt/prestashop/.env << EOF
PS_DOMAIN=${PS_DOMAIN}
PS_ADMIN_FOLDER=${PS_ADMIN_FOLDER}
PRESTASHOP_ADMIN_EMAIL=${PRESTASHOP_ADMIN_EMAIL}
PRESTASHOP_ADMIN_PASSWORD=${PRESTASHOP_ADMIN_PASSWORD}
DB_ROOT_PASSWORD=${DB_ROOT_PASSWORD}
DB_PASSWORD=${DB_PASSWORD}
EOF
- chmod 600 /opt/prestashop/.env - chmod 600 /opt/prestashop/.env
# Deployer # Deployer
- cp docker-compose.yml /opt/prestashop/docker-compose.yml - cp docker-compose.yml /opt/prestashop/docker-compose.yml
@@ -71,20 +62,18 @@ steps:
- cd /opt/prestashop && docker compose ps - cd /opt/prestashop && docker compose ps
# Etape 4 : Healthcheck post-deploiement # Etape 4 : Healthcheck post-deploiement
# PS_DOMAIN n'est pas sensible, passe en valeur directe pour eviter - name: healthcheck
# les problemes d'injection de secret dans les blocs multilignes
healthcheck:
image: curlimages/curl:8.11.0 image: curlimages/curl:8.11.0
environment: environment:
PS_DOMAIN: PS_DOMAIN:
from_secret: PS_DOMAIN from_secret: PS_DOMAIN
commands: commands:
- | - |
TARGET="http://${PS_DOMAIN}"
if [ -z "${PS_DOMAIN}" ]; then if [ -z "${PS_DOMAIN}" ]; then
echo "ERREUR: PS_DOMAIN non defini, verifier le secret Woodpecker" echo "ERREUR: PS_DOMAIN non defini, verifier le secret Woodpecker"
exit 1 exit 1
fi fi
TARGET="http://${PS_DOMAIN}"
echo "Healthcheck sur ${TARGET} (max 10 minutes)..." echo "Healthcheck sur ${TARGET} (max 10 minutes)..."
MAX=60 MAX=60
i=0 i=0
@@ -102,10 +91,10 @@ steps:
exit 1 exit 1
# Notification en cas d'echec # Notification en cas d'echec
notify-failure: - name: notify-failure
image: alpine:3.20 image: alpine:3.20
commands: commands:
- 'echo "ECHEC pipeline #${CI_BUILD_NUMBER} sur commit ${CI_COMMIT_SHA}"' - 'echo "ECHEC pipeline #${CI_BUILD_NUMBER} sur commit ${CI_COMMIT_SHA}"'
- 'echo "Branche: ${CI_COMMIT_BRANCH}"' - 'echo "Branche: ${CI_COMMIT_BRANCH}"'
when: when:
status: failure - status: failure