ISO/IEC DIS 18013-5 mDL
implementation in Rust.
It is intended to be used in creating apps for devices and readers that can interact with each other to exchange mDL
data.
This crate contains a CLI tool. Run the --help
command to see what actions you can perform.
cargo run -- --help
For example, you can get the namespaces and elements defined in an mDL:
cat test/stringified-mdl.txt | cargo run -- get-namespaces -
Here are some examples on how to use the library. You can see more in tests and read about in the dedicated README.
This example demonstrates a simulated device and reader interaction.
The reader requests the age_over_21
element, and the device responds with that value.
sequenceDiagram
autonumber
Note over Device: Initialize session
Device ->> Device: Create QR Code Engagement
Device -) + Reader: Send QR Code
Reader ->> - Reader: Establish Session
Reader -) + Device: Request age_over_21
Device -)- Reader: Send age_over_21
Reader ->> Reader: Process age_over_21
Note over Device, Reader: Session finished
- Device initialization and engagement:
- The device creates a
QR code
containingDeviceEngagement
data, which includes its public key. - Internally:
- The device initializes with the
mDL
data, private key, and public key.
- The device initializes with the
- The device creates a
- Reader processing QR code and requesting needed fields:
- The reader processes the
QR code
and creates a request for theage_over_21
element. - Internally:
- Generates its private and public keys.
- Initiates a key exchange, and generates the session keys.
- The request is encrypted with the reader's session key.
- The reader processes the
- Device accepting request and responding:
- The device receives the request and creates a response with the
age_over_21
element. - Internally:
- Initiates the key exchange, and generates the session keys.
- Decrypts the request with the reader's session key.
- Parse and validate it creating error response if needed.
- The response is encrypted with the device's session key.
- The device receives the request and creates a response with the
- Reader Processing mDL data:
- The reader processes the response and prints the value of the
age_over_21
element.
- The reader processes the response and prints the value of the
There are several states through which the device goes during the interaction:
stateDiagram
state Device {
[*] --> SessionManagerInit: initialise
SessionManagerInit --> SessionManagerEngaged: qr_engagement
SessionManagerEngaged --> SessionManager: process_session_establishment
}
state SessionManagerInit {
[*] --> [*]
}
state SessionManagerEngaged {
[*] --> [*]
}
state Reader {
[*] --> [*]
}
state SessionManager {
[*] --> AwaitingRequest
AwaitingRequest --> Signing: prepare_response
Signing --> Signing: get_next_signature_payload
Signing --> ReadyToRespond: submit_next_signature
ReadyToRespond --> AwaitingRequest: retrieve_response
AwaitingRequest --> Signing: handle_request
}
User --> Device
SessionManagerInit --> Reader: qr_engagement
Reader --> SessionManagerEngaged: establish_session
ReadyToRespond --> Reader: handle_response
From the reader's perspective, the flow is simpler:
stateDiagram
state Device {
[*] --> [*]
}
state Reader {
SessionManager --> SessionManager: handle_response
}
User --> Device
Device --> Reader: qr_engagement
Reader --> Device: establish_session
Device --> Reader
Reader --> Device: new_request
You can see the full example in simulated_device_and_reader and a version that
uses State
pattern, Arc
and Mutex
simulated_device_and_reader.