Search in sources :

Example 1 with ApduConnection

use of es.gob.jmulticard.apdu.connection.ApduConnection in project jmulticard by ctt-gob-es.

the class SmartCafeKeyStoreImpl method engineLoad.

/**
 * {@inheritDoc}
 */
@Override
public void engineLoad(final KeyStore.LoadStoreParameter param) throws IOException {
    final ApduConnection conn = new es.gob.jmulticard.jse.smartcardio.SmartcardIoConnection();
    this.cryptoCard = new SmartCafePkcs15Applet(conn, new JseCryptoHelper());
    if (param != null) {
        final ProtectionParameter pp = param.getProtectionParameter();
        if (pp instanceof KeyStore.CallbackHandlerProtection) {
            if (((KeyStore.CallbackHandlerProtection) pp).getCallbackHandler() == null) {
                // $NON-NLS-1$
                throw new IllegalArgumentException("El CallbackHandler no puede ser nulo");
            }
            this.cryptoCard.setCallbackHandler(((KeyStore.CallbackHandlerProtection) pp).getCallbackHandler());
        } else if (pp instanceof KeyStore.PasswordProtection) {
            final PasswordCallback pwc = new CachePasswordCallback(((PasswordProtection) pp).getPassword());
            this.cryptoCard.setPasswordCallback(pwc);
        } else {
            LOGGER.warning(// $NON-NLS-1$ //$NON-NLS-2$
            "Se ha proporcionado un LoadStoreParameter de tipo no soportado, se ignorara: " + (pp != null ? pp.getClass().getName() : "NULO"));
        }
    }
    this.aliases = Arrays.asList(this.cryptoCard.getAliases());
}
Also used : SmartCafePkcs15Applet(es.gob.jmulticard.card.gide.smartcafe.SmartCafePkcs15Applet) PasswordProtection(java.security.KeyStore.PasswordProtection) KeyStore(java.security.KeyStore) PasswordCallback(javax.security.auth.callback.PasswordCallback) JseCryptoHelper(es.gob.jmulticard.JseCryptoHelper) ApduConnection(es.gob.jmulticard.apdu.connection.ApduConnection) PasswordProtection(java.security.KeyStore.PasswordProtection) ProtectionParameter(java.security.KeyStore.ProtectionParameter)

Example 2 with ApduConnection

use of es.gob.jmulticard.apdu.connection.ApduConnection in project jmulticard by ctt-gob-es.

the class TestDnieChangePIN method testChangePIN.

/**
 * Test para probar el cambio de PIN tras la apertura del canal seguro.
 * @throws Exception En cualquier error.
 */
@SuppressWarnings("static-method")
@Test
@Ignore
public void testChangePIN() throws Exception {
    // $NON-NLS-1$
    final CachePasswordCallback cpc = new CachePasswordCallback("password".toCharArray());
    final ApduConnection ac = new SmartcardIoConnection();
    final Dnie dni = DnieFactory.getDnie(ac, cpc, new JseCryptoHelper(), null);
    // $NON-NLS-1$ //$NON-NLS-2$
    dni.changePIN("password", "pinNuevo");
}
Also used : Dnie(es.gob.jmulticard.card.dnie.Dnie) SmartcardIoConnection(es.gob.jmulticard.jse.smartcardio.SmartcardIoConnection) ApduConnection(es.gob.jmulticard.apdu.connection.ApduConnection) Ignore(org.junit.Ignore) Test(org.junit.Test)

Example 3 with ApduConnection

use of es.gob.jmulticard.apdu.connection.ApduConnection in project jmulticard by ctt-gob-es.

the class DnieKeyStoreImpl method engineLoad.

/**
 * {@inheritDoc}
 */
