Annuler une réservation (déclenche la saga + calcule le remboursable)
const url = 'https://example.com/v1/reservations/2489E9AD-2EE2-8E00-8EC9-32D5F69181C0/cancel';const options = { method: 'POST', headers: { 'idempotency-key': 'example', 'X-API-Key': '<X-API-Key>', 'Content-Type': 'application/json' }, body: '{"reason":"guest_request","paymentId":"2489E9AD-2EE2-8E00-8EC9-32D5F69181C0"}'};
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/reservations/2489E9AD-2EE2-8E00-8EC9-32D5F69181C0/cancel \ --header 'Content-Type: application/json' \ --header 'X-API-Key: <X-API-Key>' \ --header 'idempotency-key: example' \ --data '{ "reason": "guest_request", "paymentId": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0" }'Authorizations
Section intitulée « Authorizations »Parameters
Section intitulée « Parameters »Path Parameters
Section intitulée « Path Parameters »Identifiant de la réservation
Header Parameters
Section intitulée « Header Parameters »Clé d’idempotence (8-200 car.) — dédup native via workflowId Temporal. Un re-play avec la même clé retourne le résultat existant sans double-annulation.
Request Body required
Section intitulée « Request Body required »object
Example
guest_requestID du paiement à rembourser (optionnel)
Responses
Section intitulée « Responses »Annulation enregistrée — saga Temporal lancée
object
object
Centimes remboursables (string pour bigint safe)
Frais d’annulation retenus (centimes)
Example
{ "data": { "currency": "EUR" }}Corps invalide ou statut incompatible
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}Annulation refusée (no-show / statut invalide)
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}Config fiscale manquante (FAIL-CLOSED)
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}