print · login   

Learned models

Learned models of bank card protocols

We have learned models for several client implementations, i.e. real bank cards from different banks. Access to the smart cards was realised via a standard smart card reader. The models might be incorrect, but already showed reproducible bugs in some cases.

Benchmark NameModelInputs/OutputsStatesTransitionsPublications
MAESTROdot-file14 / 10684[ARP13]
MAESTRO (ASN)dot-file14 / 10684[ARP13]
MAESTRO (Rabo)dot-file14 / 10684[ARP13]
MAESTRO (Volksbank)dot-file14 / 11798[ARP13]
MasterCarddot-file14 / 9684[ARP13]
MasterCarddot-file15 / 9575[ARP13]
PINdot-file14 / 10684[ARP13]
SecureCodedot-file14 / 9456[ARP13]
SecureCode (ASN)dot-file14 / 9456[ARP13]
SecureCode (Rabo)dot-file15 / 12690[ARP13]
VISAdot-file15 / 119135[ARP13]

Pictures of Learned Models

Some of the learned models listed in the table above are shown below :

Rabo_learnresult_MAESTRO_with_verifyPIN_stripped
Fig. 2: Automaton of Dutch Maestro application. Just to highlight one observation that can be made from this diagram: the VERIFY operation, i.e. the verification of the PIN code by the smartcard, is optional; this makes sense because the terminal may check the PIN code with the bank (so-called online PIN verification), or choose not to verify the PIN at all.
Rabo_learnresult_SecureCode_Aut
Fig. 3: Automaton of Dutch SecureCode Aut application. Note that here the VERIFY operation - i.e. verification of the PIN code - must be passed successfully before cryptograms can be generated, except for the AAC cryptogram to abort the session.
Volksbank_learnresult_MAESTRO
Fig. 4: Automaton of Maestro application on Volksbank bank card.
Barclays_VISA
Fig. 5: Automaton of Visa Debit application on Barclays card. Note that the INTERNAL AUTHENTICATE can be performed at any stage of the protocol.