/*
* 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;
}
}