- v1 · actual
- v0 · deprecado
Contrato actual (v1).
order.cancelled lleva el mismo snapshot v1 que order.completed — descuentos de orden/producto, impuestos granulares, enum itemType, deliveryConfirmationCode — más el bloque de auditoría cancellation.order.cancelled dispara cuando se cancela una orden previamente inyectada — desde la UI del backoffice de Fire, un adaptador externo o una llamada a la API de cancelación. No retrae un order.completed previo de la misma orden; ambos eventos se emiten independientes.
Condición de disparo
Fire emiteorder.cancelled una vez cuando el status de una orden transiciona a CANCELLED, sin importar el estado de pago previo. La cancelación se registra con contexto completo de auditoría (quién, cuándo, por qué, fuente).
| Cobertura | Global (todos los países, todos los canales) |
| Llave de idempotencia | event.id |
| Dispara más de una vez | No, salvo en reintentos |
| Orden | No garantizado contra order.completed para la misma orden — ordena por timestamps si necesitas |
| Reintentos | Hasta 5 intentos con backoff exponencial (cuando retryOnFailure está habilitado) |
| Contexto fiscal brasileño | Incluye datos fiscales originales en cancellation.metadata.fiscal si la orden había sido autorizada fiscalmente |
Qué hay en trigger.data
Mismo snapshot V4 que order.completed — todos los campos documentados ahí están presentes acá, con tres diferencias:
statuses"CANCELLED"(no"COMPLETED").paymentStatusqueda igual a cuando la orden se completó (típicamente"SUCCEEDED"si la orden había sido pagada antes de cancelar).- Un bloque top-level nuevo
cancellationlleva la metadata de auditoría.
Ejemplo — payload real de producción (BR, sanitizado)
Referencia de data.cancellation
Bloque de auditoría que describe cómo, cuándo y por quién se canceló la orden.
Lifecycle relativo a otros eventos
Para una orden brasileña fiscal-enabled que se cancela, espera esta secuencia:order.cancelledse emite inmediatamente cuando ocurre la cancelación, antes de contactar cualquier autoridad fiscal externa.order.reversedse emite después — una vez que SEFAZ confirma vía tu proveedor fiscal. Puede llegar segundos o minutos después deorder.cancelled, según el tiempo de respuesta de SEFAZ.- Para órdenes no brasileñas o tiendas sin emisión fiscal, solo dispara
order.cancelled.
Variaciones por país
order.cancelled es global — dispara para todos los países y todos los canales cuando una orden se cancela (Argentina, Brasil, Chile, Colombia, Ecuador, Venezuela y cualquier otro país con Integration Flows activos). El bloque de auditoría de cancelación (cancellation.{cancellationId, cancelledAt, cancelledBy, cancellationReason, cancellationSource}) es idéntico para todos los países.
El único campo específico por país es cancellation.metadata.fiscal, que se popula solo para tiendas brasileñas que tenían un documento fiscal previamente autorizado (es decir, se emitió un order.invoiced para esta orden antes). Para todos los demás países — y para órdenes BR canceladas antes de la autorización fiscal — cancellation.metadata.fiscal es null y no seguirá ningún evento order.reversed.
Para tiendas no-BR (Argentina, Chile, Colombia, Ecuador, Venezuela, otros), el bloque cancellation se ve así:
Cancelación no-BR
data.store sí varían por país — consulta order.completed → Variaciones por país para country.code, currencyCode y storeFiscalConfig.govIdType (CNPJ / CUIT / RUT / NIT / RUC / RIF) por país.
Handler de ejemplo
Errores comunes
status === "CANCELLED", nopaymentStatus. Las órdenes pagadas canceladas mantienenpaymentStatus === "SUCCEEDED"; la cancelación vive en el campostatusmás el bloquecancellation.order.cancelled≠ refund. Fire reporta la cancelación; el refund (si lo hay) lo inicia el canal/procesador y no está en este payload.- No asumas que
order.completedllegó primero. Es posible la entrega fuera de orden — tu handler debería tolerar recibirorder.cancelledpara unorderIdque aún no conoce (p. ej. log + crea un placeholder; reconcilia cuando llegueorder.completed). cancellation.metadata.fiscales el doc original, no el resultado de cancelación. Para la confirmación SEFAZ, escuchaorder.reversed.
Eventos relacionados
order.completed
El evento que verás para la misma orden antes de la cancelación.
order.reversed
Solo Brasil — dispara cuando SEFAZ confirma la cancelación.

