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>
45 lines
1.5 KiB
YAML
45 lines
1.5 KiB
YAML
monolog:
|
|
channels: [deprecation, cron]
|
|
|
|
when@dev:
|
|
monolog:
|
|
handlers:
|
|
cron:
|
|
type: stream
|
|
path: "%kernel.logs_dir%/cron.log"
|
|
level: info
|
|
channels: [cron]
|
|
main:
|
|
type: stream
|
|
path: "%kernel.logs_dir%/%kernel.environment%.log"
|
|
level: debug
|
|
channels: ["!event", "!cron"]
|
|
console:
|
|
type: console
|
|
process_psr_3_messages: false
|
|
channels: ["!event", "!doctrine", "!console"]
|
|
|
|
when@prod:
|
|
monolog:
|
|
handlers:
|
|
cron:
|
|
type: stream
|
|
path: "%kernel.logs_dir%/cron.log"
|
|
level: info
|
|
channels: [cron]
|
|
main:
|
|
type: stream
|
|
path: "%kernel.logs_dir%/%kernel.environment%.log"
|
|
level: debug
|
|
channels: ["!deprecation", "!cron"]
|
|
deprecation:
|
|
type: stream
|
|
channels: [deprecation]
|
|
path: "%kernel.logs_dir%/deprecations.log"
|
|
# Remonte les logs ERROR+ vers GlitchTip en tant qu'Issues (service défini
|
|
# dans sentry.yaml). Envoi immédiat, indépendamment des handlers fichier.
|
|
sentry:
|
|
type: service
|
|
id: Sentry\Monolog\Handler
|
|
channels: ["!event", "!doctrine", "!deprecation", "!cron"]
|