1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
use ockam_core::vault::{
    SecretAttributes, SecretPersistence, SecretType, SecretVault, Signer, Verifier,
    CURVE25519_SECRET_LENGTH,
};

pub async fn sign(vault: &mut (impl Signer + Verifier + SecretVault)) {
    for attributes in [
        SecretAttributes::new(
            SecretType::X25519,
            SecretPersistence::Ephemeral,
            CURVE25519_SECRET_LENGTH,
        ),
        SecretAttributes::new(
            SecretType::Ed25519,
            SecretPersistence::Ephemeral,
            CURVE25519_SECRET_LENGTH,
        ),
    ] {
        let secret = vault.secret_generate(attributes).await.unwrap();
        let res = vault.sign(&secret, b"hello world!").await;
        assert!(res.is_ok());
        let pubkey = vault.secret_public_key_get(&secret).await.unwrap();
        let signature = res.unwrap();
        let res = vault
            .verify(&signature, &pubkey, b"hello world!")
            .await
            .unwrap();
        assert!(res);
    }
}