Este cliente permite realizar la integración con los servicios web de LibreDTE desde cualquier aplicación, y en cualquier lenguaje, que pueda construir un archivo JSON o bien un XML con los datos del documentos que se desea emitir.
La ejecución del cliente se hará a través de llamadas a los comandos del cliente como si fuera cualquier otro programa de la terminal.
Este código está liberado bajo licencia AGPL.
Al ser un cliente que se ejecuta separado del programa que lo llama, puede ser utilizado tanto desde software libre como software privativo.
Si se desea modificar o distribuir este cliente, se debe hacer bajo los términos de la licencia AGPL.
Para poder ejecutar el cliente es necesario tener instalado Python 3 (versión 3.4 o superior).
La instalación de Python 3 depende del sistema operativo, y en el caso de GNU/Linux es probable que ya venga incluído.
Si utiliza Microsoft Windows deberá descargar e instalar Python 3, marcar la opción "Add Python to PATH".
Para instalar el cliente, se puede clonar directamente el proyecto:
$ git clone https://github.com/LibreDTE/libredte-clienteO puedes descargar el archivo ZIP con el cliente comprimido.
Se recomienda agregar al PATH del sistema operativo la ruta absoluta hacia libredte-cliente ya que en esta carpeta se encuentra el programa "libredte-cliente.py" que es el comando principal que se debe ejecutar.
Si usas Microsoft Windows puedes descargar el instalador del cliente que viene con el cliente de LibreDTE, Python 3.8 y todas las dependencias necesarias.
En GNU/Linux:
$ sudo pip3 install -r requirements.txtEn Microsoft Windows:
> pip.exe install -r requirements.txtEn algunas versiones de Microsoft Windows (al menos 8 y 10) la instalación con PIP falla debido a que no es posible instalar LXML. Para solucionar esto y poder instalar el SDK es necesario instalar LXML de manera manual. Se puede descargar una versión binaria de LXML según la versión de Python que estemos usando.
Supongamos que tenemos Python 3.5 de 32 bits (independientemente que el sistema operativo sea de 64 bits). Debemos descargar el siguiente archivo lxml‑3.6.4‑cp35‑cp35m‑win32.whl y procedemos a instalar con
> pip.exe install lxml-3.6.4-cp35-cp35m-win32.whlSi usas otra versión de Python descarga la LXML que corresponda.
Cuando tengas instalada la LXML procede a instalar el SDK de LibreDTE con PIP.
La forma de ejecución dependerá del sistema operativo, algunos ejemplos son:
GNU/Linux:
$ libredte-cliente.py # si está en el PATH y hay permisos ejecución
$ libredte-cliente/libredte-cliente.py # si no está en el PATH y hay permisos ejecución
$ python libredte-cliente/libredte-cliente.py # si no está en el PATH y no hay permisos de ejecuciónMicrosoft Windows:
> python.exe libredte-cliente/libredte-cliente.pySi todo fue ok en la ejecución del cliente, o sea, se recibió un código 200 desde el servicio web, entonces el retorno del cliente al sistema operativo será 0. En caso de cualquier problema será distinto de 0.
Para poder usar el cliente es necesario contar con el HASH del usuario y que dicho usuario esté autorizado a operar con el contribuyente que se quiere interactuar.
El HASH del usuario se obtiene de la página del perfil del usuario.
Configurar los datos para autenticación en el archivo de configuración config.yml
Se adjunta la documentación y ejemplos de ejecución de los comandos existentes.
Este comando permite generar a partir de los datos en cierto formato, típicamente un archivo JSON o XML, el DTE timbrado y firmado. Dejará 5 archivos en el directorio que se le indique, estos archivos son:
- temporal.json respuesta del servicio web que crea el DTE temporal.
- emitido.json respuesta del servicio web que crea el DTE real (sin el XML) e incluye el
track_idsi el DTE fue enviado al SII. - emitido.csv mismos datos que emitido.json, pero en un archivo plano separado por punto y coma.
- emitido.xml archivo XML del documento real (sólo si se pasó la opción
--getXMLal comando). - emitido.pdf archivo PDF del documento real, con copia cedible por defecto.
Generar DTE a partir de entrada en JSON:
$ libredte-cliente.py dte_generar --json=dte.json --dir=resultadoGenerar DTE a partir de entrada en XML:
$ libredte-cliente.py dte_generar --xml=dte.xml --dir=resultadoGenerar DTE a partir de entrada en XML sin normalizar (el XML trae todos los datos):
$ libredte-cliente.py dte_generar --xml=dte.xml --dir=resultado --normalizar=0Generar DTE a partir de entrada en otros formatos, ejemplo YAML:
$ libredte-cliente.py dte_generar --archivo=dte.yml --formato=YAML --dir=resultadoGenerar DTE a partir de entrada en JSON y enviar automáticamente por correo:
$ libredte-cliente.py dte_generar --hash=1234 --json=dte.json --dir=resultado --emailEs posible especificar la codificación del archivo que se leerá, y que sea transformado automáticamente a UTF-8 por el cliente antes de enviar al servicio web de LibreDTE:
$ libredte-cliente.py dte_generar --json=dte.json --dir=resultado --encoding=ISO-8859-1Se puede cambiar el formato por defecto del PDF que se genera:
$ libredte-cliente.py dte_generar --json=dte.json --dir=resultado --formato_pdf=generalSe pueden pasar datos extras al formato del PDF que se genera cuando el formato de datos no es JSON:
$ libredte-cliente.py dte_generar --json=dte.json --dir=resultado --formato_pdf=general --extra=datos_extra.jsonActualizar el estado de un envío de DTE al SII usando el servicio web del SII:
$ libredte-cliente.py dte_estado --rut=76192083 --dte=33 --folio=1Actualizar el estado de un envío de DTE al SII usando el correo recibido desde el SII:
$ libredte-cliente.py dte_estado --rut=76192083 --dte=33 --folio=1 --metodo=emailDescargar PDF y guardar en directorio donde se está llamando al comando con nombre por defecto:
$ libredte-cliente.py dte_emitido_pdf --rut=76192083 --dte=33 --folio=1Descargar PDF y guardar en una ruta específica con un nombre de PDF personalizado:
$ libredte-cliente.py dte_emitido_pdf --rut=76192083 --dte=33 --folio=1 --pdf=/home/delaf/factura.pdfDescargar PDF en papel contínuo y guardar en una ruta específica con un nombre de PDF personalizado:
$ libredte-cliente.py dte_emitido_pdf --rut=76192083 --dte=33 --folio=1 --pdf=/home/delaf/factura.pdf --papel=80Se puede cambiar el formato por defecto del PDF que se genera:
$ libredte-cliente.py dte_emitido_pdf --rut=76192083 --dte=33 --folio=1 --formato_pdf=generalCrear un PDF localmente a partir del XML de un DTE, por el momento sólo se soportan boletas.
Crear PDF con 1 copia tributaria (por defecto):
$ libredte-cliente.py dte_crear_pdf --xml=documento.xml --pdf=documento.pdfCrear PDF con 2 copias tributarias:
$ libredte-cliente.py dte_crear_pdf --xml=documento.xml --pdf=documento.pdf --copias_tributarias=2Permite imprimir un archivo PDF directamente en la impresora.
En GNU/Linux se deberá instalar el paquete de desarrollo de CUPS y pycups:
# apt-get install libcups2-dev
# pip3 install pycupsEn Microsoft Windows se deberá instalar el paquete pywin32.
Imprimir en la impresora por defecto:
$ libredte-cliente.py imprimir --pdf=factura.pdfImprimir indicando la impresora:
$ libredte-cliente.py imprimir --pdf=factura.pdf --impresora=Brother_DCP-9020CDNEnviar todos los archivos XML de un directorio al servidor de LibreDTE:
$ libredte-cliente.py dte_sincronizar --dir=/ruta/a/xmls -vvPermite generar masivamente los DTE a partir de un archivo CSV.
$ libredte-cliente.py dte_masivos --emisor=76192083-9 --dir=masivos --csv=emision_masiva.csvEl comando creará en el directorio especificado una carpeta por cada DTE a generar, los archivos de la carpeta serán los mismos del comando dte_generar más un archivo solicitud.json que contiene el JSON del DTE creado a partir de los datos del CSV.
El comando permite enviar directamente los DTE por correo, para esto ejecutar el comando así:
$ libredte-cliente.py dte_masivos --emisor=76192083-9 --dir=masivos --csv=emision_masiva.csv --emailEl comando permite generar sólo cotizaciones (documentos temporales) en vez de los reales, para esto ejecutar el comando así:
$ libredte-cliente.py dte_masivos --emisor=76192083-9 --dir=masivos --csv=emision_masiva.csv --cotizacionPermite monitorear un directorio e ir creando automáticamente los DTE a medida que se van dejando los archivos con las solicitudes de DTE (ya sea en JSON, XML, YAML u otro formato soportado).
$ libredte-cliente.py monitor --emisor=76192083-9 --dir_entrada=/home/delaf/entrada --dir_salida=/home/delaf/salidaEl formato por defecto de los archivos debe ser JSON, si se quiere usar otro, por ejemplo XML, ejecutar con el nombre del formato (misma opción que comando dte_generar):
$ libredte-cliente.py monitor --emisor=76192083-9 --formato=xml --dir_entrada=/home/delaf/entrada --dir_salida=/home/delaf/salidaSi el receptor tiene correo asociado se puede enviar automáticamente el DTE por correo, ejecutar así:
$ libredte-cliente.py monitor --emisor=76192083-9 --dir_entrada=/home/delaf/entrada --dir_salida=/home/delaf/salida --emailEs posible enviar a imprimir directamente el PDF a la impresora por defecto del equipo de la siguiente manera:
$ libredte-cliente.py monitor --emisor=76192083-9 --dir_entrada=/home/delaf/entrada --dir_salida=/home/delaf/salida --imprimirEs posible especificar la codificación de los archivos que se leerán en el directorio que se estará monitoreando. Con esto, cada archivo será transformado automáticamente a UTF-8 por el cliente antes de enviar al servicio web de LibreDTE:
$ libredte-cliente.py monitor --emisor=76192083-9 --dir_entrada=/home/delaf/entrada --dir_salida=/home/delaf/salida --encoding=ISO-8859-1El monitor se ejecutará infinitamente y cada 1 segundo revisará el directorio para comprobar si debe generar algún DTE.
Permite crear un servidor de websockets para que la aplicación web de LibreDTE se comunique con el computador local. Esto permite, por ejemplo, imprimir directamente desde la aplicación web un DTE sin tener que bajar o abrir un PDF.
Imprimir en una impresora en red (PDF o usando ESCPOS para impresoras térmicas):
$ libredte-cliente.py websocketd --printer_type=network --printer_uri=172.16.1.5Imprimir en la impresora que el computador tenga configurada por defecto (sólo PDF):
$ libredte-cliente.py websocketd --printer_type=systemImprimir en una impresora específica que el computador tenga configurada (sólo PDF):
$ libredte-cliente.py websocketd --printer_type=system --printer_uri=Brother_HL-2070N_seriesPara la impresión en una impresora del computador se usa el comando imprimir y se deben tener los mismos requerimientos.