status-keycard/SECURE_CHANNEL.MD

168 lines
8.9 KiB
Plaintext
Raw Normal View History

2017-09-22 10:37:24 +03:00
# Secure Channel
## Overview
2017-11-14 15:50:07 +03:00
A Secure Channel must be established to allow communication between the applet and the client. This secure channel has
the concept of pairing with multiple devices (how many clients can be paired at the same time is defined by the applet).
2017-11-20 17:42:12 +03:00
The SecureChannel guarantees protection from snooping, MITM, replay attacks and provides message integrity and
authentication for each APDU.
2017-09-22 10:37:24 +03:00
2017-11-14 15:50:07 +03:00
A short description of establishing a session is as follows
2017-09-22 10:37:24 +03:00
1. The client selects the application on card. The application responds with a public EC key.
2018-10-10 10:39:51 +02:00
2. The client sends an OPEN SECURE CHANNEL command with its public key and pairing index. The EC-DH algorithm is used by
both parties to generate a shared 256-bit secret (more details below).
3. The generated secret is concatenated with the pairing key and random data and hashed with SHA-512.
4. The first half of the generated value is used as an AES key to encrypt all further communication. CBC mode is used
with a random IV generated for each APDU and prepended to the APDU payload. The second half is used to MAC generation
and verification. Both command and responses are encrypted.
5. The client sends a MUTUALLY AUTHENTICATE command to verify that the keys are matching and thus the secure channel is
2017-11-17 16:12:28 +03:00
successfully established.
2017-09-22 10:37:24 +03:00
The EC keyset used by the card for the EC-DH algorithm is generated on-card on applet installation and is not used
for anything else. The EC keyset used by the client is generated every time a new secure channel session must be
opened.
## APDU format
### OPEN SECURE CHANNEL
* CLA = 0x80
* INS = 0x10
2017-11-14 18:04:22 +03:00
* P1 = the pairing index
2017-09-22 10:37:24 +03:00
* P2 = 0x00
* Data = An EC-256 public key on the SECP256k1 curve encoded as an uncompressed point.
2017-11-20 17:42:12 +03:00
* Response Data = A 256-bit salt and a 128-bit seed IV
2017-11-17 17:27:58 +03:00
* Response SW = 0x9000 on success, 0x6A86 if P1 is invalid, 0x6A80 if the data is not a public key
2017-09-22 10:37:24 +03:00
2017-11-20 17:42:12 +03:00
This APDU is the first step to establish a Secure Channel session. A session is aborted when the application is
deselected, either directly or because of a card reset/tear.
2017-11-14 15:50:07 +03:00
2017-09-22 10:37:24 +03:00
The card generates a random 256-bit salt which is sent to the client. Both the client and the card do the following
for key derivation
2017-11-14 15:50:07 +03:00
1. Use their private key and the counterpart public key to generate a secret using the EC-DH algorithm.
2017-11-20 17:42:12 +03:00
2. The generated secret, the pairing key and the salt are concatenated and the SHA-512 of the concatenated value is
2017-11-14 15:50:07 +03:00
calculated.
2017-11-20 17:42:12 +03:00
3. The output of the SHA-512 algorithm is split in two parts of 256-bit. The first part is used as the encryption key
and the second part is used as the MAC key for further communication.
The seed IV is used by the client as the IV for the next encrypted APDU.
2017-09-22 10:37:24 +03:00
2017-11-17 16:12:28 +03:00
### MUTUALLY AUTHENTICATE
* CLA = 0x80
* INS = 0x11
* P1 = 0x00
* P2 = 0x00
2017-11-20 17:42:12 +03:00
* Data = 256-bit random number
* Response Data = 256-bit random number
2017-11-17 16:12:28 +03:00
* Response SW = 0x9000 on success, 0x6985 if the previous successfully executed APDU was not OPEN SECURE CHANNEL, 0x6982
2017-11-21 15:46:21 +03:00
if authentication failed or the data is not 256-bit long
2017-11-17 16:12:28 +03:00
This APDU allows both parties to verify that the keys generated in the OPEN SECURE CHANNEL step are matching and thus
2017-11-20 17:42:12 +03:00
guarantee authentication of the counterpart. The data sent by both parties is a 256-bit random number The APDU data is
sent encrypted with the keys generated in the OPEN SECURE CHANNEL step. Each party must verify the MAC of the received
APDU. If the MAC can be verified, it means that both parties are using the same keys. Only after this step has been
executed the secure channel can be considered to be open and other commands can be sent. If the authentication fails
2017-11-21 15:46:21 +03:00
the card must respond with 0x6982. In this case the OPEN SECURE CHANNEL command must be repeated to generate new keys.
2017-11-14 15:50:07 +03:00
### PAIR
* CLA = 0x80
2017-11-17 16:12:28 +03:00
* INS = 0x12
2017-11-14 15:50:07 +03:00
* P1 = pairing phase
* P2 = 0x00
* Data = see below
* Response Data = see below
2017-11-20 12:44:37 +03:00
* Response SW = 0x9000 on success, 0x6A80 if the data is in the wrong format, 0x6982 if client cryptogram verification
2017-11-14 18:04:22 +03:00
fails, 0x6A84 if all available pairing slot are taken, 0x6A86 if P1 is invalid or is 0x01 but the first phase was not
2017-11-20 12:44:37 +03:00
completed, 0x6985 if a secure channel is open
2017-11-14 15:50:07 +03:00
P1:
* 0x00: First step
* 0x01: Final step
Data:
* On first step: a 256-bit random client challenge
* On second step: the client cryptogram as SHA-256(shared secret, card challenge)
Response Data:
* On first step: the card cryptogram as SHA-256(shared secret, client challenge) followed by a 256-bit card challenge
* On second step: the pairing index followed by a 256-bit salt
This APDU is sent to pair a client. Pairing is performed with two commands which must be sent immediately one after the
other.
In the first phase the client sends a random challenge to the card. The card replies with the SHA-256 hash of the
challenge and the shared secret followed by its random challenge. The client is thus able to authenticate the card by
2017-11-20 12:44:37 +03:00
verifying the card cryptogram (since the client can generate the same and verify that it matches).
2017-11-14 15:50:07 +03:00
In the second phase the client sends the client cryptogram which is the SHA-256 hash of the shared secret and the card
challenge. The card verifies the cryptogram and thus authenticates the client. On success the card generates a random
256-bit salt which is appended to the shared secret. The SHA-256 hash of the concatenated value is stored in the fist
available pairing slot and will be further used to derive session keys. The card responds with the pairing index (which
the client must send in all OPEN SECURE CHANNEL commands) and the salt used to generate the key, so that the client can
generate and store the same key.
2017-11-14 18:04:22 +03:00
The shared secret is a 256-bit value which must be be known to both parts being paired. The exact means of how this
happens depend on the specific applet.
2017-11-14 15:50:07 +03:00
### UNPAIR
* CLA = 0x80
2017-11-17 16:12:28 +03:00
* INS = 0x13
2017-11-14 15:50:07 +03:00
* P1 = the index to unpair
* P2 = 0x00
2017-11-14 18:04:22 +03:00
* Response SW = 0x9000 on success, 0x6985 if security conditions are not met, 0x6A86 if the index is higher than the
highest possible pairing index.
2017-11-14 15:50:07 +03:00
This APDU is sent to unpair a client. An existing secure channel session must be open. The application implementing this
2017-11-20 17:42:12 +03:00
protocol may apply additional restrictions, such as the verification of a user PIN. On success the pairing slot at the
given index will be freed and will be made available to pair other clients. If the index is already free nothing will
happen.
2017-11-14 15:50:07 +03:00
2017-09-22 10:37:24 +03:00
### Encrypted APDUs
2017-11-20 17:42:12 +03:00
After a successful OPEN SECURE CHANNEL command all communication between card and client is encrypted. Note that only
2017-11-21 15:46:21 +03:00
the data fields of C-APDU are encrypted, which means that CLA, INS, P1, P2 for C-APDU are plaintext. This means no
sensitive data should be sent in these parameters. Additionally a MAC is calculated for the entire APDU, including
the unencrypted fields.
Because R-APDU can only contain data if their SW is a success or warning status word (0x9000, 0x62XX, 0x63XX), when the
secure channel is open all responses will have SW 0x9000. The actual SW is always appended at the end of the response
data before encryption, which means the client must interpret the last two bytes of the plaintext response as the SW.
An exception to this is SW 0x6982, which indicates that the SecureChannel has been aborted and as such is returned
without any MAC.
2017-09-22 10:37:24 +03:00
To encrypt the data both the card and the client do the following:
1. The data is padded using the ISO/IEC 9797-1 Method 2 algorithm.
2017-11-20 17:42:12 +03:00
2. The data is encrypted using AES in CBC mode using the session key.
3. An AES CBC-MAC is calculated over the entire APDU data
4. The data field of the APDU is set to the MAC followed by the encrypted data.
2017-09-22 10:37:24 +03:00
To decrypt the data both the card and the client do the following:
2017-11-20 17:42:12 +03:00
1. The first 16 bytes of the APDU data are the MAC to be verified
2017-09-22 10:37:24 +03:00
2. The remaining data is decrypted using AES in CBC mode using the session key.
3. The padding is removed.
2017-11-20 17:42:12 +03:00
The IV used for the encryption is the last seen MAC from the counterpart. This optimizes the number
of transmitted bytes and guarantees protection from replay attacks. For the MAC generation, a zero IV is always used.
MAC generation for C-APDUs is calculated on the concatenation of CLA INS P1 P2 LC 00 00 00 00 00 00 00 00 00 00 00 and
the encrypted data field. The 11-byte long padding does not become part of the data field and does not affect LC
2017-11-21 15:46:21 +03:00
MAC generation fo R-APDUs is calculated on the concatenation of Lr 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 and
the encrypted data field. The 15-byte long padding does not become part of the response field. Lr is the length of the
2017-11-20 17:42:12 +03:00
encrypted response data field and is not transmitted.
2017-09-25 10:53:04 +03:00
Because AES in CBC mode requires the data field length in bytes to be a multiple of 16, the maximum effective APDU
2017-11-20 17:42:12 +03:00
size becomes 240 bytes. Of these 16 bytes are used for the MAC and minimum of 1 byte for padding, making the maximum
2017-09-25 10:53:04 +03:00
payload size in a single APDU 223 bytes, meaning about a 13,5% overhead.
2017-09-22 10:37:24 +03:00
### Error conditions
1. If a sensitive command is received without an active Secure Channel, the card shall respond with SW 0x6985 (
SW_CONDITIONS_NOT_SATISFIED)
2017-11-20 17:42:12 +03:00
2. If a MAC cannot be verified the card shall respond 0x6982 and the Secure Channel must be closed