@Override
public void engineLoad(final InputStream stream, final char[] password) throws IOException {
    // Ponemos la conexion por defecto
    final ApduConnection conn;
    try {
        conn = DnieProvider.getDefaultApduConnection() == null ? // $NON-NLS-1$
        (ApduConnection) Class.forName("es.gob.jmulticard.jse.smartcardio.SmartcardIoConnection").getConstructor().newInstance() : DnieProvider.getDefaultApduConnection();
    } catch (final Exception e) {
        // $NON-NLS-1$
        throw new IllegalStateException("No hay una conexion de APDU por defecto: " + e);
    }
    // Aqui se realiza el acceso e inicializacion del DNIe
    this.cryptoCard = DnieFactory.getDnie(conn, password != null ? new CachePasswordCallback(password) : null, new JseCryptoHelper(), null);
    this.aliases = Arrays.asList(this.cryptoCard.getAliases());
}
Also used : JseCryptoHelper(es.gob.jmulticard.JseCryptoHelper) ApduConnection(es.gob.jmulticard.apdu.connection.ApduConnection) AuthenticationModeLockedException(es.gob.jmulticard.card.AuthenticationModeLockedException) CryptoCardException(es.gob.jmulticard.card.CryptoCardException) BadPinException(es.gob.jmulticard.card.BadPinException) ProviderException(java.security.ProviderException) IOException(java.io.IOException) PinException(es.gob.jmulticard.card.PinException)

Example 4 with ApduConnection

use of es.gob.jmulticard.apdu.connection.ApduConnection in project jmulticard by ctt-gob-es.

the class Dnie method openSecureChannelIfNotAlreadyOpened.

/**
 * Establece y abre el canal seguro CWA-14890 si no lo estaba ya hecho.
 * @throws CryptoCardException Si hay problemas en el proceso.
 * @throws PinException Si el PIN usado para la apertura de canal no es válido o no se ha proporcionado
 * 						un PIN para validar.
 */
protected void openSecureChannelIfNotAlreadyOpened() throws CryptoCardException, PinException {
    // Abrimos el canal seguro si no lo esta ya
    if (!isSecurityChannelOpen()) {
        // Aunque el canal seguro estuviese cerrado, podria si estar enganchado
        if (!(getConnection() instanceof Cwa14890Connection)) {
            final ApduConnection secureConnection;
            secureConnection = new Cwa14890OneV1Connection(this, getConnection(), this.cryptoHelper, getCwa14890PublicConstants(), getCwa14890PrivateConstants());
            try {
                setConnection(secureConnection);
            } catch (final ApduConnectionException e) {
                // $NON-NLS-1$
                throw new CryptoCardException("Error en el establecimiento del canal seguro: " + e, e);
            }
        }
        try {
            verifyPin(getInternalPasswordCallback());
        } catch (final ApduConnectionException e) {
            // $NON-NLS-1$
            throw new CryptoCardException("Error en la apertura del canal seguro: " + e, e);
        }
    }
}
Also used : Cwa14890OneV1Connection(es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890OneV1Connection) Cwa14890Connection(es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890Connection) ApduConnection(es.gob.jmulticard.apdu.connection.ApduConnection) CryptoCardException(es.gob.jmulticard.card.CryptoCardException) ApduConnectionException(es.gob.jmulticard.apdu.connection.ApduConnectionException)

Example 5 with ApduConnection

use of es.gob.jmulticard.apdu.connection.ApduConnection in project jmulticard by ctt-gob-es.

the class Dnie3 method openSecureChannelIfNotAlreadyOpened.

/**
 * Si no se había hecho anteriormente, establece y abre el canal seguro de PIN CWA-14890,
 * solicita y comprueba el PIN e inmediatamente después y, si la verificación es correcta,
 * establece el canal de USUARIO CWA-14890.
 * Si falla algún punto del proceso, vuelve al modo inicial de conexión (sin canal seguro).
 * @throws CryptoCardException Si hay problemas en el proceso.
 * @throws PinException Si el PIN usado para la apertura de canal no es válido.
 */
