Justo antes de la línea «#define RESPONSECODE int
#include <pcsclite.h>». El siguiente error es que algunos archivos binarios no se pueden enlazar porque son para 32 bits, pero no para 64.Algo como:
Este error sale porque lo que nos hemos bajado del fabricamente ya trae unos archivos compilados para 32 bits y el Makefile no limpia ese directorio. Es tan sencillo como borrar los que vienen:ld: i386 architecture of input file `openct/checksum.o' is incompatible with i386:x86-64 output ld: i386 architecture of input file `openct/buffer.o' is incompatible with i386:x86-64 output ld: i386 architecture of input file `openct/proto-t1.o' is incompatible with i386:x86-64 output
y luego ejecutar:rm openct/*.o
Una vez tenemos esto compilado para 64 bits, ejecutamos el Makefile:cc -g -Wall -fpic --pedantic -I/usr/include/PCSC -I.\ -c -o openct/checksum.o openct/checksum.c cc -g -Wall -fpic --pedantic -I/usr/include/PCSC -I.\ -c -o openct/buffer.o openct/buffer.c cc -g -Wall -fpic --pedantic -I/usr/include/PCSC -I.\ -c -o openct/proto-t1.o openct/proto-t1.c
Ya tenemos el controlador para 64 bits.make
El acceso al lector de tarjeta se realiza a través de PCSCD, por lo que lo instalamos:
Ahora, se copia el controlador a su directorio correspondiente par que lo encuentre pscscd:apt-get install pcscd
A continuación configuramos «pcscd», que es tan sencillo, siempre que no tengáis otros lectores de tarjetas, como:mkdir -p /usr/local/pcsc/drivers/ltc3x/ sudo cp libltc3x.so /usr/local/pcsc/drivers/ltc3x/
En caso de que tengáis más de un lector, podéis hacerlo concat libltc3x > /etc/reader.conf
cat libltc3x >> /etc/reader.confy editarlo para ver que está todo correcto.
Después editáis la línea «DEVICENAME» de /etc/reader.conf poniendo el puerto serie al que tengáis conectado el lector. Reiniciamos el servidor:
Si todo ha ido bien, debería encenderse un momento una luz roja y luego apagarse todo.sudo /etc/init.d/pcscd restart
Si introduces una tarjeta debería encenderse una luz verde fija.
Podemos probar que lee la tarjeta con la orden «pcsc_scan» y al introducir un DNIe debería salir algo como:
Ale, ya somos capaces de leer el DNIe, ahora vamos a hacer que esto nos sea útil.Reader 0: C3PO LTC3x Serial Smart Card Reader 00 00 Card state: Card inserted, ATR: 3B 7F 38 00 00 00 6A 44 4E 49 65 20 02 4C 34 01 13 03 90 00 ATR: 3B 7F 38 00 00 00 6A 44 4E 49 65 20 02 4C 34 01 13 03 90 00 + TS = 3B --> Direct Convention + T0 = 7F, Y(1): 0111, K: 15 (historical bytes) TA(1) = 38 --> Fi=744, Di=12, 62 cycles/ETU 64516 bits/s at 4 MHz, fMax for Fi = 8 MHz => 129032 bits/s TB(1) = 00 --> VPP is not electrically connected TC(1) = 00 --> Extra guard time: 0 + Historical bytes: 00 6A 44 4E 49 65 20 02 4C 34 01 13 03 90 00 Category indicator byte: 00 (compact TLV data object) Tag: 6, len: A (pre-issuing data) Data: 44 4E 49 65 20 02 4C 34 01 13 Mandatory status indicator (3 last bytes) LCS (life card cycle): 03 (Initialisation state) SW: 9000 (Normal processing.) Possibly identified card (using /usr/share/pcsc/smartcard_list.txt): 3B 7F 38 00 00 00 6A 44 4E 49 65 20 02 4C 34 01 13 03 90 00 3B 7F 38 00 00 00 6A 44 4E 49 65 [1,2]0 02 4C 34 01 13 03 90 00 DNI electronico (Spanish electronic ID card) http://www.dnielectronico.es
Para ello, hay que obtener los paquete del DNIe que tiene publicados la FMNT en: http://www.dnielectronico.es/descargas/PKCS11_para_Sistemas_Unix/opensc_1.4.6_menu64.html Elegís el de Debian (por supuesto :-D): http://www.dnielectronico.es/descargas/PKCS11_para_Sistemas_Unix/1.4.6.Debian_Lenny_64/Debian_Lenny_opensc-dnie_1.4.6-2_amd64.deb.tar Este tar contiene tres paquetes de Debian:
$ tar -xvf Debian_Lenny_opensc-dnie_1.4.6-2_amd64.deb.tar libopensc2_0.11.7-7_amd64.deb opensc-dnie_1.4.6-2_amd64.deb opensc_0.11.7-7_amd64.debA pesar de que el único que no está en Debian oficialmente es opensc-dnie_1.4.6-2_amd64.deb, debéis instalar los tres. Esto es porque cambian configuraciones y no se lo han querido currar hasta ese punto. Incluso hay una dependencia más especificada, pero no da problemas.
Es posible que os salga un warning diciendo que cuidado que estáis desactualizando un paquete, no hay problema, es necesario desactualizarlo por lo anterior.
Al instalar estos paquetes aparecerá un mensaje en que dice que una vez instalado, se vaya al menú de aplicaciones, sección de oficina y se ejecute el icono Registar módulo DNIe PKCS#11
Esto abre una página de Iceweasel y salen varias ventanas, seguid las instrucciones. Una vez hecho esto, reiniciamos Iceweasel.
Si todo ha ido según lo esperado, podremos ir a Iceweasel y en Editar-> Preferencias-> Avanzado -> Cifrado -> Ver certificados. Ahí nos pedirá el PIN del DNIe y entonces debería aparecer nuestro nombre.
Para comprobar que todo va bien y que se puede usar en internet podemos usar una página de verificación que proporciona la casa de la moneda. Haciendo click aquí deberías ver toda tu información e incluso firmar un mensaje, aunque esto a mí no me funciona.
Una nota a la hora que autenticarse en páginas es que cuando te sale la ventana de selección de certificado a usar, a mí me aparece preseleccionado el de firma electrónica, con lo que la autenticación no funciona, hay que seleccionar el otro, el de autenticación.
Una vez hecho esto ya podremos hacer mucho más rápidamente gestiones con los ministerios.
Esta entrada ha sido creada con la inestimable ayuda de Fer.