Search in sources :

Example 1 with ResponseApdu

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

the class AndroidCCIDConnection method transmit.

/**
 * {@inheritDoc}
 */
@Override
public ResponseApdu transmit(final CommandApdu command) throws ApduConnectionException {
    if (!isOpen()) {
        // $NON-NLS-1$
        throw new UnavailableReaderException("No existe dispositivo USB asignado a la conexion");
    }
    try {
        if (!this.ccidReader.isCardActive()) {
            if (!this.ccidReader.isCardPresent()) {
                // No hay tarjeta en el lector
                throw new CardNotPresentException();
            }
            // Hay tarjeta, pero no esta activa
            // $NON-NLS-1$ //$NON-NLS-2$
            Log.i("es.gob.jmulticard", "La tarjeta del lector no esta activa, se reiniciara");
            this.reset();
        }
        if (DEBUG) {
            // $NON-NLS-1$ //$NON-NLS-2$
            Log.d("es.gob.jmulticard", "APDU Enviada:\n" + HexUtils.hexify(command.getBytes(), true));
        }
        final ResponseApdu response;
        try {
            response = new ResponseApdu(this.ccidReader.transmit(command.getBytes()));
            if (DEBUG) {
                // $NON-NLS-1$ //$NON-NLS-2$
                Log.d("es.gob.jmulticard", "APDU Recibida:\n" + HexUtils.hexify(response.getBytes(), true));
            }
            // Solicitamos el resultado de la operacion si es necesario
            if (response.getStatusWord().getMsb() == TAG_RESPONSE_PENDING) {
                // Si ya se ha devuelto parte de los datos, los concatenamos al resultado
                if (response.getData().length > 0) {
                    final byte[] data = response.getData();
                    final byte[] additionalData = transmit(new GetResponseApduCommand((byte) 0x00, response.getStatusWord().getLsb())).getBytes();
                    final byte[] fullResponse = new byte[data.length + additionalData.length];
                    System.arraycopy(data, 0, fullResponse, 0, data.length);
                    System.arraycopy(additionalData, 0, fullResponse, data.length, additionalData.length);
                    return new ResponseApdu(fullResponse);
                }
                return transmit(new GetResponseApduCommand((byte) 0x00, response.getStatusWord().getLsb()));
            } else // (de eso se encargara la clase de conexion con canal seguro)
            if (response.getStatusWord().getMsb() == TAG_RESPONSE_INVALID_LENGTH && command.getCla() == (byte) 0x00) {
                command.setLe(response.getStatusWord().getLsb());
                return transmit(command);
            }
            return response;
        } catch (final UsbDeviceException e) {
            // $NON-NLS-1$
            throw new ApduConnectionException("Error enviando APDU: " + e, e);
        }
    } catch (final NotAvailableUSBDeviceException e) {
        // $NON-NLS-1$
        throw new UnavailableReaderException("No se puede acceder al dispositivo USB: " + e, e);
    }
}
Also used : UnavailableReaderException(es.gob.jmulticard.apdu.connection.UnavailableReaderException) UsbDeviceException(es.inteco.labs.android.usb.device.exception.UsbDeviceException) ResponseApdu(es.gob.jmulticard.apdu.ResponseApdu) GetResponseApduCommand(es.gob.jmulticard.apdu.iso7816four.GetResponseApduCommand) CardNotPresentException(es.gob.jmulticard.apdu.connection.CardNotPresentException) ApduConnectionException(es.gob.jmulticard.apdu.connection.ApduConnectionException) NotAvailableUSBDeviceException(es.inteco.labs.android.usb.device.exception.NotAvailableUSBDeviceException)

Example 2 with ResponseApdu

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

the class Iso7816EightCard method verifyCertificate.

/**
 * Verifica un certificado en base a una clave pública cargada anteriormente
 * y que deberá ser la del certificado a partir del cual se generó el
 * certificado que ahora se valida.
 * @param cert Certificado que se desea comprobar.
 * @throws SecureChannelException Cuando el certificado no es correcto u ocurre algún error en la validación.
 * @throws ApduConnectionException Cuando ocurre un error en la comunicación con la tarjeta.
 */
