Logo

dev-resources.site

for different kinds of informations.

Probando a firmar documentos con Docuten

Published at
12/7/2023
Categories
groovy
docuten
spanish
Author
jagedn
Categories
3 categories in total
groovy
open
docuten
open
spanish
open
Author
6 person written this
jagedn
open
Probando a firmar documentos con Docuten

Recientemente, he empezado a colaborar con la plataforma de Firma y Factura electrónica de Docuten.

Básicamente, es un servicio SAAS para empresas y su función es gestionar todo lo relativo a la firma digital de documentos (contratos, recibos, etc.) así como la factura electrónica.

Una vez que te das de alta en la plataforma, puedes por ejemplo subir documentos para ser firmados por otra persona. Esta persona recibe un correo con un enlace al documento, puede abrirlo y si está de acuerdo puede aceptarlo introduciendo un código OTP que recibe en un segundo correo (existen más métodos de autentificación, pero este es muy simple)

Como todo buen SAAS, tiene un API bastante simple de usar y es el que voy a usar en este post para crear un caso de uso inventado.

WARNING

Actualmente, NO puedes crearte tus propios ApiToken, sino que tienes que pedírselo al admin para que te lo creen. En este post, parto de que ya tienes tu token (y no lo compartes con nadie que no sea de confianza)

Caso de Uso

Queremos crear un documento PDF "al vuelo" y enviárselo al email de alguien para que lo firme.

Queremos que el documento se guarde en la plataforma de Docuten y que podamos consultarlo una vez firmado

WARNING

Como viene siendo habitual en este blog, son solamente ideas para ver cómo integrar las piezas, pocas veces es un caso de uso real.

Para este caso de uso vamos a crear un simple script de Groovy desde el que crearemos y enviaremos el pdf a Docuten.

Parámetros de entrada

email = args[0]
accessToken = args[1]
label = args.length > 2 ? args[2] : "firmar asciidoctor"
url = args.length > 3 ? args[3] : 'https://sandbox.docuten.com'
Enter fullscreen mode Exit fullscreen mode

Vamos a hacer que el script pida para ejecutarse como parámetros:

  • el email de quien debe firmar

  • el token proporcionado por Docuten que nos identifica

  • una etiqueta para el documento

  • la url del entorno (puede ser sandbox para hacer pruebas por ejemplo)

Crear un pdf con Asciidoctor

Crear un pdf a partir de un texto es realmente sencillo con Groovy y las librerías Java de Asciidoctor

@GrabConfig(systemClassLoader = true)
@Grab('org.asciidoctor:asciidoctorj:2.5.7')
@Grab('org.asciidoctor:asciidoctorj-pdf:2.3.9')

import org.asciidoctor.Asciidoctor
import org.asciidoctor.Options
import org.asciidoctor.SafeMode

adoc = """= Titulo

Hola caracola

Hoy es ${new Date()} y `2*2` siguen siendo ${2*2}

"""

try (Asciidoctor asciidoctor = Asciidoctor.Factory.create()) {
    def file = Files.createTempFile("docuten", ".adoc")
    file.text = adoc.toString()

    def pdf = Files.createTempFile("docuten", ".pdf")

    asciidoctor.convertFile(file.toFile(), Options.builder()
            .safe(SafeMode.UNSAFE)
            .toFile(pdf)
            .backend("pdf")
            .build());

    // ...
}
Enter fullscreen mode Exit fullscreen mode

Como es un ejemplo simple, construimos un texto en Asciidoctor de forma dinámica y lo convertimos a PDF generándolo en un fichero temporal.

Enviar a Docuten

Para enviar a Docuten un fichero para firmar simplemente necesitas un Api-Token (que te proporcionan una vez te des de alta en la plataforma) y enviar un payload mediante POST

def payload = [
        "document": [
                "file_name" : pdf.name,
                "title" : label,
                "content" : pdf.bytes.encodeBase64().toString(),
                "description": "Toma toma toma",
                "language" : "ES",
        ],
        "signer" : [
                [
                        "email" : email,
                        "allow_historic" : "true",
                        "mobile" : "",
                        "language" : "ES",
                        "allow_reject" : "true",
                        "signature_type" : "OTP",
                        "allow_download" : "true",
                        "allow_delegate" : "false",
                        "allow_download_signed" : "true",
                        "allow_sign" : "true",
                        "name" : "jorge",
                        "allow_download_evidence": "true",
                        "redirect_url" : ""
                ]
        ],
        "metadata": [[:]],
]

def request = HttpRequest.newBuilder()
        .uri(URI.create("$url/api/v1/documents"))
        .POST(HttpRequest.BodyPublishers.ofString(JsonOutput.toJson(payload)))
        .header('Authorization', "Basic ${accessToken}")
        .header('Content-Type', "application/json")
        .build();

def response = HttpClient.newHttpClient()
        .send(request, HttpResponse.BodyHandlers.ofString())

def json = new JsonSlurper().parseText(response.body())
println json
Enter fullscreen mode Exit fullscreen mode

Como puedes ver, el payload a enviar permite enviar el documento a una lista de personas para que todas firmen el documento y además cada una puede usar un método diferente para firmar.

En este ejemplo solo vamos a enviárselo a un email, que pasaremos por argumento

Ejecución

Así es tan simple como ejecutar

groovy docuten.groovy [email protected] 12345678790abc

y tu cliente recibirá un pdf para ser firmado

Conclusión

En futuros post espero poder investigar un poco más el API para ver cómo completar la integración de sistemas con la plataforma.

Por ejemplo una clinica veterinaria podría enviar los resultados de un análisis al email de un cliente y una vez firmado por este proceder a la intervención.

O un taller mecánico podría enviar la propuesta de un arreglo, etc

groovy Article's
30 articles in total
Favicon
Exploring Groovy: Features and Advantages Over Java
Favicon
Tasting Groogle
Favicon
Machine Learning with Spark and Groovy
Favicon
Groogle 4.0.0 (Google DSL)
Favicon
Tutorial: Learn how to use the H2 Database with Spring Boot! 🤔
Favicon
Mocking with Groovy
Favicon
Check for newer versions of dependencies in pom.xml
Favicon
Setting up linters in Gitlab CI for C++ and Groovy / Jenkins code
Favicon
Machine Learning con Groovy
Favicon
Groovy 🎷 Cheat Sheet - 01 Say "Hello" from Groovy
Favicon
Advice needed
Favicon
HackTheBox - Writeup Builder [Retired]
Favicon
The golden age of Kotlin and its uncertain future
Favicon
Probando a firmar documentos con Docuten
Favicon
Groogle al rescate
Favicon
Tech Watch #3 — October, 20, 2023
Favicon
Swagger-Operator, let groovy operate your cluster
Favicon
Nextflow: Organizando fotos por geoposicion
Favicon
🎶 Groovy: The Dynamic and Versatile JVM Language! 🚀
Favicon
FediSearch
Favicon
Introduction To Jenkins Shared Libraries
Favicon
Remove items matching a pattern from a list in Groovy
Favicon
Processing in parallel with Groovy
Favicon
Wednesday Links - Edition 2023-05-03 🇵🇱📜
Favicon
Wednesday Links - Edition 2023-04-26
Favicon
An Introduction to Jenkins Pipeline: Simplifying Continuous Integration and Delivery with Examples
Favicon
Graalvanizando un script de Groovy
Favicon
Passage of time calculations in Groovy
Favicon
Write a method like Python's string.printable in Groovy
Favicon
Neat time and date manipulation with Groovy

Featured ones: