first comit
This commit is contained in:
13
.env.example
Normal file
13
.env.example
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
# Domaine PrestaShop (utilise par Fabio pour le routage)
|
||||||
|
PS_DOMAIN=presta.syoul.fr
|
||||||
|
|
||||||
|
# Dossier admin (renommer pour la securite)
|
||||||
|
PS_ADMIN_FOLDER=admin-secure
|
||||||
|
|
||||||
|
# Compte administrateur PrestaShop
|
||||||
|
PRESTASHOP_ADMIN_EMAIL=admin@syoul.fr
|
||||||
|
PRESTASHOP_ADMIN_PASSWORD=changeme_fort
|
||||||
|
|
||||||
|
# Base de donnees
|
||||||
|
DB_ROOT_PASSWORD=changeme_root
|
||||||
|
DB_PASSWORD=changeme_user
|
||||||
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
/docs-syoul
|
||||||
|
/plans
|
||||||
|
.env
|
||||||
76
.woodpecker.yml
Normal file
76
.woodpecker.yml
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
when:
|
||||||
|
branch: main
|
||||||
|
event: push
|
||||||
|
|
||||||
|
steps:
|
||||||
|
|
||||||
|
# Etape 1 : Validation syntaxique du docker-compose.yml
|
||||||
|
validate:
|
||||||
|
image: docker:27-cli
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
environment:
|
||||||
|
PS_DOMAIN: presta.syoul.fr
|
||||||
|
DB_PASSWORD: placeholder
|
||||||
|
DB_ROOT_PASSWORD: placeholder
|
||||||
|
PRESTASHOP_ADMIN_EMAIL: placeholder
|
||||||
|
PRESTASHOP_ADMIN_PASSWORD: placeholder
|
||||||
|
commands:
|
||||||
|
- docker compose config --quiet
|
||||||
|
- echo "docker-compose.yml valide"
|
||||||
|
|
||||||
|
# Etape 2 : Verifications de securite
|
||||||
|
security-check:
|
||||||
|
image: alpine:3.20
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
if [ -f .env ]; then
|
||||||
|
echo "ERREUR: .env ne doit pas etre commite dans le depot !"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
- grep -q "^\.env$" .gitignore || (echo "ERREUR: .env manquant dans .gitignore" && exit 1)
|
||||||
|
- echo "Verifications de securite OK"
|
||||||
|
|
||||||
|
# Etape 3 : Deploiement sur sonic via Docker socket
|
||||||
|
deploy:
|
||||||
|
image: docker:27-cli
|
||||||
|
volumes:
|
||||||
|
# Acces au Docker socket de l'hote (sonic)
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
# Dossier de deploiement sur l'hote (contient le .env)
|
||||||
|
- /opt/prestashop:/opt/prestashop
|
||||||
|
commands:
|
||||||
|
# Copier le docker-compose.yml vers le dossier de deploiement
|
||||||
|
- cp docker-compose.yml /opt/prestashop/docker-compose.yml
|
||||||
|
# Lancer/mettre a jour la stack depuis le dossier de deploiement
|
||||||
|
# (le .env doit deja etre present dans /opt/prestashop/.env sur sonic)
|
||||||
|
- cd /opt/prestashop && docker compose pull
|
||||||
|
- cd /opt/prestashop && docker compose up -d --remove-orphans
|
||||||
|
- cd /opt/prestashop && docker compose ps
|
||||||
|
|
||||||
|
# Etape 4 : Healthcheck post-deploiement
|
||||||
|
healthcheck:
|
||||||
|
image: curlimages/curl:8.11.0
|
||||||
|
environment:
|
||||||
|
PS_DOMAIN:
|
||||||
|
from_secret: PS_DOMAIN
|
||||||
|
commands:
|
||||||
|
- echo "Attente du demarrage de PrestaShop..."
|
||||||
|
- sleep 90
|
||||||
|
- |
|
||||||
|
HTTP_CODE=$(curl -sSo /dev/null -w "%{http_code}" "http://${PS_DOMAIN}" || echo "000")
|
||||||
|
echo "HTTP Status: ${HTTP_CODE}"
|
||||||
|
if [ "${HTTP_CODE}" != "200" ] && [ "${HTTP_CODE}" != "301" ] && [ "${HTTP_CODE}" != "302" ]; then
|
||||||
|
echo "ERREUR: PrestaShop ne repond pas correctement (code ${HTTP_CODE})"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "PrestaShop repond correctement"
|
||||||
|
|
||||||
|
# Notification en cas d'echec
|
||||||
|
notify-failure:
|
||||||
|
image: alpine:3.20
|
||||||
|
commands:
|
||||||
|
- echo "ECHEC pipeline #${CI_BUILD_NUMBER} sur commit ${CI_COMMIT_SHA:0:8}"
|
||||||
|
- echo "Branche: ${CI_COMMIT_BRANCH}"
|
||||||
|
when:
|
||||||
|
status: failure
|
||||||
64
docker-compose.yml
Normal file
64
docker-compose.yml
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
services:
|
||||||
|
prestashop:
|
||||||
|
image: prestashop/prestashop:8-apache
|
||||||
|
container_name: prestashop
|
||||||
|
restart: unless-stopped
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
environment:
|
||||||
|
DB_SERVER: db
|
||||||
|
DB_NAME: prestashop
|
||||||
|
DB_USER: prestashop
|
||||||
|
DB_PASSWD: ${DB_PASSWORD}
|
||||||
|
PS_DOMAIN: ${PS_DOMAIN}
|
||||||
|
PS_FOLDER_ADMIN: ${PS_ADMIN_FOLDER:-admin-secure}
|
||||||
|
ADMIN_MAIL: ${PRESTASHOP_ADMIN_EMAIL}
|
||||||
|
ADMIN_PASSWD: ${PRESTASHOP_ADMIN_PASSWORD}
|
||||||
|
PS_INSTALL_AUTO: "1"
|
||||||
|
PS_ERASE_DB: "0"
|
||||||
|
# SSL desactive cote PrestaShop : Fabio gere le TLS en terminaison
|
||||||
|
# Cela evite les boucles de redirection HTTPS
|
||||||
|
PS_ENABLE_SSL: "0"
|
||||||
|
volumes:
|
||||||
|
- ps_data:/var/www/html
|
||||||
|
labels:
|
||||||
|
# Registrator lit l'IP du conteneur depuis le reseau "sonic" (-useIpFromNetwork sonic)
|
||||||
|
# et enregistre le service dans Consul -> Fabio route presta.syoul.fr vers cette IP
|
||||||
|
SERVICE_NAME: "prestashop"
|
||||||
|
SERVICE_80_NAME: "prestashop"
|
||||||
|
SERVICE_80_TAGS: "urlprefix-${PS_DOMAIN}/"
|
||||||
|
networks:
|
||||||
|
- prestashop-net
|
||||||
|
# Reseau "sonic" requis pour que Registrator trouve l'IP du conteneur
|
||||||
|
- sonic
|
||||||
|
|
||||||
|
db:
|
||||||
|
image: mariadb:10.11
|
||||||
|
container_name: prestashop-db
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
MYSQL_ROOT_PASSWORD: ${DB_ROOT_PASSWORD}
|
||||||
|
MYSQL_DATABASE: prestashop
|
||||||
|
MYSQL_USER: prestashop
|
||||||
|
MYSQL_PASSWORD: ${DB_PASSWORD}
|
||||||
|
volumes:
|
||||||
|
- db_data:/var/lib/mysql
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "healthcheck.sh", "--connect", "--innodb_initialized"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 10
|
||||||
|
networks:
|
||||||
|
- prestashop-net
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
ps_data:
|
||||||
|
db_data:
|
||||||
|
|
||||||
|
networks:
|
||||||
|
prestashop-net:
|
||||||
|
driver: bridge
|
||||||
|
sonic:
|
||||||
|
# Reseau externe existant sur le serveur (partage avec Registrator/Consul/Fabio)
|
||||||
|
external: true
|
||||||
Reference in New Issue
Block a user