Facturación asincrónica e individual (encolada)
Utilizá la API de facturación electrónica AFIP de TusFacturas.app, para emitir comprobantes de venta desde tu sistema actual y enviarlo a nuestra cola de procesamiento.
Una vez configurada tu cuenta y creado tu CUIT+PDV, podrás comenzar a emitir facturas electrónicas.
Te sugerimos revisar el apartado de ¿Cómo empiezo? si es la primera vez que utilizas nuestros servicios.
Facturación asincrónica e individual (encolada)
Al utilizar éste servicio, los comprobantes que emitas, quedarán en una cola de procesamiento. A medida que se van procesando, se te enviará un webhook para que puedas obtener la información generada.
Te sugerimos leer primero:
La documentación de "Facturación", para conocer cómo debe componerse el request que envíes
La documentación "Webhooks (notificaciones)" para conocer cómo funciona el servicio de notificaciones.
¿Cómo funciona el modo asincrónico, de facturación individual?
Tu servidor envía el request a TusFacturasAPP y éste queda en cola de procesamiento.
A medida que TF va procesando, te envían un webhook con la respuesta de ese procesamiento (puede ser de éxito o error)
En caso que recibas una respuesta exitosa, deberás consultar el comprobante usando el método de consulta avanzada por external_reference
Datos a tener en cuenta:
La fecha que envíes en el comprobante, determina cuándo será enviado a procesar, por lo que puedes enviar comprobantes a la cola de procesamiento con fecha posterior a hoy. Te sugerimos leer el apartado de "FAQs sobre la cola de procesamiento".
El request, deben venir con el campo número en cero (0).
Debes enviar un "external_reference" de manera obligatoria y debería ser único. TusFacturasAPP no realiza ésta validación, por lo que si envias +1 request con el mismo external_reference, tendrás problemas de tu lado para procesar las respuestas.
Tu CUIT + PDV, debe tener una dirección de webhook definida, de manera obligatoria, ya que sin ella, no se podrán enviar a procesar los requests y serán rechazados de manera instantánea.
No podrás enviar comprobantes de tipo E en ésta modalidad.
Si creas abonos, tené en cuenta que no recibirás un hook por cada vez que el abono se emita, solo con la primera emisión. (funcionalidad en desarrollo)
Al momento del envío del request, la suscripción de tu espacio de trabajo debe encontrarse vigente, activa y con cupo de facturación disponible para emitir el comprobante (aunque no se emita hoy).
Si se detecta al menos un (1) error de validación de datos, no se mandará a procesar y obtendrás la respuesta al instante, no por un webhook.
A donde enviar el request?
Nuevo comprobante de Venta asincrónico e individual (encolado)
POST
https://www.tusfacturas.app/app/api/v2/facturacion/nuevo_encola
Charset: UTF-8
Tipo de dato esperado: JSON
Request Body
¿Que te retornaremos ?
Si el request enviado, posee errores en la validación o formato de los campos enviados, pero cumple con los siguientes requisitos básicos:
Tu CUIT/PDV tiene una dirección de webhook valida
Tu request cuenta con el campo "external_reference"
Recibirás la respuesta al instante y también se te notificará vía webhook.
Ejemplo de un request, cuya external_reference no es válida:
Ejemplo del hook que recibirás:
En cambio, si tu request no cumple con los requisitos básicos previamente mencionados, solo recibirás al instante la respuesta y no se te notificará por webhook (el comprobante no entrará en la cola de procesamiento)
En caso que no se detecten errores tempranos, en la etapa de validación de los datos enviados, obtendrás la siguiente respuesta de manera instantánea y recibirás un webhook para informarte que se ha encolado, como se explica a continuación.
Ejemplo :
Webhooks de respuesta
Existen 3 tipos de eventos posibles para el recurso de facturación que podes recibir en ésta instancia: "encolado", "emitido" y "error".
Te sugerimos conocer más sobre los webhooks, en la documentación de Webhooks (notificaciones).
El hook de "encolado", te informa que el request ha sido aceptado para su procesamiento. Mientras un comprobante se encuentre dentro de la cola de procesamiento, puedes realizar las siguientes operaciones: Cambiar fecha del comprobante o eliminar el comprobante de la cola de procesamiento.
El JSON que recibirás será similar al siguiente ejemplo:
El hook de "emido", te informa que el request ha sido procesado con éxito y se ha emitido el comprobante correctamente. Una vez recibido éste hook, podrás realizar una consulta avanzada por external_reference, para obtener la información de éste comprobante generado.
El JSON que recibirás será similar al siguiente ejemplo:
El hook de "error", te informa que el request ha sido procesado, pero se han detectado errores y no se podrá facturar. Si un comprobante se encuentra procesado con error dentro de la cola de procesamiento, puedes realizar las siguientes operaciones: Cambiar fecha del comprobante, re-enviar el comprobante a la cola de procesamiento o eliminar el comprobante de la cola de procesamiento.
El JSON que recibirás será similar al siguiente ejemplo y a diferencia de los anteriores, obtendrás la lista de errores detectados, dentro del campo "msg".
Última actualización