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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
// Copyright 2021 Axiom-Team
//
// This file is part of Duniter-v2S.
//
// Duniter-v2S is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, version 3 of the License.
//
// Duniter-v2S is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with Duniter-v2S. If not, see <https://www.gnu.org/licenses/>.

//! Various basic types for use in the identity pallet.

use codec::{Decode, Encode};
use frame_support::pallet_prelude::*;
use scale_info::{prelude::vec::Vec, TypeInfo};
use serde::{Deserialize, Serialize};

/// Internal events related to identity.
pub enum IdtyEvent<T: crate::Config> {
    /// Creation of a new identity by another.
    // pallet account links account to identity
    // pallet wot adds certification
    // pallet quota adds storage item for this identity
    Created {
        /// Identity of the creator.
        creator: T::IdtyIndex,
        /// Account of the identity owner.
        owner_key: T::AccountId,
    },
    /// Removing an identity (unvalidated or revoked).
    // pallet wot removes associated certifications if status is not revoked
    // pallet quota removes associated quota
    // pallet smith-members exclude smith
    Removed {
        /// Status of the identity.
        status: IdtyStatus,
    },
    // TODO add a way to unlink accounts corresponding to revoked or removed identities
}

/// Reasons for revocation.
#[derive(Encode, Decode, Clone, PartialEq, Eq, RuntimeDebug, TypeInfo)]
pub enum RevocationReason {
    /// Revoked by root (e.g., governance or migration).
    Root,
    /// Revoked by user action (revocation document).
    User,
    /// Revoked due to inactive period.
    Expired,
}

/// Reasons for removal.
#[derive(Encode, Decode, Clone, PartialEq, Eq, RuntimeDebug, TypeInfo)]
pub enum RemovalReason {
    /// Removed by root.
    Root,
    /// Removed because unconfirmed.
    Unconfirmed,
    /// Removed because unvalidated.
    Unvalidated,
    /// Removed automatically after revocation buffer.
    Revoked,
}

/// Represents the name of an identity, ASCII encoded.
#[derive(
    Encode,
    Decode,
    Default,
    Clone,
    PartialEq,
    Eq,
    PartialOrd,
    Ord,
    RuntimeDebug,
    Serialize,
    Deserialize,
    TypeInfo,
)]
pub struct IdtyName(pub Vec<u8>);

impl From<&str> for IdtyName {
    fn from(s: &str) -> Self {
        Self(s.as_bytes().to_vec())
    }
}

/// State of an identity.
#[derive(
    Encode,
    Decode,
    Default,
    Clone,
    Copy,
    PartialEq,
    Eq,
    RuntimeDebug,
    TypeInfo,
    Deserialize,
    Serialize,
)]
pub enum IdtyStatus {
    /// Created through a first certification but unconfirmed.
    #[default]
    Unconfirmed,
    /// Confirmed by key owner with a name published but unvalidated.
    Unvalidated,
    /// Member of the main web of trust.
    // (there must be a membership in membership pallet storage)
    Member,
    /// Not a member of the main web of trust, auto-revocation planned.
    NotMember,
    /// Revoked manually or automatically, deletion possible.
    Revoked,
}

/// Identity value structure.
///
/// Represents the value associated with an identity, akin to key/value pairs.
#[derive(Serialize, Deserialize, Debug, Encode, Decode, Clone, PartialEq, Eq, TypeInfo)]
pub struct IdtyValue<BlockNumber, AccountId, IdtyData> {
    /// Data shared between pallets defined by runtime.
    /// Only contains `first_eligible_ud` in our case.
    pub data: IdtyData,
    /// Block before which creating a new identity is not allowed.
    pub next_creatable_identity_on: BlockNumber,
    /// Previous owner key of this identity (optional).
    pub old_owner_key: Option<(AccountId, BlockNumber)>,
    /// Current owner key of this identity.
    pub owner_key: AccountId,
    /// Next action scheduled on identity.
    ///
    /// `0` if no action is scheduled.
    pub next_scheduled: BlockNumber,
    /// Current status of the identity (until validation).
    pub status: IdtyStatus,
}

/// Reprensent the payload to define a new owner key.
#[derive(Clone, Copy, Encode, RuntimeDebug)]
pub struct IdtyIndexAccountIdPayload<'a, AccountId, IdtyIndex, Hash> {
    /// Hash of the genesis block.
    // Used to avoid replay attacks across networks.
    pub genesis_hash: &'a Hash,
    /// Identity index.
    pub idty_index: IdtyIndex,
    /// Old owner key of the identity.
    pub old_owner_key: &'a AccountId,
}

/// Represents the payload for identity revocation.
#[derive(Clone, Copy, Encode, Decode, PartialEq, Eq, TypeInfo, RuntimeDebug)]
pub struct RevocationPayload<IdtyIndex, Hash> {
    /// Hash of the genesis block.
    // Used to avoid replay attacks across networks.
    pub genesis_hash: Hash,
    /// Identity index.
    pub idty_index: IdtyIndex,
}