Expand description
A Keystore is a secure repository of private keys. MetaLairClient is a reference to a Keystore. MetaLairClient allows async generation of keypairs, and usage of those keypairs, reference by the public AgentPubKey.
§Examples
use holo_hash::AgentPubKey;
use holochain_keystore::*;
use holochain_serialized_bytes::prelude::*;
#[tokio::main(flavor = "multi_thread")]
async fn main() {
tokio::task::spawn(async move {
let keystore = holochain_keystore::spawn_test_keystore().await.unwrap();
let agent_pubkey = AgentPubKey::new_random(&keystore).await.unwrap();
#[derive(Debug, serde::Serialize, serde::Deserialize, SerializedBytes)]
struct MyData(Vec<u8>);
let my_data_1 = MyData(b"signature test data 1".to_vec());
let signature = agent_pubkey.sign(&keystore, &my_data_1).await.unwrap();
assert!(agent_pubkey.verify_signature(&signature, &my_data_1).await.unwrap());
}).await.unwrap();
}
Modules§
- Keystore backed by lair_keystore_api.
- Paths for the keystore.
Structs§
- Abstraction around runtime switching/upgrade of lair keystore / client.
Enums§
- Keystore Error Type.
Constants§
- First Test Agent Pub Key
- Second Test Agent Pub Key
- Third Test Agent Pub Key
- Fourth Test Agent Pub Key
Traits§
- Extend holo_hash::AgentPubKey with additional signature functionality from Keystore.
Functions§
- Construct a simple in-memory in-process keystore.
- Construct a new TestKeystore with the new lair api.
Type Aliases§
- alias
- Lair result type.