42b02a8148
Auto Tag Develop / tag (push) Successful in 9s
## Objectif Remonter les erreurs **backend** Symfony vers **GlitchTip** (SDK Sentry), **prod uniquement**, **inerte sans `SENTRY_DSN`**. Transport réseau via **Tailscale** sur le host de prod (infra, hors repo). Frontend hors périmètre. ## Contenu - `sentry/sentry-symfony:^5.10` (+ `symfony.lock` recipe) - `config/bundles.php` → `SentryBundle ['prod' => true]` - `config/packages/sentry.yaml` (nouveau) : DSN runtime, release `%app.version%`, 4xx ignorés, pas de tracing, handler Monolog ERROR+ - `config/packages/monolog.yaml` : handler `sentry` en `when@prod` - `.env` : bloc `SENTRY_DSN` documenté (vide → inerte) - `doc/error-tracking.md` (runbook Tailscale) + section `CLAUDE.md` - Spec + plan sous `docs/superpowers/` ## Vérifications - Prod `cache:clear` OK, service `Sentry\Monolog\Handler` chargé - **267/267 tests verts**, dev/test inchangés (bundle non chargé hors prod) - Aucun changement `frontend/` / `.gitea/` / `deploy/docker/` - Revue multi-agents : **READY TO MERGE** (aucun Critical/Important) ## Activation prod (hors code, cf. `doc/error-tracking.md`) 1. Tailscale sur l'hôte GlitchTip **et** sur le VPS OVH (prod) 2. Créer le projet `sirh-api` dans GlitchTip → récupérer le DSN 3. `SENTRY_DSN=http://<clé>@<IP-tailnet>:<port>/<id>` dans l'env_file serveur + redéploiement 🤖 Generated with [Claude Code](https://claude.com/claude-code) Reviewed-on: #37 Co-authored-by: matthieu <matthieu@yuno.malio.fr> Co-committed-by: matthieu <matthieu@yuno.malio.fr>
89 lines
3.0 KiB
Docker
89 lines
3.0 KiB
Docker
# --- Stage 1: Build backend ---
|
|
FROM php:8.4-cli AS backend-build
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
libicu-dev libpq-dev libpng-dev libzip-dev libxml2-dev \
|
|
unzip curl git \
|
|
&& docker-php-ext-install -j$(nproc) intl pdo_pgsql zip gd opcache \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY --from=composer:2 /usr/bin/composer /usr/bin/composer
|
|
|
|
WORKDIR /app
|
|
COPY composer.json composer.lock symfony.lock ./
|
|
RUN APP_ENV=prod APP_DEBUG=0 composer install --no-dev --optimize-autoloader --no-scripts --no-interaction
|
|
|
|
COPY bin bin/
|
|
COPY config config/
|
|
COPY migrations migrations/
|
|
COPY public public/
|
|
COPY src src/
|
|
COPY templates templates/
|
|
|
|
# --- Stage 2: Build frontend ---
|
|
FROM node:lts-alpine AS frontend-build
|
|
|
|
WORKDIR /app/frontend
|
|
COPY frontend/package.json frontend/package-lock.json ./
|
|
RUN npm ci
|
|
|
|
COPY frontend/ ./
|
|
ENV CI=1 \
|
|
NUXT_TELEMETRY_DISABLED=1 \
|
|
NUXT_PUBLIC_API_BASE=/api \
|
|
NUXT_PUBLIC_APP_BASE=/
|
|
RUN npm run generate
|
|
|
|
# --- Stage 3: Production image ---
|
|
FROM php:8.4-fpm AS production
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
libicu-dev libpq-dev libpng-dev libzip-dev libxml2-dev \
|
|
nginx supervisor ca-certificates \
|
|
&& docker-php-ext-install -j$(nproc) intl pdo_pgsql zip gd opcache \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# CA racine interne MALIO (auto-signée) — permet au SDK Sentry/HttpClient de joindre
|
|
# GlitchTip en HTTPS sur logs.malio-dev.fr (cert *.malio-dev.fr). Le host est résolu vers
|
|
# l'IP tailnet via `extra_hosts` dans le docker-compose du serveur (cf. doc/error-tracking.md).
|
|
# Sans cette CA approuvée, le SDK logue « Message not sent » et rien ne remonte.
|
|
COPY deploy/docker/malio-dev-root-ca.crt /usr/local/share/ca-certificates/malio-dev-root-ca.crt
|
|
RUN update-ca-certificates
|
|
|
|
# PHP production config
|
|
RUN mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini"
|
|
COPY docker/php/config/php.ini "$PHP_INI_DIR/conf.d/99-app.ini"
|
|
|
|
# PHP-FPM: forward worker output to stderr for docker logs
|
|
RUN echo "catch_workers_output = yes" >> /usr/local/etc/php-fpm.d/www.conf \
|
|
&& echo "decorate_workers_output = no" >> /usr/local/etc/php-fpm.d/www.conf
|
|
|
|
# Nginx: log to stdout/stderr
|
|
RUN ln -sf /dev/stdout /var/log/nginx/access.log \
|
|
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
|
|
|
# Remove default nginx site
|
|
RUN rm -f /etc/nginx/sites-enabled/default
|
|
|
|
# Configs
|
|
COPY deploy/docker/supervisord.conf /etc/supervisor/conf.d/app.conf
|
|
COPY deploy/docker/nginx.conf /etc/nginx/sites-enabled/sirh.conf
|
|
|
|
# Backend from stage 1
|
|
COPY --from=backend-build /app /var/www/html
|
|
|
|
# Frontend from stage 2
|
|
COPY --from=frontend-build /app/frontend/.output/public /var/www/html/frontend/.output/public
|
|
|
|
# Symfony needs a .env file to boot (variables are overridden by env_file in docker-compose)
|
|
RUN echo "APP_ENV=prod" > /var/www/html/.env
|
|
|
|
# Permissions
|
|
RUN mkdir -p /var/www/html/var \
|
|
&& chown -R www-data:www-data /var/www/html/var
|
|
|
|
WORKDIR /var/www/html
|
|
EXPOSE 80
|
|
|
|
CMD ["supervisord", "-n", "-c", "/etc/supervisor/conf.d/app.conf"]
|