스토리지 구조체 (struct) 생성하기
유사한 그룹으로 구성된 스토리지 항목의 구조체를 생성하는 것은 그들을 추적하는 질서정연한 방법입니다. 이렇게 그룹화된 경우 개별적인 StorageValue 항목을 따로 유지하는 것보다 참조하기가 더 쉽습니다. 이는 테스트와 제네시스 구성을 더 쉽게 만들 수 있습니다.
이 가이드에서는 on_initialize에서 사용되는 구조체를 보유하는 StorageValue 스토리지 항목을 생성하는 방법을 보여줍니다. 이 구조체는 다음과 같은 작업을 수행합니다:
초기 금액 (
issuance)을 추적합니다.해당 금액을 받는 계정 (
minter)을 추적합니다.일부 금액을 소모할 수 있는 계정 (
burner)을 추적합니다.on_initialize에서 (부분적으로) 사용됩니다.
시작하기 전에
구조체를 작성할 팔레트가 작동하는지 확인하세요. 이미 작업 중인 팔레트가 없다면 템플릿 팔레트를 사용하세요.
구조체 생성하기
MetaData라는 이름의 구조체를 생성하고 다른 유형을 선언하세요:#[derive(Clone, Encode, Decode, Eq, PartialEq, RuntimeDebug, Default)] pub struct MetaData<AccountId, Balance> { issuance: Balance, minter: AccountId, burner: AccountId, }구조체를 스토리지 항목으로 선언하기
StorageValue를 사용하여 구조체를 새로운 단일 스토리지 항목으로 선언하세요:#[pallet::storage] #[pallet::getter(fn meta_data)] pub(super) type MetaDataStore<T: Config> = StorageValue<_, MetaData<T::AccountId, T::Balance>, ValueQuery>;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안에서 사용된 변수와 일치해야 합니다.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(), }); } }on_initialize()에서 구조체 사용하기MetaData의issuance필드에 초기화할 금액을 할당하세요: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함수는 지정된 항목의 값을 체인이 시작될 때 스토리지에 기록합니다.
예제
reward-coin예제 팔레트
자원
Last updated