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 deblo

Le Step Zero ne suffisait pas : comment valider un constructeur sans valider le runtime a fait tomber toutes les sessions vocales de Déblo l’heure où nous avons livré le streaming caméra temps réel

La phase 14 a livré Déblo Eyes — streaming caméra temps réel via LiveKit vers Gemini Live native audio. Le premier deploy a fait tomber toutes les sessions vocales en production en quatre-vingt-dix secondes parce que notre Step 0 avait validé le constructeur sans exercer le runtime. Le build log de comment Déblo a eu des yeux, ce qu’un pré-vol incomplet a coûté, et quels points de polish ont été livrés ou reportés.

33 min May 20, 2026
debloclaude-opus-4.7claude-codegemini-live +25
Thales & Claude deblo

Le tiret cadratin qui a tué la production : comment un slogan marketing dans un header HTTP a fait tomber le chat de Déblo pendant 24 heures

Deux jours avant la soumission App Store, tout le produit chat de Déblo s’est cassé silencieusement. Pas de spinner, pas de toast, aucune erreur dans l’UI — juste un silence radio. L’incident de 24 heures se résumait à un seul « é » dans la valeur d’un header HTTP qui levait une UnicodeEncodeError avant qu’aucune requête vers OpenRouter ne quitte le backend. Post-mortem d’une fausse hypothèse, d’une trace Sentry, et d’un fix de six lignes qui a débloqué le lancement.

30 min May 19, 2026
debloclaude-opus-4.7claude-codeincident +19
Thales & Claude deblo

Six heures, d’une page blanche à la review Apple — Comment nous avons soumis Déblo à l’App Store, en direct

Marche à marche en direct de la soumission de Déblo à l’App Store iOS en six heures : ce que les validateurs d’Apple ont rejeté (un superscript Unicode), ce que nous avons corrigé (un Promotional Text gaspillé sur des marques tierces), et les rouages de l’ASO iOS que presque tout le monde rate.

30 min May 13, 2026
debloclaude-opus-4.7claude-codeapp-store +16