Librería open-source para generar registros de facturación Verifactu (huella encadenada, QR y XML) en tu propio software, sin intermediarios.
Project description
Traazza
Verifactu en tu código. No en el servidor de otro.
Librería open-source (MIT) para generar los registros de facturación de Veri*factu —huella encadenada SHA-256, código QR, XML y firma— dentro de tu propio software, sin enviar tus facturas a un tercero ni pagar una cuota por NIF.
Regla de oro. Traazza es una librería/herramienta para desarrolladores, no un SIF que emita facturas reales en tu nombre. Quien la integra es el «productor del SIF» y asume la declaración responsable y el art. 201 bis LGT.
Estado: ALPHA. El núcleo está validado contra material oficial de la AEAT (huella al carácter, XML contra los XSD oficiales), pero el envío en vivo y la firma con certificado cualificado son responsabilidad del integrador. Aún no apta para producción sin ese último tramo.
Instalación
pip install traazza # núcleo, sin dependencias
pip install "traazza[qr]" # + generar imágenes QR (segno)
pip install "traazza[xsd]" # + validar contra los XSD (xmlschema)
pip install "traazza[envio]" # + enviar a la AEAT por SOAP (requests)
pip install "traazza[firma]" # + firma XAdES (signxml)
El núcleo (huella, XML, construcción del QR) no tiene dependencias. Cada capacidad extra vive detrás de un módulo opcional.
En 30 segundos
from traazza.modelos import Emisor, Cadena, SistemaInformatico, LineaDesglose
from traazza import qr, xml, envoltorio
emisor = Emisor("89890001K", "Empresa Ejemplo SL")
sistema = SistemaInformatico(
nombre_razon="Mi Software SL", nif="B00000000", nombre_sif="MiFacturador",
id_sif="01", version="1.0.0", numero_instalacion="INST-001")
cadena = Cadena(emisor)
factura = cadena.alta(
num_serie="2024/A-1", fecha_expedicion="01-01-2024", tipo_factura="F1",
cuota_total="21.00", importe_total="121.00",
fecha_hora_huso="2024-01-01T10:00:00+01:00",
descripcion_operacion="Venta de prueba",
desglose=[LineaDesglose("100.00", "21.00", "21.00")])
print(factura.huella) # huella SHA-256 encadenada
print(qr.url_desde_registro(factura)) # URL del QR tributario
print(xml.registro_alta_xml(factura, sistema))# XML del registro de alta
Cada registro que crea la Cadena incorpora automáticamente la huella del
anterior: así se garantiza la trazabilidad y la inalterabilidad.
Qué sabe hacer
| Módulo | Para qué |
|---|---|
huella |
Huella SHA-256 encadenada, validada al carácter contra los 3 ejemplos oficiales. |
modelos |
Registros de alta y anulación y el encadenado (Cadena). |
qr |
URL del QR tributario (validada contra los ejemplos oficiales) y render SVG/PNG nivel M. |
xml |
XML de alta/anulación conforme al diseño oficial. |
validacion |
Validación contra los XSD oficiales de la AEAT (incluidos en el paquete). |
envoltorio |
RegFactuSistemaFacturacion (Cabecera + registros) para el envío. |
cliente |
Envío SOAP con mTLS a la AEAT (mTLS, reintentos, idempotencia, parseo). |
eventos |
Registro de eventos del sistema, encadenado SHA-256. |
firma |
Firma XAdES (modo NO Veri*factu). |
Código QR
from traazza import qr
url = qr.url_factura(nif="89890001K", numserie="2024/A-1",
fecha="01-01-2024", importe="121.00")
qr.guardar_qr(url, "factura.png") # nivel de corrección M (art. 21)
# Textos oficiales para maquetar la factura:
qr.TEXTO_QR_TRIBUTARIO # "QR tributario:"
qr.FRASE_VERIFACTU_LARGA # "Factura verificable en la sede electrónica de la AEAT"
Validar contra el XSD oficial
from traazza import validacion
esquema = validacion.esquema_registros() # SuministroInformacion.xsd (incluido)
validacion.validar_alta(factura, sistema, esquema) # True o lanza con el detalle
Enviar a la AEAT (modo Veri*factu)
from traazza.cliente import Cliente, Entorno
cli = Cliente(entorno=Entorno.PRUEBAS, cert=("cert.pem", "clave.pem"))
resp = cli.enviar(emisor, [factura], sistema)
print(resp.estado_envio, resp.csv) # "Correcto" + CSV = aceptado
En modo Veri*factu la remisión con certificado cualificado cuenta como firma
básica: no necesitas firmar los registros. La firma XAdES (traazza.firma)
solo es obligatoria en modo NO Veri*factu.
Línea de comandos
# URL del QR (y opcionalmente la imagen)
traazza qr --nif 89890001K --numserie 2024/A-1 --fecha 01-01-2024 --importe 121.00 --salida qr.png
# Huella encadenada de un lote de facturas (JSON)
traazza cadena facturas.json
# XML de los registros / envoltorio completo
traazza xml facturas.json
traazza envoltorio facturas.json
# Validar un XML contra el XSD oficial incluido
traazza validar registro.xml
traazza validar envoltorio.xml --envoltorio
Formato del JSON en traazza --help y en la cabecera de traazza/cli.py.
Filosofía
- Tus datos son tuyos. Traazza corre en tu máquina; tus facturas no pasan por ningún servidor intermedio.
- Núcleo sin dependencias. Lo que exige librerías externas es opcional.
- Validado, no prometido. Lo que decimos que cumple, lo cumple contra el material oficial de la AEAT, y hay tests que lo demuestran.
Licencia
MIT.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file traazza-0.0.2.tar.gz.
File metadata
- Download URL: traazza-0.0.2.tar.gz
- Upload date:
- Size: 47.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
51b944febdcfc9dc9877fd199c76c0c102838a4567a6bed798dcac1940cc0930
|
|
| MD5 |
90fae9d5505fa83ff6e0f650370bc4a4
|
|
| BLAKE2b-256 |
48c94c966d66c3795d159f588eb10f7ff4b37dbe859ff45dc6fddba9e16d6d5c
|
File details
Details for the file traazza-0.0.2-py3-none-any.whl.
File metadata
- Download URL: traazza-0.0.2-py3-none-any.whl
- Upload date:
- Size: 34.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b40528f91938b1879a5361120c6e786677a4b74ea1e2b7a4e37ce22900eea7c
|
|
| MD5 |
b10a3c87991e0f7413ae6ff6884ee124
|
|
| BLAKE2b-256 |
235b411dcab76028f7525028f08197922961b71d939ade5bd102bc5803a53e3b
|