El Cliente @firma es uno de los productos de la Suite @firma de soluciones de identificación y firma electrónica. Se proporciona de a las Administraciones Públicas para que dispongan de los instrumentos necesarios para implementar la autenticación y firma electrónica avanzada de una forma rápida y efectiva.
El cliente de firma es una herramienta de firma electrónica en entornos de escritorio y dispositivos móviles, que funciona en forma de Applet de Java integrado en una página Web mediante JavaScript, como aplicación de escritorio, o como aplicación móvil, dependiendo del entorno del usuario.
Es software libre con licencia GPL 2+ y EUPL 1.1. Puede consular más información y el código del producto en la forja del CTT.
Los módulos del Cliente @firma se encuentran preparados para su compilación y empaquetado mediante Apache Maven. A continuación se indican los distintos parámetros a utilizar para construir sus artefactos según el uso que se desee dar.
A cualquiera de los comandos que se indican se le puede agregar el parámetro -DskipTests
para omitir los tests JUnit.
Los módulos del Cliente @firma incluidos en este repositorio se pueden construir mediante el siguiente comando de Maven.
mvn clean install
Este comando generará todos los módulos básicos del proyecto.
Para la construcción de AutoFirma (JAR) y los servicios que utiliza será necesario usar el perfil env-install
. Este se puede activar mediante el comando:
mvn clean install -Denv=install
Con esto, se podrán construir los artefactos:
afirma-server-triphase-signer
: WAR con el servicio para la generación de firmas trifásicas.afirma-signature-retriever
: WAR con el servicio de recuperación de datos del servidor intermedio.afirma-signature-storage
: WAR con el servicio de guardado de datos en el servidor intermedio.afirma-simple
: JAR autoejecutable de AutoFirma (AutoFirma.jar
).afirma-ui-simple-configurator
: JAR autoejecutable del configurador necesario para la instalación de AutoFirma (AutoFirmaConfigurador.jar
).
Para el despliegue de los distintos módulos en un repositorio de artefactos, además de la construcción de los los propios artefactos, es necesario aportar el código fuente de la aplicación, su JavaDoc y firmar los distintos artefactos. Para evitar generar estos recursos y realizar la firma de los artefactos para la operativa ordinaria de compilación y empaquetado se ha creado un perfil env-deploy
para que se utilice sólo cuando se va a proceder al despliegue de los artefactos en un repositorio. Se puede hacer eso mediante el comando:
mvn clean deploy -Denv=deploy
El proyecto está formado por múltiples módulos, algunos de los cuales se utilizan en varias de las aplicaciones del Cliente @firma. Otros son los módulos de las propias aplicaciones o con recursos necesarios para su construcción o su uso.
A continuación, se muestra un listado de los distintos módulos actualmente en uso en el proyecto:
afirma-core
: Módulo con los componentes principales del proyecto.afirma-core-keystores
: Módulo con las clases de gestión de almacenes de claves de usuario.afirma-core-massive
: Módulo con funcionalidades para la ejecución de operaciones masivas de firma.afirma-crypto-batch-client
: Módulo con el componente cliente para la invocación de las operaciones de firma de lote en servidor.afirma-crypto-cades
: Módulo con la lógica de generación de las firmas CAdES (excluidas cofirmas y contrafirmas) y ASiC-CAdES.afirma-crypto-cades-multi
: Módulo con la lógica de generación de las cofirmas y contrafirmas CAdES.afirma-crypto-cadestri-client
: Módulo con lógica de invocación para la generación de firmas trifásicas CAdES en servidor.afirma-crypto-cms
: Módulo con la lógica de generación de las firmas CMS.afirma-crypto-core-pkcs7
: Módulo con la lógica básica de estructuras PKCS#7, necesarias para la generación de firmas ASN.1 (CAdES, PAdES, etc.).afirma-crypto-core-xml
: Módulo con la lógica básica de estructuras XML, necesarias para la generación de firmas XML (XAdES, ODF, OOXML, etc.).afirma-crypto-odf
: Módulo con la lógica de generación de las firmas ODF.afirma-crypto-ooxml
: Módulo con la lógica de generación de las firmas OOXML.afirma-crypto-padestri-client
: Módulo con lógica de invocación para la generación de firmas trifásicas PAdES en servidor.afirma-crypto-pdf
: Módulo con la lógica de generación de las firmas PAdES.afirma-crypto-pdf-common
: Módulo con recursos comunes utilizados en los módulos que operan sobre firmas PDF.afirma-crypto-validation
: Módulo con la lógica de verificación de la integridad de las firmas CAdES, PAdES y XAdES (no incluye la comprobación de la validez de los certificados).afirma-crypto-xades
: Módulo con la lógica de generación de las firmas XAdES, ASiC-XAdES y FacturaE.afirma-crypto-xadestri-client
: Módulo con lógica de invocación para la generación de firmas trifásicas XAdES y de FacturaE en servidor.afirma-crypto-xmlsignature
: Módulo con la lógica de generación de las firmas XMLdSig.afirma-keystores-filters
: Módulo con los filtros de certificados utilizados por AutoFirma.afirma-keystores-mozilla
: Módulo para la gestión del almacén de claves de Mozilla Firefox.afirma-server-triphase-signer
: Módulo principal del servicio de firma trifásica y de lotes.afirma-server-triphase-signer-cache
: Módulo con la interfaz que define las operaciones de guardado y recuperación de datos de caché del servidor trifásico.afirma-server-triphase-signer-core
: Módulo con la funcionalidad básica de firma trifásica CAdES, PAdES, XAdES y de FacturaE.afirma-server-triphase-signer-document
: Módulo con la interfaz que define las operaciones de guardado y recuperación de documentos para firmar del servidor trifásico.afirma-signature-retriever
: Módulo principal del servicio de recuperación del servidor intermedio.afirma-signature-storage
: Módulo principal del servicio de guardado del servidor intermedio.afirma-simple
: Módulo principal de la aplicación AutoFirma.afirma-simple-installer
: Módulo con los componentes para la generación de los instaladores de AutoFirma.afirma-simple-plugin-hash
: Módulo con el plugin de AutoFirma para generación y validación de hashes.afirma-simple-plugin-hash-exe
: Módulo de la aplicación EXE para el registro de las entradas de generación y validación de hashes en el menú contextual de Windows.afirma-simple-plugin-validatecerts
: Módulo con el plugin de AutoFirma para validación de firmas.afirma-simple-plugins
: Módulo con los recursos base para la implementación de plugins de AutoFirma.afirma-ui-core-jse
: Módulo con las interfaces gráficas genéricas usadas por las distintas aplicaciones del Cliente @firma.afirma-ui-core-jse-keystores
: Módulo con la interfaz gráfica del diálogo de selección de certificados.afirma-ui-miniapplet-deploy
: Módulo principal para el desarrollo de AutoScript.afirma-ui-simple-configurator
: Módulo principal de la aplicación de configuración ejecutada durante la instalación de AutoFirma.
La lista de módulos obsoletos y/o sin soporte que se conservan en el repositorio son los siguientes:
afirma-crypto-cipher
: Obsoleto. Módulo con las clases para el cifrado sincrono y asíncrono de datos usado en el antiguo Applet de @firma y StandAlone.afirma-crypto-cms-enveloper
: Obsoleto. Módulo con la lógica para la generación de sobre digitales CMS utilizada en los antiguos Applet de @firma y StandAlone.afirma-crypto-core-pkcs7-tsp
: Sin soporte. Módulo con la lógica para agregar sellos de siempre a firmas PKCS#7afirma-crypto-jarverifier
: Obsoleto. Módulo para la comprobación de la integridad de un JAR utilizada en el antiguo Applet de @firma.afirma-crypto-pdf-enhancer
: Obsoleto. Módulo con un cliente SOAP para el envío de peticiones a @firma para la actualización de PDF a formatos longevos.afirma-keystores-capiaddressbook
: Obsoleto. Módulo con la lógica de acceso a la libreta de direcciones de Windows.afirma-keystores-single
: Obsoleto. Módulo con un proveedor criptográfico para la gestión de certificados sueltos como si fuesen almacenes.afirma-miniapplet-report
: Obsoleto. Módulo para la generación de informes de las pruebas del antiguo MiniApplet.afirma-miniapplet-store-testdata
: Obsoleto. Módulo para el guardado de los datos de los informes de las pruebas del antiguo MiniApplet.afirma-report-fail-tests
: Obsoleto. Módulo para la notificación de errores de las pruebas del antiguo MiniApplet.afirma-server-simple-webstart
: Obsoleto. Módulo principal del servicio para la generación del JNLP para la ejecución de AutoFirma WebStart.afirma-standalone
: Obsoleto. Módulo principal de la antigua herramienta de escritorio StandAlone.afirma-standalone-installer
: Obsoleto. Módulo con los componentes para la generación del instalador de la antigua herramienta de escritorio StandAlone.afirma-ui-applet
: Obsoleto. Módulo principal del antiguo Applet de @firma.afirma-ui-applet-deploy
: Obsoleto. Módulo con el JavaScript de despliegue del antiguo Applet de @firma.afirma-ui-miniapplet
: Obsoleto. Módulo principal del antiguo MiniApplet.afirma-ui-simple-webstart
: Obsoleto. Módulo principal del antiguo empaquetado de AutoFirma como aplicación WebStart,afirma-windows-store
: Obsoleto. Módulo principal del antiguo cliente de firma para Windows 8.
No se ofrece ningún tipo de mantenimiento ni soporte sobre estos módulos.