- v1 · actual
- v0 · deprecado
Contrato actual (v1). El snapshot de orden que se lleva acá sigue el contrato v1 de
order.completed — descuentos de orden/producto, impuestos granulares, enum itemType, deliveryConfirmationCode — más el bloque fiscal de autorización.order.invoiced dispara cuando la autoridad fiscal del país autoriza el documento fiscal asociado a una orden — SEFAZ en Brasil, SRI en Ecuador, DIAN en Colombia, AFIP en Argentina, SII en Chile, SENIAT en Venezuela. Lo emite el pipeline fiscal de Fire, que se integra con tu proveedor fiscal como proveedor de documentos.
Este evento es separado de order.completed: la orden se paga primero (order.completed), después Fire pide la emisión fiscal vía tu proveedor fiscal, y order.invoiced dispara solo cuando la autoridad fiscal devuelve la autorización.
Condición de disparo
Fire emiteorder.invoiced una vez por documento fiscal, la primera vez que todo lo siguiente es verdadero:
- La orden está en una tienda con facturación fiscal habilitada (
storeFiscalConfig.enabled === true) - Se emitió un documento fiscal a tu proveedor fiscal
- tu proveedor fiscal reporta que la autoridad fiscal autorizó el documento (el
statustransiciona aauthorized; en Brasil esto corresponde al códigocStatde autorización SEFAZ)
| Cobertura | Todos los países — Brasil (NFC-e/NF-e vía SEFAZ) y CO/EC/CL/AR/VE vía el callback fiscal genérico. El país viaja en fiscal.countryCode, ya no en el nombre del evento |
| Tipos de documento | Varían por país — nfce/nfe (BR), factura electrónica (CO/EC/CL/AR/VE). Llega en fiscal.docSubtype |
| Llave de idempotencia | event.id |
| Dispara más de una vez | No, salvo en reintentos |
Latencia relativa a order.completed | Usualmente segundos; puede ser minutos si la autoridad fiscal está degradada |
Qué hay en trigger.data
Mismo snapshot V4 que order.completed más un bloque top-level fiscal con las referencias del documento autorizado. Los campos varían por país — abajo se muestra Brasil (chaveAcesso, protocolo); otros países llevan sus identificadores propios (cufe en CO, claveAcceso en EC, cae en AR, etc.). Ver el callback fiscal genérico para el contrato por país.
El status de la orden permanece "COMPLETED" y paymentStatus permanece "SUCCEEDED" — la autorización fiscal no cambia el status de orden.
Ejemplo — payload real de producción (BR, sanitizado)
Referencia de data.fiscal
Referencias del documento autorizado por SEFAZ.
Dónde viven los totales fiscales
Los valores agregados fiscales (vBC, vNF, vICMS, etc.) no están dentro dedata.fiscal — están en data.payments.metadata.fiscal, el mismo lugar donde order.completed los lleva. order.invoiced no los duplica; trata el snapshot de la orden como la única fuente de verdad para los agregados monetarios.
La clasificación por línea (NCM, CFOP, CSOSN, fiscalCategoryCode) vive en data.orderLines[n].metadata.fiscal. Igual que en order.completed.
El bloque data.store.storeFiscalConfig lleva la identidad del emisor (CNPJ, legalName, tradeName) — también igual a order.completed.
Handler de ejemplo
Errores comunes
status === "authorized", no"COMPLETED". Eldata.status(status de la orden) es"COMPLETED"; el status fiscal está endata.fiscal.status.pdfUrlyxmlUrlpueden ser efímeros. En producción, tu proveedor fiscal puede firmar/expirar estos links. Descarga y persiste los artefactos al recibir, en lugar de linkear clientes directamente a tu proveedor fiscal.cStata menudo esnull. No hagas lógica que dependa de él. Usastatus === "authorized"yprotocolocomo señales autoritativas.- No hay evento para
rejected/denied/error. Si SEFAZ rechaza el documento, no dispara evento hoy. El status del documento fiscal se persiste internamente pero no se dispara flow. Vigila esto en el roadmap. - El país ya no vive en el nombre del evento.
order.invoiceddispara para todos los países; usafiscal.countryCodepara filtrar. Los campos del bloquefiscalvarían por país (chaveAcesso/protocolo en BR, cufe en CO, claveAcceso en EC, etc.).
Eventos relacionados
order.completed
Dispara antes de este evento — la orden misma.
order.reversed
Dispara después si el documento se cancela en SEFAZ.

