# Payout manuel — Procédure pour v0.603 **Contexte** : En v0.602, le payout vendeurs inclut Stripe Connect onboarding et l'affichage de la balance. Le **transfert automatique après vente** est reporté en v0.603 pour éviter la complexité d'injection du StripeConnectService dans le flow marketplace (ProcessWebhook). ## État v0.602 - ✅ Onboarding Stripe Connect (POST /sell/connect/onboard) - ✅ Balance vendeur (GET /sell/balance) - ✅ Carte balance et bouton "Configurer les paiements" dans SellerDashboard - ❌ Transfert automatique après paiement réussi (webhook Hyperswitch) ## Implémentation prévue v0.603 1. **Injection StripeConnectService** dans `marketplace.Service` (optionnel) 2. **ProcessWebhook** : après `status == "succeeded"` et création des licences, pour chaque item : - Récupérer le produit et son `seller_id` - Vérifier si le vendeur a un compte Stripe Connect actif (`PayoutsEnabled`) - Calculer le montant vendeur (total - commission plateforme - frais paiement) - Appeler `stripeConnectService.CreateTransfer(sellerUserID, amount, "eur", orderID)` 3. **Gestion multi-produits** : une commande peut contenir des produits de vendeurs différents → un transfert par vendeur unique 4. **Commission plateforme** : configurable (ex. 10%), à définir dans config ## Procédure manuelle (en attendant v0.603) En production, les vendeurs peuvent : 1. S'onboarder via Stripe Connect (bouton dans SellerDashboard) 2. Consulter leur balance (GET /sell/balance) 3. Les paiements arrivent sur le compte Stripe de la plateforme ; un processus manuel ou cron externe peut initier les transferts vers les comptes Connect des vendeurs ## Références - [Stripe Connect Transfers](https://stripe.com/docs/connect/charges#transfer-availability) - `veza-backend-api/internal/services/stripe_connect_service.go` : `CreateTransfer` - `veza-backend-api/internal/core/marketplace/service.go` : `ProcessWebhook` (L601-637)