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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
use crate::{AuthenticationProof, Changes, Contact, Lease, ProfileIdentifier};
use cfg_if::cfg_if;
use ockam_core::compat::vec::Vec;
use ockam_core::{Address, Message};
use ockam_vault::{PublicKey, Secret};
use serde::{Deserialize, Serialize};

#[derive(Serialize, Deserialize)]
pub enum MaybeContact {
    None,
    Contact(Contact),
}

#[derive(Serialize, Deserialize, Message)]
pub enum IdentityResponse {
    AddKey,
    CreateProfile(ProfileIdentifier),
    CreateAuthenticationProof(AuthenticationProof),
    GetPublicKey(PublicKey),
    GetProfilePublicKey(PublicKey),
    GetProfileSecretKey(Secret),
    GetSecretKey(Secret),
    GetChanges(Changes),
    Contacts(Vec<Contact>),
    GetContact(MaybeContact),
    VerifyAuthenticationProof(bool),
    VerifyContact(bool),
    VerifyAndUpdateContact(bool),
    VerifyChanges(bool),
    VerifyAndAddContact(bool),
    CreateSecureChannelListener,
    CreateSecureChannel(Address),
    Lease(Lease),
    #[cfg(feature = "credentials")]
    CredentialResponse(IdentityCredentialResponse),
}

cfg_if! {
    if #[cfg(feature = "credentials")] {
        use crate::{
            BlsSecretKey,
            BbsCredential, CredentialFragment2, CredentialOffer, CredentialPresentation, CredentialProof,
            CredentialPublicKey, CredentialRequestFragment, EntityCredential, ProofRequestId,
        };

        #[derive(Serialize, Deserialize)]
        pub enum IdentityCredentialResponse {
            GetSigningKey(BlsSecretKey),
            GetIssuerPublicKey(CredentialPublicKey),
            CreateOffer(CredentialOffer),
            CreateProofOfPossession(CredentialProof),
            SignCredential(BbsCredential),
            SignCredentialRequest(CredentialFragment2),
            AcceptCredentialOffer(CredentialRequestFragment),
            CombineCredentialFragments(BbsCredential),
            IsValidCredential(bool),
            PresentCredential(CredentialPresentation),
            CreateProofRequestId(ProofRequestId),
            VerifyProofOfPossession(bool),
            VerifyCredentialPresentation(bool),
            AddCredential,
            GetCredential(EntityCredential),
        }

    }
}