Skip to content
Snippets Groups Projects
Select Git revision
  • master default protected
  • network/gdev-800 protected
  • cgeek/issue-297-cpu
  • gdev-800-tests
  • update-docker-compose-rpc-squid-names
  • fix-252
  • 1000i100-test
  • hugo/tmp-0.9.1
  • network/gdev-803 protected
  • hugo/endpoint-gossip
  • network/gdev-802 protected
  • hugo/distance-precompute
  • network/gdev-900 protected
  • tuxmain/anonymous-tx
  • debug/podman
  • hugo/195-doc
  • hugo/195-graphql-schema
  • hugo-tmp-dockerfile-cache
  • release/client-800.2 protected
  • release/runtime-800 protected
  • gdev-900-0.10.1 protected
  • gdev-900-0.10.0 protected
  • gdev-900-0.9.2 protected
  • gdev-800-0.8.0 protected
  • gdev-900-0.9.1 protected
  • gdev-900-0.9.0 protected
  • gdev-803 protected
  • gdev-802 protected
  • runtime-801 protected
  • gdev-800 protected
  • runtime-800-bis protected
  • runtime-800 protected
  • runtime-800-backup protected
  • runtime-701 protected
  • runtime-700 protected
  • runtime-600 protected
  • runtime-500 protected
  • v0.4.1 protected
  • runtime-401 protected
  • v0.4.0 protected
40 results

identity.rs

Blame
  • identity.rs 3.00 KiB
    // Copyright 2021 Axiom-Team
    //
    // This file is part of Substrate-Libre-Currency.
    //
    // Substrate-Libre-Currency 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.
    //
    // Substrate-Libre-Currency 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 Substrate-Libre-Currency. If not, see <https://www.gnu.org/licenses/>.
    
    use super::gdev;
    use super::gdev::runtime_types::pallet_identity;
    use super::*;
    use sp_keyring::AccountKeyring;
    use subxt::tx::PairSigner;
    
    // submit extrinsics
    
    pub async fn create_identity(
        client: &Client,
        from: AccountKeyring,
        to: AccountKeyring,
    ) -> Result<()> {
        let from = PairSigner::new(from.pair());
        let to = to.to_account_id();
    
        let _events = create_block_with_extrinsic(
            client,
            client
                .tx()
                .create_signed(
                    &gdev::tx().identity().create_identity(to),
                    &from,
                    BaseExtrinsicParamsBuilder::new(),
                )
                .await?,
        )
        .await?;
    
        Ok(())
    }
    
    pub async fn confirm_identity(client: &Client, from: AccountKeyring, pseudo: String) -> Result<()> {
        let from = PairSigner::new(from.pair());
    
        let _events = create_block_with_extrinsic(
            client,
            client
                .tx()
                .create_signed(
                    &gdev::tx().identity().confirm_identity(pseudo),
                    &from,
                    BaseExtrinsicParamsBuilder::new(),
                )
                .await?,
        )
        .await?;
    
        Ok(())
    }
    
    // fetch identity in storage
    
    use crate::DuniterWorld;
    // declare IdtyValue types
    type BlockNumber = u32;
    type AccountId = subxt::ext::sp_core::crypto::AccountId32;
    type IdtyData = gdev::runtime_types::common_runtime::entities::IdtyData;
    type IdtyValue =
        gdev::runtime_types::pallet_identity::types::IdtyValue<BlockNumber, AccountId, IdtyData>;
    
    // get identity value from account keyring name
    pub async fn get_identity_value(world: &mut DuniterWorld, account: String) -> Result<IdtyValue> {
        let account = AccountKeyring::from_str(&account)
            .expect("unknown account")
            .to_account_id();
    
        let identity_index = world
            .read(&gdev::storage().identity().identity_index_of(&account))
            .await?
            .ok_or_else(|| anyhow::anyhow!("identity {} has no associated index", account))
            .unwrap();
    
        let _identity_value = world
            .read(&gdev::storage().identity().identities(&identity_index))
            .await?
            .ok_or_else(|| {
                anyhow::anyhow!(
                    "indentity index {} does not have associated value",
                    identity_index
                )
            })?;
    
        Ok(_identity_value)
    }