Encaisser une caution (en-tête Idempotency-Key obligatoire)
const url = 'https://example.com/v1/deposits';const options = { method: 'POST', headers: { 'Idempotency-Key': 'example', 'X-API-Key': '<X-API-Key>', 'Content-Type': 'application/json' }, body: '{"stayId":"2489E9AD-2EE2-8E00-8EC9-32D5F69181C0","establishmentId":"2489E9AD-2EE2-8E00-8EC9-32D5F69181C0","depositMode":"card_imprint","amount":{"amountCents":"50000","currency":"EUR"},"instrument":"example","paymentMethod":"cash","paymentReference":"example"}'};
try { const response = await fetch(url, options); const data = await response.json(); console.log(data);} catch (error) { console.error(error);}curl --request POST \ --url https://example.com/v1/deposits \ --header 'Content-Type: application/json' \ --header 'Idempotency-Key: example' \ --header 'X-API-Key: <X-API-Key>' \ --data '{ "stayId": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0", "establishmentId": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0", "depositMode": "card_imprint", "amount": { "amountCents": "50000", "currency": "EUR" }, "instrument": "example", "paymentMethod": "cash", "paymentReference": "example" }'Authorizations
Section intitulée « Authorizations »Parameters
Section intitulée « Parameters »Header Parameters
Section intitulée « Header Parameters »Clé d’idempotence OBLIGATOIRE (8–200 car.) — anti-double-encaissement PSP. Retourné 400 si absent ou longueur invalide.
Request Body required
Section intitulée « Request Body required »Caution PSP-agnostique. instrument = token opaque (PCI SAQ A), jamais données carte.
object
object
Montant en centimes (bigint string)
Example
50000Token PSP opaque (hosted-fields) — jamais PAN/CVV
Responses
Section intitulée « Responses »Caution encaissée
object
object
Example generated
{ "data": { "depositId": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0" }}Corps invalide ou montant hors plafond
object
Code machine de l’erreur
Message lisible
Origine domaine de l’erreur (optionnel)
object
Identifiant de corrélation pour le support
Example
{ "code": "RESERVATION_NOT_FOUND", "message": "Réservation introuvable", "status": 404}Non authentifié (Idempotency-Key manquante → 400)
object
Code machine de l’erreur
Message lisible
Origine domaine de l’erreur (optionnel)
object
Identifiant de corrélation pour le support
Example
{ "code": "RESERVATION_NOT_FOUND", "message": "Réservation introuvable", "status": 404}Permission refusée ou IDOR
object
Code machine de l’erreur
Message lisible
Origine domaine de l’erreur (optionnel)
object
Identifiant de corrélation pour le support
Example
{ "code": "RESERVATION_NOT_FOUND", "message": "Réservation introuvable", "status": 404}