Compare commits
	
		
			3 Commits
		
	
	
		
			dd3ffe74b3
			...
			b8c1fc1a93
		
	
	| Author | SHA1 | Date | 
|---|---|---|
|  | b8c1fc1a93 | |
|  | cd64353de1 | |
|  | ceb0ac2455 | 
|  | @ -324,9 +324,9 @@ checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "base64" | name = "base64" | ||||||
| version = "0.21.5" | version = "0.21.6" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "35636a1494ede3b646cc98f74f8e62c773a38a659ebc777a2cf26b9b74171df9" | checksum = "c79fed4cdb43e993fcdadc7e58a09fd0e3e649c4436fa11da71c9f1f3ee7feb9" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "base64ct" | name = "base64ct" | ||||||
|  | @ -568,9 +568,9 @@ dependencies = [ | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "clap" | name = "clap" | ||||||
| version = "4.4.13" | version = "4.4.14" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "52bdc885e4cacc7f7c9eedc1ef6da641603180c783c41a15c264944deeaab642" | checksum = "33e92c5c1a78c62968ec57dbc2440366a2d6e5a23faf829970ff1585dc6b18e2" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clap_builder", |  "clap_builder", | ||||||
|  "clap_derive", |  "clap_derive", | ||||||
|  | @ -578,9 +578,9 @@ dependencies = [ | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "clap_builder" | name = "clap_builder" | ||||||
| version = "4.4.12" | version = "4.4.14" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "fb7fb5e4e979aec3be7791562fcba452f94ad85e954da024396433e0e25a79e9" | checksum = "f4323769dc8a61e2c39ad7dc26f6f2800524691a44d74fe3d1071a5c24db6370" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "anstream", |  "anstream", | ||||||
|  "anstyle", |  "anstyle", | ||||||
|  | @ -624,14 +624,14 @@ dependencies = [ | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "console" | name = "console" | ||||||
| version = "0.15.7" | version = "0.15.8" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "c926e00cc70edefdc64d3a5ff31cc65bb97a3460097762bd23afb4d8145fccf8" | checksum = "0e1f83fc076bd6dd27517eacdf25fef6c4dfe5f1d7448bafaaf3a26f13b5e4eb" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "encode_unicode", |  "encode_unicode", | ||||||
|  "lazy_static", |  "lazy_static", | ||||||
|  "libc", |  "libc", | ||||||
|  "windows-sys 0.45.0", |  "windows-sys 0.52.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
|  | @ -1143,9 +1143,9 @@ dependencies = [ | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "getrandom" | name = "getrandom" | ||||||
| version = "0.2.11" | version = "0.2.12" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f" | checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "js-sys", |  "js-sys", | ||||||
|  | @ -1393,9 +1393,9 @@ dependencies = [ | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "k256" | name = "k256" | ||||||
| version = "0.13.2" | version = "0.13.3" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3f01b677d82ef7a676aa37e099defd83a28e15687112cafdd112d60236b6115b" | checksum = "956ff9b67e26e1a6a866cb758f12c6f8746208489e3e4a4b5580802f2f0a587b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "ecdsa", |  "ecdsa", | ||||||
|  | @ -3177,15 +3177,6 @@ dependencies = [ | ||||||
|  "windows-targets 0.52.0", |  "windows-targets 0.52.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows-sys" |  | ||||||
| version = "0.45.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "75283be5efb2831d37ea142365f009c02ec203cd29a3ebecbc093d52315b66d0" |  | ||||||
| dependencies = [ |  | ||||||
|  "windows-targets 0.42.2", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows-sys" | name = "windows-sys" | ||||||
| version = "0.48.0" | version = "0.48.0" | ||||||
|  | @ -3204,21 +3195,6 @@ dependencies = [ | ||||||
|  "windows-targets 0.52.0", |  "windows-targets 0.52.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows-targets" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "8e5180c00cd44c9b1c88adb3693291f1cd93605ded80c250a75d472756b4d071" |  | ||||||
| dependencies = [ |  | ||||||
|  "windows_aarch64_gnullvm 0.42.2", |  | ||||||
|  "windows_aarch64_msvc 0.42.2", |  | ||||||
|  "windows_i686_gnu 0.42.2", |  | ||||||
|  "windows_i686_msvc 0.42.2", |  | ||||||
|  "windows_x86_64_gnu 0.42.2", |  | ||||||
|  "windows_x86_64_gnullvm 0.42.2", |  | ||||||
|  "windows_x86_64_msvc 0.42.2", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows-targets" | name = "windows-targets" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3249,12 +3225,6 @@ dependencies = [ | ||||||
|  "windows_x86_64_msvc 0.52.0", |  "windows_x86_64_msvc 0.52.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_aarch64_gnullvm" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "597a5118570b68bc08d8d59125332c54f1ba9d9adeedeef5b99b02ba2b0698f8" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_aarch64_gnullvm" | name = "windows_aarch64_gnullvm" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3267,12 +3237,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" | checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_aarch64_msvc" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "e08e8864a60f06ef0d0ff4ba04124db8b0fb3be5776a5cd47641e942e58c4d43" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_aarch64_msvc" | name = "windows_aarch64_msvc" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3285,12 +3249,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" | checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_i686_gnu" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "c61d927d8da41da96a81f029489353e68739737d3beca43145c8afec9a31a84f" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_i686_gnu" | name = "windows_i686_gnu" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3303,12 +3261,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" | checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_i686_msvc" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "44d840b6ec649f480a41c8d80f9c65108b92d89345dd94027bfe06ac444d1060" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_i686_msvc" | name = "windows_i686_msvc" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3321,12 +3273,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" | checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_x86_64_gnu" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "8de912b8b8feb55c064867cf047dda097f92d51efad5b491dfb98f6bbb70cb36" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_x86_64_gnu" | name = "windows_x86_64_gnu" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3339,12 +3285,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" | checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_x86_64_gnullvm" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "26d41b46a36d453748aedef1486d5c7a85db22e56aff34643984ea85514e94a3" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_x86_64_gnullvm" | name = "windows_x86_64_gnullvm" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  | @ -3357,12 +3297,6 @@ version = "0.52.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" | checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows_x86_64_msvc" |  | ||||||
| version = "0.42.2" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "9aec5da331524158c6d1a4ac0ab1541149c0b9505fde06423b02f5ef0106b9f0" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows_x86_64_msvc" | name = "windows_x86_64_msvc" | ||||||
| version = "0.48.5" | version = "0.48.5" | ||||||
|  |  | ||||||
|  | @ -1,7 +1,10 @@ | ||||||
| [package] | [package] | ||||||
| name = "keyfork-prompt" | name = "keyfork-prompt" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
|  | description = "Prompt management utilities for Keyfork" | ||||||
|  | repository = "https://git.distrust.co/public/keyfork" | ||||||
| edition = "2021" | edition = "2021" | ||||||
|  | license = "MIT" | ||||||
| 
 | 
 | ||||||
| # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html | # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| use std::{ | use std::{ | ||||||
|     env, |     env, | ||||||
|     io::stdin, |     fs::File, | ||||||
|     path::PathBuf, |     path::{Path, PathBuf}, | ||||||
|     process::ExitCode, |     process::ExitCode, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -9,10 +9,11 @@ use keyfork_shard::openpgp::{combine, discover_certs, openpgp::Cert, parse_messa | ||||||
| 
 | 
 | ||||||
| type Result<T, E = Box<dyn std::error::Error>> = std::result::Result<T, E>; | type Result<T, E = Box<dyn std::error::Error>> = std::result::Result<T, E>; | ||||||
| 
 | 
 | ||||||
| fn validate<'a>( | fn validate( | ||||||
|     key_discovery: impl Into<Option<&'a str>>, |     shard: impl AsRef<Path>, | ||||||
| ) -> Result<Vec<Cert>> { |     key_discovery: Option<&str>, | ||||||
|     let key_discovery = key_discovery.into().map(PathBuf::from); | ) -> Result<(File, Vec<Cert>)> { | ||||||
|  |     let key_discovery = key_discovery.map(PathBuf::from); | ||||||
|     key_discovery.as_ref().map(std::fs::metadata).transpose()?; |     key_discovery.as_ref().map(std::fs::metadata).transpose()?; | ||||||
| 
 | 
 | ||||||
|     // Load certs from path
 |     // Load certs from path
 | ||||||
|  | @ -21,20 +22,20 @@ fn validate<'a>( | ||||||
|         .transpose()? |         .transpose()? | ||||||
|         .unwrap_or(vec![]); |         .unwrap_or(vec![]); | ||||||
| 
 | 
 | ||||||
|     Ok(certs) |     Ok((File::open(shard)?, certs)) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn run() -> Result<()> { | fn run() -> Result<()> { | ||||||
|     let mut args = env::args(); |     let mut args = env::args(); | ||||||
|     let program_name = args.next().expect("program name"); |     let program_name = args.next().expect("program name"); | ||||||
|     let args = args.collect::<Vec<_>>(); |     let args = args.collect::<Vec<_>>(); | ||||||
|     let cert_list = match args.as_slice() { |     let (messages_file, cert_list) = match args.as_slice() { | ||||||
|         [key_discovery] => validate(key_discovery.as_str())?, |         [shard, key_discovery] => validate(shard, Some(key_discovery))?, | ||||||
|         [] => validate(None)?, |         [shard] => validate(shard, None)?, | ||||||
|         _ => panic!("Usage: {program_name} threshold [key_discovery]"), |         _ => panic!("Usage: {program_name} <shard> [key_discovery]"), | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     let mut encrypted_messages = parse_messages(stdin())?; |     let mut encrypted_messages = parse_messages(messages_file)?; | ||||||
| 
 | 
 | ||||||
|     let encrypted_metadata = encrypted_messages |     let encrypted_metadata = encrypted_messages | ||||||
|         .pop_front() |         .pop_front() | ||||||
|  |  | ||||||
|  | @ -4,8 +4,9 @@ Combine `threshold` shares into a previously [`split`] secret. | ||||||
| 
 | 
 | ||||||
| ## Arguments | ## Arguments | ||||||
| 
 | 
 | ||||||
| `keyfork-shard-combine-openpgp [key_discovery]` | `keyfork-shard-combine-openpgp <shard> [key_discovery]` | ||||||
| 
 | 
 | ||||||
|  | * `shard`: The shard file to read from. | ||||||
| * `key_discovery`: A file or directory containing OpenPGP keys. | * `key_discovery`: A file or directory containing OpenPGP keys. | ||||||
|   If the number of keys found is less than `threshold`, an OpenPGP Card |   If the number of keys found is less than `threshold`, an OpenPGP Card | ||||||
|   fallback will be used to decrypt the rest of the messages. |   fallback will be used to decrypt the rest of the messages. | ||||||
|  | @ -17,10 +18,6 @@ The terminal may be overridden if the default pinentry command is | ||||||
| used if an OpenPGP key file has an encrypted secret key or to prompt for the | used if an OpenPGP key file has an encrypted secret key or to prompt for the | ||||||
| PIN for an OpenPGP smart card. | PIN for an OpenPGP smart card. | ||||||
| 
 | 
 | ||||||
| ## Input |  | ||||||
| 
 |  | ||||||
| OpenPGP messages from [`split`]. |  | ||||||
| 
 |  | ||||||
| ## Output | ## Output | ||||||
| 
 | 
 | ||||||
| Hex-encoded secret. | Hex-encoded secret. | ||||||
|  | @ -29,10 +26,10 @@ Hex-encoded secret. | ||||||
| 
 | 
 | ||||||
| ```sh | ```sh | ||||||
| # Decrypt using only smartcards | # Decrypt using only smartcards | ||||||
| keyfork-shard-combine-openpgp < shard.pgp | keyfork-shard-combine-openpgp shard.pgp | ||||||
| 
 | 
 | ||||||
| # Decrypt using on-disk private keys | # Decrypt using on-disk private keys | ||||||
| keyfork-shard-combine-openpgp key_discovery.pgp < shard.pgp | keyfork-shard-combine-openpgp key_discovery.pgp shard.pgp | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| [`split`]: ./split.md | [`split`]: ./split.md | ||||||
|  |  | ||||||
|  | @ -68,8 +68,9 @@ Combine `threshold` shares into a secret. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| `keyfork shard combine [key_discovery]` | `keyfork shard combine <shard> [key_discovery]` | ||||||
| 
 | 
 | ||||||
|  | * `shard`: A file containing the encrypted shards. | ||||||
| * `key_discovery`: Either a file or a directory containing public keys. | * `key_discovery`: Either a file or a directory containing public keys. | ||||||
|   If a file, load all private keys from a file. |   If a file, load all private keys from a file. | ||||||
|   If a directory, for every file in the directory (non-recursively), load |   If a directory, for every file in the directory (non-recursively), load | ||||||
|  | @ -77,11 +78,6 @@ Combine `threshold` shares into a secret. | ||||||
|   If the amount of keys found is less than `threshold`, it is up to the format |   If the amount of keys found is less than `threshold`, it is up to the format | ||||||
|   to determine how to discover the keys. |   to determine how to discover the keys. | ||||||
| 
 | 
 | ||||||
| ### Input |  | ||||||
| 
 |  | ||||||
| The input of the command is dependent on the format, but should be the exact |  | ||||||
| same as the output from the `split` command previously used. |  | ||||||
| 
 |  | ||||||
| ### Output | ### Output | ||||||
| 
 | 
 | ||||||
| Hex-encoded secret. | Hex-encoded secret. | ||||||
|  | @ -106,8 +102,9 @@ by a remote recovery operator. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| `keyfork shard transport [key_discovery]` | `keyfork shard transport <shard> [key_discovery]` | ||||||
| 
 | 
 | ||||||
|  | * `shard`: A file containing encrypted shards. | ||||||
| * `key_discovery`: Either a file or a directory containing public keys. | * `key_discovery`: Either a file or a directory containing public keys. | ||||||
|   If a file, load all private keys from a file. |   If a file, load all private keys from a file. | ||||||
|   If a directory, for every file in the directory (non-recursively), load |   If a directory, for every file in the directory (non-recursively), load | ||||||
|  | @ -115,11 +112,6 @@ by a remote recovery operator. | ||||||
|   If the amount of keys found is less than `threshold`, it is up to the format |   If the amount of keys found is less than `threshold`, it is up to the format | ||||||
|   to determine how to discover the keys. |   to determine how to discover the keys. | ||||||
| 
 | 
 | ||||||
| ### Input |  | ||||||
| 
 |  | ||||||
| The input of the command is dependent on the format, but should be the exact |  | ||||||
| same as the output from the `split` command previously used. |  | ||||||
| 
 |  | ||||||
| ### Prompts | ### Prompts | ||||||
| 
 | 
 | ||||||
| The command will prompt for 33 words from the remote shard recovery operator, | The command will prompt for 33 words from the remote shard recovery operator, | ||||||
|  | @ -131,10 +123,10 @@ operator. | ||||||
| 
 | 
 | ||||||
| ```sh | ```sh | ||||||
| # Transport using a smart card | # Transport using a smart card | ||||||
| keyfork shard transport < shard.pgp | keyfork shard transport shard.pgp | ||||||
| 
 | 
 | ||||||
| # Transport using on-disk private keys | # Transport using on-disk private keys | ||||||
| keyfork shard transport key_discovery.pgp < shard.pgp | keyfork shard transport key_discovery.pgp shard.pgp | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| [`keyfork recover remote-shard`]: ../recover/index.md#keyfork-recover-remote-shard | [`keyfork recover remote-shard`]: ../recover/index.md#keyfork-recover-remote-shard | ||||||
|  |  | ||||||
|  | @ -164,6 +164,9 @@ pub enum ShardSubcommands { | ||||||
|     /// Decrypt a single share and re-encrypt it to an ephemeral symmetric key using mnemonic-based
 |     /// Decrypt a single share and re-encrypt it to an ephemeral symmetric key using mnemonic-based
 | ||||||
|     /// prompts. The mnemonics can be sent over insecure channels.
 |     /// prompts. The mnemonics can be sent over insecure channels.
 | ||||||
|     Transport { |     Transport { | ||||||
|  |         /// The path to load the shard from.
 | ||||||
|  |         shard: PathBuf, | ||||||
|  | 
 | ||||||
|         /// The path to discover private keys from.
 |         /// The path to discover private keys from.
 | ||||||
|         key_discovery: Option<PathBuf>, |         key_discovery: Option<PathBuf>, | ||||||
|     }, |     }, | ||||||
|  | @ -175,6 +178,9 @@ pub enum ShardSubcommands { | ||||||
|     /// hardware metadata discovery, any hardware key used to split may be used to decrypt metadata
 |     /// hardware metadata discovery, any hardware key used to split may be used to decrypt metadata
 | ||||||
|     /// used to combine.
 |     /// used to combine.
 | ||||||
|     Combine { |     Combine { | ||||||
|  |         /// The path to load the shards from.
 | ||||||
|  |         shard: PathBuf, | ||||||
|  | 
 | ||||||
|         /// The path to discover private keys from.
 |         /// The path to discover private keys from.
 | ||||||
|         key_discovery: Option<PathBuf>, |         key_discovery: Option<PathBuf>, | ||||||
|     }, |     }, | ||||||
|  | @ -186,21 +192,16 @@ impl ShardSubcommands { | ||||||
|         shard: &Shard, |         shard: &Shard, | ||||||
|         _keyfork: &Keyfork, |         _keyfork: &Keyfork, | ||||||
|     ) -> Result<(), Box<dyn std::error::Error>> { |     ) -> Result<(), Box<dyn std::error::Error>> { | ||||||
|         let mut stdin = stdin(); |         let stdin = stdin(); | ||||||
|         let mut stdout = stdout(); |         let mut stdout = stdout(); | ||||||
|         let mut input = String::new(); |  | ||||||
|         stdin.read_to_string(&mut input)?; |  | ||||||
|         let mut format = shard.format.clone(); |         let mut format = shard.format.clone(); | ||||||
|         // bang sandwich macro fun
 |  | ||||||
|         if input.contains("BEGIN PGP MESSAGE") && !matches!(self, ShardSubcommands::Split { .. }) { |  | ||||||
|             let _ = format.insert(Format::OpenPGP(OpenPGP)); |  | ||||||
|         } |  | ||||||
|         match self { |         match self { | ||||||
|             ShardSubcommands::Split { |             ShardSubcommands::Split { | ||||||
|                 threshold, |                 threshold, | ||||||
|                 max, |                 max, | ||||||
|                 key_discovery, |                 key_discovery, | ||||||
|             } => { |             } => { | ||||||
|  |                 let input = std::io::read_to_string(stdin)?; | ||||||
|                 assert!(threshold <= max, "threshold {threshold} <= max {max}"); |                 assert!(threshold <= max, "threshold {threshold} <= max {max}"); | ||||||
|                 let secret = smex::decode(input.trim())?; |                 let secret = smex::decode(input.trim())?; | ||||||
|                 match format { |                 match format { | ||||||
|  | @ -213,20 +214,44 @@ impl ShardSubcommands { | ||||||
|                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), |                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             ShardSubcommands::Transport { key_discovery } => match format { |             ShardSubcommands::Transport { | ||||||
|                 Some(Format::OpenPGP(o)) => o.decrypt(key_discovery.as_ref(), input.as_bytes()), |                 shard, | ||||||
|  |                 key_discovery, | ||||||
|  |             } => { | ||||||
|  |                 let shard_content = std::fs::read_to_string(shard)?; | ||||||
|  |                 if shard_content.contains("BEGIN PGP MESSAGE") { | ||||||
|  |                     let _ = format.insert(Format::OpenPGP(OpenPGP)); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 match format { | ||||||
|  |                     Some(Format::OpenPGP(o)) => { | ||||||
|  |                         o.decrypt(key_discovery.as_ref(), shard_content.as_bytes()) | ||||||
|  |                     } | ||||||
|                     Some(Format::P256(_p)) => todo!(), |                     Some(Format::P256(_p)) => todo!(), | ||||||
|                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), |                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), | ||||||
|             }, |  | ||||||
|             ShardSubcommands::Combine { key_discovery } => match format { |  | ||||||
|                 Some(Format::OpenPGP(o)) => { |  | ||||||
|                     o.combine(key_discovery.as_ref(), input.as_bytes(), &mut stdout) |  | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|  |             ShardSubcommands::Combine { | ||||||
|  |                 shard, | ||||||
|  |                 key_discovery, | ||||||
|  |             } => { | ||||||
|  |                 let shard_content = std::fs::read_to_string(shard)?; | ||||||
|  |                 if shard_content.contains("BEGIN PGP MESSAGE") { | ||||||
|  |                     let _ = format.insert(Format::OpenPGP(OpenPGP)); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 match format { | ||||||
|  |                     Some(Format::OpenPGP(o)) => o.combine( | ||||||
|  |                         key_discovery.as_ref(), | ||||||
|  |                         shard_content.as_bytes(), | ||||||
|  |                         &mut stdout, | ||||||
|  |                     ), | ||||||
|                     Some(Format::P256(_p)) => { |                     Some(Format::P256(_p)) => { | ||||||
|                         todo!() |                         todo!() | ||||||
|                     } |                     } | ||||||
|                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), |                     None => panic!("{COULD_NOT_DETERMINE_FORMAT}"), | ||||||
|             }, |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue