스토리지 구조체 (struct) 생성하기

유사한 그룹으로 구성된 스토리지 항목의 구조체를 생성하는 것은 그들을 추적하는 질서정연한 방법입니다. 이렇게 그룹화된 경우 개별적인 StorageValue 항목을 따로 유지하는 것보다 참조하기가 더 쉽습니다. 이는 테스트와 제네시스 구성을 더 쉽게 만들 수 있습니다.

이 가이드에서는 on_initialize에서 사용되는 구조체를 보유하는 StorageValue 스토리지 항목을 생성하는 방법을 보여줍니다. 이 구조체는 다음과 같은 작업을 수행합니다:

  • 초기 금액 (issuance)을 추적합니다.

  • 해당 금액을 받는 계정 (minter)을 추적합니다.

  • 일부 금액을 소모할 수 있는 계정 (burner)을 추적합니다.

  • on_initialize에서 (부분적으로) 사용됩니다.

시작하기 전에

구조체를 작성할 팔레트가 작동하는지 확인하세요. 이미 작업 중인 팔레트가 없다면 템플릿 팔레트를 사용하세요.

  1. 구조체 생성하기

    MetaData라는 이름의 구조체를 생성하고 다른 유형을 선언하세요:

    #[derive(Clone, Encode, Decode, Eq, PartialEq, RuntimeDebug, Default)]
    pub struct MetaData<AccountId, Balance> {
    	issuance: Balance,
    	minter: AccountId,
    	burner: AccountId,
    }
  2. 구조체를 스토리지 항목으로 선언하기

    StorageValue를 사용하여 구조체를 새로운 단일 스토리지 항목으로 선언하세요:

    #[pallet::storage]
    #[pallet::getter(fn meta_data)]
    	pub(super) type MetaDataStore<T: Config> = StorageValue<_, MetaData<T::AccountId, T::Balance>, ValueQuery>;
  3. GenesisConfig 구성하기

    MetaData 구조체에서 값을 초기화하기 위해 #[pallet::genesis_config] 속성을 사용하세요.

    // `admin`를 `T::AccountId` 타입으로 선언합니다.
    #[pallet::genesis_config]
    pub struct GenesisConfig<T: Config> {
    	pub admin: T::AccountId,
    	}
    // 기본값을 지정합니다.
    #[cfg(feature = "std")]
    impl<T: Config> Default for GenesisConfig<T> {
    	fn default() -> Self {
    		Self {
    			admin: Default::default(),
    			}
    		}
    	}

    admin 변수는 node/chainspec.rs 파일 내의 fn testnet_genesis 안에서 사용된 변수와 일치해야 합니다.

  4. GenesisBuild 구성하기

    #[pallet::genesis_build] 속성을 사용하여 admin을 사용하여 구조체의 값을 초기화하세요. 이때 T::AccountId 타입의 값을 초기화합니다:

    #[pallet::genesis_build]
    impl<T: Config> GenesisBuild<T> for GenesisConfig<T> {
    	fn build(&self) {
    		MetaDataStore::<T>::put(MetaData {
    			issuance: Zero::zero(),
    			minter: self.admin.clone(),
    			burner: self.admin.clone(),
    		});
    	}
    }
  5. on_initialize()에서 구조체 사용하기

    MetaDataissuance 필드에 초기화할 금액을 할당하세요:

    fn on_initialize(_n: T::BlockNumber) -> Weight {
    	// StorageValue 구조체에 대한 별칭 생성하기
    	let mut meta = MetaDataStore::<T>::get();
    
    	// `issuance` 필드에 값을 추가합니다.
    	let value: T::Balance = 50u8.into();
    	meta.issuance = meta.issuance.saturating_add(value);
    
    	// 스토리지의 `minter` 계정에 금액 추가하기
    	Accounts::<T>::mutate(&meta.minter, |bal| {
    		*bal = bal.saturating_add(value);
    	});
    }

    on_initialize 함수는 지정된 항목의 값을 체인이 시작될 때 스토리지에 기록합니다.

예제

자원

Last updated