mirror of
https://github.com/TanelOrumaa/Estonian-ID-card-mobile-authenticator-POC.git
synced 2024-12-22 20:40:16 +02:00
Add a method for getting the authentication certificate (WIP).
This commit is contained in:
parent
d2ad8920a1
commit
1c8a606376
@ -373,10 +373,45 @@ public class Comms {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte[] getAuthenticationCertificate(String PIN1) throws NoSuchPaddingException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IllegalBlockSizeException, BadPaddingException, InvalidKeyException, IOException {
|
/**
|
||||||
|
* Retrieves the authentication certificate from the chip
|
||||||
|
*
|
||||||
|
* @return authentication certificate
|
||||||
|
*/
|
||||||
|
public byte[] getAuthenticationCertificate() throws NoSuchPaddingException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IllegalBlockSizeException, BadPaddingException, InvalidKeyException, IOException {
|
||||||
|
|
||||||
return new byte[0];
|
selectIASECCApplication();
|
||||||
|
|
||||||
|
byte[] APDU = createSecureAPDU(new byte[]{-83, -15}, selectFile);
|
||||||
|
byte[] response = idCard.transceive(APDU);
|
||||||
|
Log.i("Select AWP Application", Hex.toHexString(response));
|
||||||
|
|
||||||
|
APDU = createSecureAPDU(new byte[]{52, 1}, selectFile);
|
||||||
|
response = idCard.transceive(APDU);
|
||||||
|
Log.i("Select certificate", Hex.toHexString(response));
|
||||||
|
|
||||||
|
byte[] responses = new byte[0];
|
||||||
|
byte[] readCert = Arrays.copyOf(read, read.length);
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
|
||||||
|
readCert[2] = (byte) i;
|
||||||
|
APDU = createSecureAPDU(new byte[0], readCert);
|
||||||
|
response = idCard.transceive(APDU);
|
||||||
|
Log.i("Read certificate", Hex.toHexString(response));
|
||||||
|
|
||||||
|
if (!Hex.toHexString(response).substring(response.length * 2 - 4).equals("6b00")) {
|
||||||
|
byte[] decrypted = encryptDecryptData(Arrays.copyOfRange(response, 4, 244), Cipher.DECRYPT_MODE);
|
||||||
|
responses = Arrays.copyOf(responses, responses.length + decrypted.length);
|
||||||
|
System.arraycopy(decrypted, 0, responses, responses.length - decrypted.length, decrypted.length);
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Log.i("Certificate", new String(responses, StandardCharsets.UTF_8));
|
||||||
|
|
||||||
|
return responses;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user