Oberthur_AuthentIC_v3 - xhanulik/OpenSC GitHub Wiki
Oberthur AuthentIC v3
Oberthur's card 'COSMO v7' with PKI applet 'AuthentIC v3.1'
The native Oberthur's support of this card&applet is based on the PKCS#15 specification.
Deviations from PKCS#15 standard
Sign PIN flags
For 'Sign PIN' the !PinAttributes.pinFlags include the integrity-protected
flag.
In reality, for the actually available cards, the ACLs of this PIN do not need SM.
The OpenSC support of this card uses integrity-protected
flag to differentiate 'User PIN' and 'Sign PIN'.
For 'Sign PIN' and 'Sign PUK' the !PinAttributes.pinFlags
include the local
flag .
In fact, for the 'AuthentIC v3' applet all credentials (including PINs) are globals.
In the OpenSC ASN.1 parser this flag is explicitly suppressed for the 'AuthentIC v3' card.
'NONE' security condition
It seems that Oberthur middleware do not accept 'NONE' as security condition in the access rules of the private RSA keys. Actually in the OpenSC card profile all ACLs of the private keys are set to 'CHV1'.
EF(DIR) content
EF(DIR) contains the 'Discretionary ASN.1 data object' (RSA PKCS#15 v1.1 pp 10) with tag '73'. The mandatory OID is absent. Also the 'odfPath' and 'tokenInfoPath' are incomplete - the value of the both is the parent DF and not full path.
'GET CHALLENGE'
For the APDU command 'GET CHALLENGE' number of returned bytes do not depends on Le, it's always 24 bytes.
'Supported algorithms' for public keys
For Oberthur's middleware the 'Supported algorithms' are mandatory in PKCS#15 encoding of the public keys. Oberthur's middleware do not returns the CKA_MODULUS of the private keys. (By the way, it provokes the seg.fault in NSS library - there is an attempt to dereference NULL pointer in the PK11_GetPrivateModulusLen() function).
'External Authentication'
For a moment it's not working.
In any APDU commands context the EXTERNAL AUTHENTICATION
command returns 6985
- GET CHALLENGE is not the previous command
.
Waiting for answer from Oberthur.