keyfork (0.2.5)
Installation
[registry]
default = "forgejo"
[registries.forgejo]
index = "sparse+ " # Sparse index
# index = " " # Git
[net]
git-fetch-with-cli = true
cargo add keyfork@0.2.5
About this package
Keyfork: The Kitchen Sink of Entropy
Note: Keyfork operations are meant to be run on an airgapped machine and Keyfork will error if either any network interfaces are detected or if Keyfork is running on a system with a kernel using an insecure random number generator.
An all-inclusive crate encapsulating end-user functionality of the Keyfork
ecosystem, the Keyfork binary includes all mechanisms that should be exposed to
the user when running Keyfork. Information about what operations Keyfork
performs are available in detail by running keyfork help
(each subcommand has
thorough documentation) or in the docs
mdBook, but here's a quick overview:
Getting Started with Keyfork
Keyfork offers two options for getting started. For multi-user setups, it is
best to look at the detailed documentation for Keyfork Shard. For single-user
setups, keyfork mnemonic generate
will (by default) create a 256-bit mnemonic
phrase that can be used to start Keyfork. Store this phrase, as it's the only
way you'll be able to start Keyfork in the future. It is recommended to use a
mnemonic recovery sheet or a printed-steel solution such as the Billfodl or
Cryptosteel Capsule.
keyfork mnemonic generate
Once a mnemonic has been generated and stored in a secure manner, Keyfork can be started by "recovering" the server from the mnemonic backup mechanism:
keyfork recover mnemonic
Deriving Keys
Keyfork's primary goal is to derive keys. These keys can later be used for
things such as signing documents and artifacts or decrypting payloads.
Keyfork's first derivation target is OpenPGP, a protocol supporting many
cryptographic operations. OpenPGP keys require a User ID, which can be used to
identify the owner of the key, either by name or by email. To get an OpenPGP
public key (more accurately known as a "cert"), the sq
tool is used to
convert a key to a certificate:
keyfork derive openpgp "John Doe <jdoe@example.com>" | sq key extract-cert
All Keyfork derivations are intended to be reproducible. Because of this, Keyfork derived keys can be recreated at any time, only requiring the knowledge of how the key was made.
Dependencies
ID | Version |
---|---|
base64 | ^0.22.1 |
card-backend-pcsc | ^0.5.0 |
clap | ^4.4.2 |
clap_complete | ^4.4.6 |
keyfork-bin | ^0.1.0 |
keyfork-derive-openpgp | ^0.1.2 |
keyfork-derive-path-data | ^0.1.1 |
keyfork-derive-util | ^0.2.0 |
keyfork-entropy | ^0.1.1 |
keyfork-mnemonic | ^0.4.0 |
keyfork-prompt | ^0.2.0 |
keyfork-qrcode | ^0.1.1 |
keyfork-shard | ^0.3.0 |
keyforkd | ^0.1.1 |
keyforkd-client | ^0.2.0 |
keyforkd-models | ^0.2.0 |
openpgp-card | ^0.4.1 |
openpgp-card-sequoia | ^0.2.0 |
sequoia-openpgp | ^1.21.2 |
serde | ^1.0.195 |
smex | ^0.1.0 |
thiserror | ^1.0.56 |
tokio | ^1.35.1 |