@Override
protected void openSecureChannelIfNotAlreadyOpened() throws CryptoCardException, PinException {
    // Si el canal seguro esta ya abierto salimos sin hacer nada
    if (isSecurityChannelOpen()) {
        return;
    }
    // establecido pero cerrado
    try {
        setConnection(this.rawConnection);
    } catch (final ApduConnectionException e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error en el establecimiento del canal inicial previo al seguro de PIN: " + e, // $NON-NLS-1$
        e);
    }
    // Establecemos el canal PIN y lo verificamos
    final ApduConnection pinSecureConnection = new Cwa14890OneV2Connection(this, getConnection(), getCryptoHelper(), new Dnie3PinCwa14890Constants(), new Dnie3PinCwa14890Constants());
    try {
        selectMasterFile();
    } catch (final Exception e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error seleccionado el MF tras el establecimiento del canal seguro de PIN: " + e, // $NON-NLS-1$
        e);
    }
    try {
        setConnection(pinSecureConnection);
    } catch (final ApduConnectionException e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error en el establecimiento del canal seguro de PIN: " + e, // $NON-NLS-1$
        e);
    }
    // $NON-NLS-1$
    LOGGER.info("Canal seguro de PIN para DNIe establecido");
    try {
        verifyPin(getInternalPasswordCallback());
    } catch (final ApduConnectionException e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error en la verificacion de PIN: " + e, // $NON-NLS-1$
        e);
    }
    // Y establecemos ahora el canal de usuario
    final ApduConnection usrSecureConnection = new Cwa14890OneV2Connection(this, getConnection(), getCryptoHelper(), new Dnie3UsrCwa14890Constants(), new Dnie3UsrCwa14890Constants());
    try {
        selectMasterFile();
    } catch (final Exception e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error seleccionado el MF tras el establecimiento del canal seguro de usuario: " + e, // $NON-NLS-1$
        e);
    }
    try {
        setConnection(usrSecureConnection);
    } catch (final ApduConnectionException e) {
        throw new CryptoCardException(// $NON-NLS-1$
        "Error en el establecimiento del canal seguro de usuario: " + e, // $NON-NLS-1$
        e);
    }
    // $NON-NLS-1$
    LOGGER.info("Canal seguro de Usuario para DNIe establecido");
}
Also used : Cwa14890OneV2Connection(es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890OneV2Connection) CryptoCardException(es.gob.jmulticard.card.CryptoCardException) ApduConnection(es.gob.jmulticard.apdu.connection.ApduConnection) ApduConnectionException(es.gob.jmulticard.apdu.connection.ApduConnectionException) ApduConnectionException(es.gob.jmulticard.apdu.connection.ApduConnectionException) IOException(java.io.IOException) CryptoCardException(es.gob.jmulticard.card.CryptoCardException) PinException(es.gob.jmulticard.card.PinException) Iso7816FourCardException(es.gob.jmulticard.card.iso7816four.Iso7816FourCardException)

Aggregations

ApduConnection (es.gob.jmulticard.apdu.connection.ApduConnection)12 ApduConnectionException (es.gob.jmulticard.apdu.connection.ApduConnectionException)5 CryptoCardException (es.gob.jmulticard.card.CryptoCardException)5 JseCryptoHelper (es.gob.jmulticard.JseCryptoHelper)4 SmartcardIoConnection (es.gob.jmulticard.jse.smartcardio.SmartcardIoConnection)4 IOException (java.io.IOException)4 PinException (es.gob.jmulticard.card.PinException)3 Cwa14890Connection (es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890Connection)2 Cwa14890OneV2Connection (es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890OneV2Connection)2 AuthenticationModeLockedException (es.gob.jmulticard.card.AuthenticationModeLockedException)2 BadPinException (es.gob.jmulticard.card.BadPinException)2 Dnie (es.gob.jmulticard.card.dnie.Dnie)2 SmartCafePkcs15Applet (es.gob.jmulticard.card.gide.smartcafe.SmartCafePkcs15Applet)2 ProviderException (java.security.ProviderException)2 Cwa14890OneV1Connection (es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890OneV1Connection)1 StCard (es.gob.jmulticard.card.bit4id.stcm.StCard)1 CeresSc (es.gob.jmulticard.card.dnie.CeresSc)1 Iso7816FourCardException (es.gob.jmulticard.card.iso7816four.Iso7816FourCardException)1 KeyStore (java.security.KeyStore)1 PasswordProtection (java.security.KeyStore.PasswordProtection)1