public void verifyCertificate(final byte[] cert) throws ApduConnectionException {
    final CommandApdu apdu = new PsoVerifyCertificateApduCommand((byte) 0x00, cert);
    final ResponseApdu res = this.getConnection().transmit(apdu);
    if (!res.isOk()) {
        throw new SecureChannelException(// $NON-NLS-1$
        "Error en la verificacion del certificado. Se obtuvo el error: " + HexUtils.hexify(res.getBytes(), true));
    }
}
Also used : CommandApdu(es.gob.jmulticard.apdu.CommandApdu) SecureChannelException(es.gob.jmulticard.apdu.connection.cwa14890.SecureChannelException) ResponseApdu(es.gob.jmulticard.apdu.ResponseApdu) PsoVerifyCertificateApduCommand(es.gob.jmulticard.apdu.iso7816eight.PsoVerifyCertificateApduCommand)

Example 3 with ResponseApdu

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

the class Iso7816FourCard method readBinary.

/**
 * Lee un contenido binario del fichero actualmente seleccionado.
 * @param msbOffset Octeto más significativo del desplazamiento
 *                  (<i>offset</i>) hasta el punto de inicio de la lectura desde
 *        			el comienzo del fichero.
 * @param lsbOffset Octeto menos significativo del desplazamiento (<i>offset</i>)
 *                  hasta el punto de inicio de la lectura desde el comienzo del
 *                  fichero.
 * @param readLength Longitud de los datos a leer (en octetos).
 * @return APDU de respuesta.
 * @throws ApduConnectionException Si hay problemas en el env&iacute;o de la APDU.
 * @throws RequiredSecurityStateNotSatisfiedException Si la lectura requiere el cumplimiento
 *                        de una condici&oacute;n de seguridad y esta no se ha satisfecho.
 * @throws OffsetOutsideEfException Si el desplazamiento indicado o el tama&ntilde;o indicados
 *                                  para la lectura caen fuera de los l&iacute;mites del fichero.
 */
private ResponseApdu readBinary(final byte msbOffset, final byte lsbOffset, final byte readLength) throws ApduConnectionException, RequiredSecurityStateNotSatisfiedException, OffsetOutsideEfException {
    final CommandApdu apdu = new ReadBinaryApduCommand(getCla(), msbOffset, lsbOffset, readLength);
    final ResponseApdu res = getConnection().transmit(apdu);
    if (res.isOk()) {
        return res;
    }
    if (OFFSET_OUTSIDE_EF.equals(res.getStatusWord())) {
        throw new OffsetOutsideEfException(OFFSET_OUTSIDE_EF, apdu);
    }
    if (UNSATISFIED_SECURITY_STATE.equals(res.getStatusWord())) {
        throw new RequiredSecurityStateNotSatisfiedException(res.getStatusWord());
    }
    if (EOF_REACHED.equals(res.getStatusWord())) {
        // $NON-NLS-1$
        LOGGER.warning("Se ha alcanzado el final de fichero antes de poder leer los octetos indicados");
        return res;
    }
    // $NON-NLS-1$
    throw new ApduConnectionException("Respuesta invalida en la lectura de binario con el codigo: " + res.getStatusWord());
}
Also used : CommandApdu(es.gob.jmulticard.apdu.CommandApdu) ResponseApdu(es.gob.jmulticard.apdu.ResponseApdu) ReadBinaryApduCommand(es.gob.jmulticard.apdu.iso7816four.ReadBinaryApduCommand) ApduConnectionException(es.gob.jmulticard.apdu.connection.ApduConnectionException)

Example 4 with ResponseApdu

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

the class Iso7816FourCard method selectFileById.

/**
 * Selecciona un fichero (DF o EF).
 * @param id Identificador del fichero a seleccionar.
 * @return Tama&ntilde;o del fichero seleccionado.
 * @throws ApduConnectionException Si hay problemas en el env&iacute;o de la APDU.
 * @throws Iso7816FourCardException Si falla la selecci&oacute;n de fichero.
 */
