Back to 0fee
0fee

La pile middleware : authentification, limitation de débit et idempotence

Comment 0fee.dev gère l'authentification par clé API, la limitation de débit et les clés d'idempotence. Par Juste A. Gnimavo et Claude.

Juste A. Gnimavo (Thales) & Claude | March 27, 2026 4 min 0fee
EN/ FR/ ES
middlewareauthenticationrate-limitingidempotencysecurity

Chaque requête API vers 0fee.dev traverse une pile middleware avant d'atteindre un gestionnaire de route. Cette pile gère trois préoccupations : vérifier que l'appelant est autorisé, s'assurer qu'il ne dépasse pas sa limite de débit et prévenir les paiements en double quand des problèmes réseau provoquent des retentatives. Ce ne sont pas des fonctionnalités optionnelles pour une plateforme de paiement -- ce sont les fondations de la confiance entre la plateforme et ses marchands.

Authentification par clé API

0fee.dev utilise des clés API à préfixe qui encodent les informations d'environnement et de type directement dans la chaîne de la clé :

PréfixeTypeEnvironnementUsage
sk_live_Clé secrèteProductionAppels API côté serveur
sk_sand_Clé secrèteSandboxTests côté serveur
pk_live_Clé publiqueProductionCôté client (widget de checkout)
pk_sand_Clé publiqueSandboxTests côté client

La convention de préfixe a été empruntée à Stripe, et pour une bonne raison : elle permet aux développeurs de distinguer instantanément les types de clés.

Vérification de suspension de facturation

Après l'authentification, le middleware vérifie si le compte du marchand est suspendu pour factures impayées. Le code de statut 402 -- Payment Required -- est rarement utilisé en pratique, mais il est sémantiquement parfait pour ce cas.

Limitation de débit basée sur Redis

La limitation de débit utilise un algorithme de fenêtre glissante implémenté dans DragonflyDB. Chaque clé API obtient un budget de requêtes configurable par fenêtre temporelle.

La décision de conception la plus importante du limiteur de débit est la dégradation gracieuse. Quand DragonflyDB est indisponible, le limiteur de débit laisse passer les requêtes. C'est un compromis délibéré : pour une plateforme de paiement, un limiteur de débit temporairement absent est bien moins nocif que le blocage de requêtes de paiement légitimes.

Gestion des clés d'idempotence

Considérez ce scénario : le serveur d'un marchand envoie une requête de paiement à 0fee.dev. La requête réussit et 5 000 XOF sont débités du compte Orange Money du client. Mais la réponse HTTP est perdue à cause d'un timeout réseau. Le serveur du marchand, ne sachant pas que le paiement a réussi, relance la requête. Sans gestion de l'idempotence, le client est débité deux fois.

Les clés d'idempotence préviennent cela. Le marchand inclut un en-tête Idempotency-Key avec un identifiant unique. Si la même clé est envoyée deux fois, la seconde requête renvoie la réponse mise en cache de la première -- aucun nouveau paiement n'est créé.

La chaîne middleware complète

La requête arrive
    |
    v
[1] Extraire la clé API ou le token de session
    |
    v
[2] Valider les identifiants (consultation BD)
    |
    v
[3] Vérifier la suspension de facturation
    |-- 402 Payment Required ? -> Renvoyer erreur
    |
    v
[4] Vérifier la clé d'idempotence
    |-- Doublon ? -> Renvoyer réponse mise en cache
    |
    v
[5] Vérifier la limite de débit
    |-- Dépassée ? -> Renvoyer 429
    |
    v
[6] Gestionnaire de route (logique métier)
    |
    v
[7] Stocker la réponse d'idempotence
    |
    v
[8] Ajouter les en-têtes de limite de débit à la réponse
    |
    v
Réponse envoyée

Chaque étape peut court-circuiter la chaîne. L'ordonnancement est intentionnel : l'authentification est la moins coûteuse, donc elle vient en premier. La logique métier est la plus coûteuse, donc elle vient en dernier.


Cet article fait partie de la série « Comment nous avons construit 0fee.dev ». 0fee.dev est un orchestrateur de paiement couvrant 53+ fournisseurs dans 200+ pays, construit par Juste A. GNIMAVO et Claude depuis Abidjan sans aucun ingénieur humain. Suivez la série pour l'histoire complète de la construction.

Share this article:

Responses

Write a response
0/2000
Loading responses...

Related Articles

Thales & Claude thales

Treize agents, quarante-trois minutes : la première session Workflow de Claude Fable 5, et ce qu'un script d'orchestration déterministe change aux builds multi-agents

Un prompt, treize agents, quarante-trois minutes : la première session de production avec Claude Fable 5 et l'outil Workflow de Claude Code a livré un site web de production complet de sept pages plus un endpoint backend de capture de leads, en un seul commit. Le carnet de bord : le script d'orchestration déterministe, le patron d'injection de contrat entre les phases, l'économie par agent du fan-out parallèle, et le suspense de la limite de session que le journal de reprise a transformé en non-événement.

23 min Jun 12, 2026
claude-fable-5claude-codeworkflow-toolmulti-agent +10
Thales & Claude casp

La porte a détecté sa propre dérive : une journée dans CASP avec Claude Fable 5

Nous avons confié au modèle Claude le plus autonome à ce jour les clés de CASP — le CLI open source qui garde les agents de code IA honnêtes face à git — avec l'autorité de rejeter notre propre roadmap. Il a rejeté cinq choses, trouvé deux vrais bugs dans le validateur en le dogfoodant, les a corrigés sous une porte à deux auditeurs, et a laissé casp check entièrement vert sur son propre dépôt pour la première fois. CASP 0.3.0 en est le résultat.

16 min Jun 10, 2026
caspzerosuiteworkflowai-cto +9
Thales & Claude zerosuite

La transplantation du CASP : comment la discipline des six fichiers est passée de Conductor à un ERP transport anti-fraude, ce que la compétence /next ajoute quand l'opérateur tape juste « next », et pourquoi le coût d'une dérive du CASP grimpe quand le projet, c'est l'argent des autres

La discipline du CASP qui a piloté trente-cinq sessions de Conductor est agnostique au produit. Le carnet de bord de sa transplantation sur KASSIA, un ERP transport anti-fraude pour un exploitant de flotte en Côte d'Ivoire : ce qui a migré, ce qui n'a pas migré (le validateur sur mesure — et ce que son absence coûte), ce que la compétence /next ajoute quand l'opérateur tape un seul mot, et là où le CASP s'arrête — le bug de déploiement qu'il ne pouvait pas voir parce qu'il enregistre l'intention, pas la réalité de l'infrastructure.

23 min Jun 8, 2026
kassiaerp-kassia-transport-logistiquezerosuiteCASP +15