1 unstable release
Uses new Rust 2024
| 0.1.0 | Sep 26, 2025 |
|---|
#7 in #smartcard
115KB
2.5K
SLoC
rust-cktap
A Rust implementation of the Coinkite Tap Protocol (cktap) for use with SATSCARD, TAPSIGNER, and SATSCHIP products.
This project provides PC/SC APDU message encoding and decoding, cvc authentication, certificate chain verification, and card response verification.
It is up to the crate user to send and receive the raw cktap APDU messages via NFC to the card by implementing the CkTransport trait. An example implementation is provided using the optional rust pcsc crate. Mobile users are expected to implement CkTransport using the iOS or Android provided libraries.
Supported Features
Shared Commands
- status
- read
- response verification
- derive
- response verification
- certs
- new
- nfc
- sign
- response verification
- wait
SATSCARD-Only Commands
TAPSIGNER-Only Commands
Automated and CLI Testing with Emulator
Prerequisites
- Install dependencies for cktap emulator
Run tests with emulator
just test
Run CLI with emulated card reader
just start # for SATSCARD emulator
just start -t # for TAPSIGNER emulator
just run_emu --help
just run_emu certs
just run_emu read
just stop # stop emulator
Manual Testing with real cards
Prerequisites
- Get USB PCSC NFC card reader, for example:
- Get Coinkite SATSCARD, TAPSIGNER, or SATSCHIP cards
- Install card reader PCSC driver
- Connect USB PCSC NFC reader to desktop system
- Place SATSCARD, TAPSIGNER, or SATSCHIP on reader
Run CLI with desktop USB PCSC NFC card reader
just run --help
just run certs
just run read
Minimum Supported Rust Version (MSRV)
This library should always compile with any valid combination of features on Rust 1.85.0.
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~19MB
~276K SLoC