public int selectFileById(final byte[] id) throws ApduConnectionException, Iso7816FourCardException {
    final CommandApdu selectCommand = new SelectFileByIdApduCommand(getCla(), id);
    final ResponseApdu res = getConnection().transmit(selectCommand);
    if (HexUtils.arrayEquals(res.getBytes(), new byte[] { (byte) 0x6a, (byte) 0x82 })) {
        throw new FileNotFoundException(id);
    }
    final SelectFileApduResponse response = new SelectFileApduResponse(res);
    if (response.isOk()) {
        return response.getFileLength();
    }
    final StatusWord sw = response.getStatusWord();
    if (sw.equals(new StatusWord((byte) 0x6A, (byte) 0x82))) {
        throw new FileNotFoundException(id);
    }
    throw new Iso7816FourCardException(sw, selectCommand);
}
Also used : SelectFileByIdApduCommand(es.gob.jmulticard.apdu.iso7816four.SelectFileByIdApduCommand) SelectFileApduResponse(es.gob.jmulticard.apdu.iso7816four.SelectFileApduResponse) CommandApdu(es.gob.jmulticard.apdu.CommandApdu) StatusWord(es.gob.jmulticard.apdu.StatusWord) ResponseApdu(es.gob.jmulticard.apdu.ResponseApdu)

Example 5 with ResponseApdu

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

the class Iso7816FourCard method readAllRecords.

/**
 * Lee todos los registros del binario actualmente seleccionado.
 * @return Lista de registros leidos del binario actualmente seleccionado.
 * @throws ApduConnectionException Si hay problemas en el env&iacute;o de la APDU.
 * @throws Iso7816FourCardException SI ocurren problemas durante la lectura de los registros.
 */
public List<byte[]> readAllRecords() throws ApduConnectionException, Iso7816FourCardException {
    final List<byte[]> ret = new ArrayList<>();
    StatusWord readedResponseSw;
    final CommandApdu readRecordApduCommand = new ReadRecordApduCommand(getCla());
    do {
        final ResponseApdu readedResponse = sendArbitraryApdu(readRecordApduCommand);
        readedResponseSw = readedResponse.getStatusWord();
        if (!readedResponse.isOk() && !ReadRecordApduCommand.RECORD_NOT_FOUND.equals(readedResponseSw)) {
            throw new Iso7816FourCardException(// $NON-NLS-1$
            "Error en la lectura de registro", // $NON-NLS-1$
            readedResponseSw);
        }
        ret.add(readedResponse.getData());
    } while (!ReadRecordApduCommand.RECORD_NOT_FOUND.equals(readedResponseSw));
    return ret;
}
Also used : CommandApdu(es.gob.jmulticard.apdu.CommandApdu) ReadRecordApduCommand(es.gob.jmulticard.apdu.iso7816four.ReadRecordApduCommand) StatusWord(es.gob.jmulticard.apdu.StatusWord) ArrayList(java.util.ArrayList) ResponseApdu(es.gob.jmulticard.apdu.ResponseApdu)

Aggregations

ResponseApdu (es.gob.jmulticard.apdu.ResponseApdu)32 ApduConnectionException (es.gob.jmulticard.apdu.connection.ApduConnectionException)23 CommandApdu (es.gob.jmulticard.apdu.CommandApdu)20 BadPinException (es.gob.jmulticard.card.BadPinException)13 IOException (java.io.IOException)12 PinException (es.gob.jmulticard.card.PinException)10 Iso7816FourCardException (es.gob.jmulticard.card.iso7816four.Iso7816FourCardException)10 AuthenticationModeLockedException (es.gob.jmulticard.card.AuthenticationModeLockedException)7 CryptoCardException (es.gob.jmulticard.card.CryptoCardException)7 CertificateException (java.security.cert.CertificateException)7 SecureChannelException (es.gob.jmulticard.apdu.connection.cwa14890.SecureChannelException)6 StatusWord (es.gob.jmulticard.apdu.StatusWord)5 LostChannelException (es.gob.jmulticard.apdu.connection.LostChannelException)4 TlvException (es.gob.jmulticard.asn1.TlvException)4 InvalidCardException (es.gob.jmulticard.card.InvalidCardException)4 FileNotFoundException (es.gob.jmulticard.card.iso7816four.FileNotFoundException)4 CardNotPresentException (es.gob.jmulticard.apdu.connection.CardNotPresentException)3 Cwa14890Connection (es.gob.jmulticard.apdu.connection.cwa14890.Cwa14890Connection)3 PsoSignHashApduCommand (es.gob.jmulticard.apdu.iso7816eight.PsoSignHashApduCommand)3 GetResponseApduCommand (es.gob.jmulticard.apdu.iso7816four.GetResponseApduCommand)3