Add TASK_CHECKUP.md with all pending tasks and improvements

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Serreau Jovann
2026-03-22 19:44:44 +01:00
parent aaad00ede0
commit 048999c26c

63
TASK_CHECKUP.md Normal file
View File

@@ -0,0 +1,63 @@
# Task Checkup - E-Ticket
## A faire
### Billetterie & Commandes
- [ ] Décrémenter la quantité disponible du billet après achat (stock management)
- [ ] Empêcher l'achat si stock épuisé (vérification côté serveur)
- [ ] Ajouter un email de notification à l'orga quand une commande est passée
- [ ] Ajouter un email de notification à l'orga quand une commande est annulée/remboursée
- [ ] Gérer l'expiration des commandes pending (cron pour annuler après X minutes)
- [ ] Ajouter le webhook `payment_intent.payment_failed` pour gérer les échecs
- [ ] Ajouter le webhook `charge.refunded` pour mettre à jour le statut automatiquement
### Billets & Scan
- [ ] Créer le système de scan QR code (app scanner pour les contrôleurs)
- [ ] Route API de validation du billet (decode base64 → check reference → check state → mark scanned)
- [ ] Gérer la sortie définitive (invalider le billet après le premier scan si `hasDefinedExit`)
- [ ] Gérer les re-entrées (billet scanné mais pas `hasDefinedExit` → autoriser)
- [ ] Expirer automatiquement les billets après la date de fin de l'événement (cron)
### Invitations Organisateur
- [ ] Après inscription via invitation, connecter automatiquement l'utilisateur
- [ ] Empêcher la double inscription (même email) — déjà vérifié mais ajouter un message clair
- [ ] Ajouter une notification admin quand un orga accepte/refuse une invitation
### Paiements & Finances
- [ ] Ajouter le dashboard financier pour l'orga (total encaissé, en attente, remboursé)
- [ ] Ajouter les virements Stripe (payouts) dans l'onglet de l'orga
- [ ] Générer un récapitulatif mensuel des ventes (export CSV/PDF)
### Admin
- [ ] Dashboard admin : stats globales (CA total, nb commandes, nb billets, nb orgas)
- [ ] Admin : liste de toutes les commandes avec filtres
- [ ] Admin : pouvoir suspendre un organisateur
- [ ] Admin : pouvoir modifier l'offre/commission d'un orga existant (déjà fait partiellement)
- [ ] Admin : logs des actions importantes (audit trail)
### UX & Pages
- [ ] Page /tarifs : détailler les 3 offres (free/basic/custom) avec les prix
- [ ] Ajouter la recherche d'événements sur la homepage
- [ ] Ajouter le filtrage par date/ville sur /evenements
- [ ] Responsive : vérifier toutes les pages sur mobile 320px
- [ ] Ajouter les métadonnées OpenGraph sur toutes les pages publiques
- [ ] Ajouter le sitemap dynamique avec les événements en ligne
### Sécurité & Performance
- [ ] Rate limiting sur les routes sensibles (login, commande, invitation)
- [ ] CSRF token sur tous les formulaires POST
- [ ] Ajouter un captcha sur le formulaire de contact événement
- [ ] Cache Meilisearch : invalider quand un événement est modifié
- [ ] Optimiser les requêtes N+1 (stats tab, billets par catégorie)
### Tests
- [ ] Atteindre 90%+ de couverture PHP
- [ ] Atteindre 100% de couverture JS
- [ ] Ajouter des tests E2E (Panther ou Playwright) pour le flow d'achat complet
- [ ] Ajouter des tests pour le flow d'inscription via invitation
### Infrastructure
- [ ] Configurer les crons Symfony (expiration commandes, expiration billets)
- [ ] Ajouter le monitoring des queues Messenger (failed messages)
- [ ] Configurer les backups automatiques de la base de données
- [ ] Ajouter le health check endpoint pour le monitoring