2026-03-22 19:44:44 +01:00
|
|
|
# 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
|
2026-03-22 20:39:39 +01:00
|
|
|
- [ ] Vérifier le type de billet (billet/reservation_brocante/vote) selon l'offre orga à la création
|
2026-03-22 19:44:44 +01:00
|
|
|
|
|
|
|
|
### Invitations Organisateur
|
2026-03-22 19:46:37 +01:00
|
|
|
- [ ] Bloquer l'envoi d'invitations (billets) si Stripe n'est pas validé sur le compte orga
|
2026-03-22 22:49:41 +01:00
|
|
|
- [x] Après inscription via invitation, connecter automatiquement l'utilisateur
|
2026-03-22 22:34:18 +01:00
|
|
|
- [x] Empêcher la double inscription (même email) avec message clair et redirect vers login
|
2026-03-22 22:33:04 +01:00
|
|
|
- [x] Ajouter une notification admin quand un orga accepte/refuse une invitation
|
2026-03-22 19:44:44 +01:00
|
|
|
|
|
|
|
|
### Paiements & Finances
|
2026-03-22 22:23:59 +01:00
|
|
|
- [x] Ajouter le dashboard financier pour l'orga (encaissé, en attente, remboursé, com E-Ticket, com Stripe, net perçu)
|
2026-03-22 22:19:22 +01:00
|
|
|
- [x] Ajouter les virements Stripe (payouts) dans l'onglet de l'orga (déjà en place)
|
Add monthly export CSV + PDF for admin and organizers
- ExportService: monthly stats query, CSV generation, PDF generation via dompdf
- Admin: /admin/export/{year}/{month} (CSV) + /admin/export/{year}/{month}/pdf
- Orga: /mon-compte/export/{year}/{month} (CSV) + /mon-compte/export/{year}/{month}/pdf
- Admin CSV: commande, date, événement, orga, acheteur, billets, total HT, com E-Ticket, com Stripe
- Orga CSV: + net perçu column
- PDF A4 landscape: KPIs + orders table with commissions breakdown
- Buttons in admin dashboard and orga payouts tab (current + previous month)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 22:16:55 +01:00
|
|
|
- [x] Générer un récapitulatif mensuel des ventes (export CSV + PDF, admin et orga)
|
2026-03-22 19:44:44 +01:00
|
|
|
|
|
|
|
|
### Admin
|
2026-03-22 22:09:16 +01:00
|
|
|
- [x] Dashboard admin : stats globales (CA global, commission E-Ticket, commission Stripe, nb commandes, nb billets, nb orgas, revenus net)
|
Add admin orders page with search, status filter, KPIs
- /admin/commandes: paginated list of all orders
- Search by order number, name, email
- Filter by status (pending, paid, cancelled, refunded)
- 4 KPIs: paid count, CA total HT, refunded count, cancelled count
- Table: order number, buyer, event, billets, total, date, status badges
- Navigation link 'Commandes' in admin header
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 21:25:32 +01:00
|
|
|
- [x] Admin : liste de toutes les commandes avec filtres (recherche, statut, KPIs)
|
2026-03-22 20:53:46 +01:00
|
|
|
- [x] Admin : pouvoir suspendre/réactiver un organisateur (badge, bouton toggle, redirect si suspendu, audit log)
|
2026-03-22 20:49:23 +01:00
|
|
|
- [x] Admin : pouvoir modifier l'offre/commission d'un orga existant
|
2026-03-22 22:05:16 +01:00
|
|
|
- [x] Vérifier que les permissions des sous-comptes sont respectées (scanner, events, tickets)
|
Add audit trail: AuditLog entity, AuditService, admin logs page
- AuditLog entity: action, entityType, entityId, data (JSON), performedBy, ipAddress
- AuditService: logs actions with current user and IP
- Audit on: order_created, order_paid, order_cancelled, order_refunded
- Admin /admin/logs: paginated table with action badges, details, user, IP
- Navigation link 'Logs' in admin header
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 20:48:10 +01:00
|
|
|
- [x] Admin : logs des actions importantes (audit trail: commande, paiement, annulation, remboursement)
|
2026-03-22 19:44:44 +01:00
|
|
|
|
|
|
|
|
### UX & Pages
|
Redesign /tarifs page: 3 offers (free/basic 20EUR/mo/custom), commissions table, examples
- Free: 0 EUR, 1 event, billets standards
- Basic: 20 EUR/mois, events illimites, PDF, invitations
- Sur-mesure: sur devis, design personnalise, brocantes, vote
- Commission examples table: 1, 2, 5, 10, 15, 20 EUR
- Stripe fees + E-Ticket fees breakdown
- Includes section with 6 feature cards
- Neo-brutalist design matching the rest of the app
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 20:36:26 +01:00
|
|
|
- [x] Page /tarifs : détailler les 3 offres (free/basic/custom) avec commissions et exemples
|
2026-03-22 20:33:47 +01:00
|
|
|
- [x] Ajouter la recherche d'événements sur la homepage
|
2026-03-22 20:32:51 +01:00
|
|
|
- [x] Ajouter le filtrage par date/ville sur /evenements
|
2026-03-22 20:29:40 +01:00
|
|
|
- [x] Responsive : pages publiques OK à 320px (flex-wrap, overflow-x-auto, breakpoints)
|
2026-03-22 20:24:18 +01:00
|
|
|
- [x] Ajouter les métadonnées OpenGraph sur toutes les pages publiques (og:title, og:description, og:type, og:url, og:image, twitter:card)
|
2026-03-22 19:51:34 +01:00
|
|
|
- [x] Ajouter le sitemap dynamique avec les événements en ligne
|
2026-03-22 20:24:18 +01:00
|
|
|
- [x] Fix breadcrumb JSON-LD URLs (absolute_url)
|
2026-03-22 19:44:44 +01:00
|
|
|
|
2026-03-22 19:48:11 +01:00
|
|
|
### API (Application mobile scanner uniquement)
|
2026-03-22 19:47:43 +01:00
|
|
|
- [ ] POST `/api/login` : authentification email + password orga, retourne un JWT token
|
|
|
|
|
- [ ] GET `/api/events` : liste des événements de l'orga authentifié
|
|
|
|
|
- [ ] POST `/api/events/{id}/scan` : scan d'un billet (decode QR → check reference → check state → mark scanned, gérer sortie définitive)
|
|
|
|
|
- [ ] Middleware JWT pour sécuriser les routes /api/*
|
|
|
|
|
|
2026-03-22 19:44:44 +01:00
|
|
|
### Sécurité & Performance
|
2026-03-22 20:01:01 +01:00
|
|
|
- [x] Rate limiting sur les routes sensibles (login 5/15min, commande 10/5min, invitation 5/15min, contact 3/10min)
|
Add automatic CSRF protection on all POST forms
- CsrfProtectionSubscriber: auto-injects hidden _csrf_token in HTML responses,
auto-verifies on POST requests
- Excludes: webhooks, JSON APIs, login (has its own CSRF)
- 9 tests covering all cases (GET, excluded, JSON, no token, invalid, valid, inject, non-HTML)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 20:08:02 +01:00
|
|
|
- [x] CSRF token sur tous les formulaires POST (auto-inject + auto-verify)
|
2026-03-22 20:09:11 +01:00
|
|
|
- [x] Cache Meilisearch : invalider quand un événement est modifié (déjà fait via EventIndexService::indexEvent)
|
2026-03-22 20:13:31 +01:00
|
|
|
- [x] Optimiser les requêtes N+1 (stats tab, billets par catégorie)
|
2026-03-22 19:44:44 +01:00
|
|
|
|
|
|
|
|
### Tests
|
|
|
|
|
- [ ] Atteindre 90%+ de couverture PHP
|
|
|
|
|
- [ ] Atteindre 100% de couverture JS
|
|
|
|
|
- [ ] Ajouter des tests pour le flow d'inscription via invitation
|
|
|
|
|
|
|
|
|
|
### Infrastructure
|
2026-03-22 19:55:35 +01:00
|
|
|
- [x] Configurer les crons pour les backups automatiques (DB + uploads, toutes les 30 min, rétention 1 jour)
|
|
|
|
|
- [x] Ajouter le monitoring des queues Messenger (commande + cron toutes les heures + email admin)
|