/* * Controlador Java de la Secretaria de Estado de Administraciones Publicas * para el DNI electronico. * * El Controlador Java para el DNI electronico es un proveedor de seguridad de JCA/JCE * que permite el acceso y uso del DNI electronico en aplicaciones Java de terceros * para la realizacion de procesos de autenticacion, firma electronica y validacion * de firma. Para ello, se implementan las funcionalidades KeyStore y Signature para * el acceso a los certificados y claves del DNI electronico, asi como la realizacion * de operaciones criptograficas de firma con el DNI electronico. El Controlador ha * sido disenado para su funcionamiento independiente del sistema operativo final. * * Copyright (C) 2012 Direccion General de Modernizacion Administrativa, Procedimientos * e Impulso de la Administracion Electronica * * Este programa es software libre y utiliza un licenciamiento dual (LGPL 2.1+ * o EUPL 1.1+), lo cual significa que los usuarios podran elegir bajo cual de las * licencias desean utilizar el codigo fuente. Su eleccion debera reflejarse * en las aplicaciones que integren o distribuyan el Controlador, ya que determinara * su compatibilidad con otros componentes. * * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la * Lesser GNU General Public License publicada por la Free Software Foundation, * tanto en la version 2.1 de la Licencia, o en una version posterior. * * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la * European Union Public License publicada por la Comision Europea, * tanto en la version 1.1 de la Licencia, o en una version posterior. * * Deberia recibir una copia de la GNU Lesser General Public License, si aplica, junto * con este programa. Si no, consultelo en <http://www.gnu.org/licenses/>. * * Deberia recibir una copia de la European Union Public License, si aplica, junto * con este programa. Si no, consultelo en <http://joinup.ec.europa.eu/software/page/eupl>. * * Este programa es distribuido con la esperanza de que sea util, pero * SIN NINGUNA GARANTIA; incluso sin la garantia implicita de comercializacion * o idoneidad para un proposito particular. */ package es.gob.jmulticard.apdu.dnie; import javax.security.auth.callback.PasswordCallback; import es.gob.jmulticard.apdu.CommandApdu; /** APDU ISO 7816-4 de verificación de PIN (CHV, <i>Card Holder Verification</i>). * <b>Importante</b>: La implementación actual solo funciona bajo CWA-14890, para un * funcionamiento con canal no cifrado es necesario sobrecargar <code>getBytes()</code> * @author Tomás García-Merás */ public final class VerifyApduCommand extends CommandApdu { private static final byte INS_VERIFY = (byte) 0x20; private final PasswordCallback pwc; /** Construye una APDU ISO 7816-4 de verificación de PIN (CHV, <i>Card Holder Verification</i>). * @param cla Clase (CLA) de la APDU * @param pinPc Pin de la tarjeta inteligente */ public VerifyApduCommand(final byte cla, final PasswordCallback pinPc) { super( cla, // CLA VerifyApduCommand.INS_VERIFY, // INS (byte)0x00, // P1 (byte)0x00, // P2 new byte[] { (byte) 0x00 }, // Data null // Le ); if (pinPc == null) { throw new IllegalArgumentException( "No se puede verificar el titular con un PasswordCallback nulo" //$NON-NLS-1$ ); } this.pwc = pinPc; } /** {@inheritDoc} */ @Override public byte[] getData() { final char[] p = this.pwc.getPassword(); final byte[] k = new byte[p.length]; for (int i=0; i<k.length;i++) { k[i] = (byte) p[i]; } for (int i=0;i<k.length;i++) { p[i] = '\0'; } return k; } }