near_contract_standards/non_fungible_token/
metadata.rsuse near_sdk::json_types::Base64VecU8;
use near_sdk::{ext_contract, near, require};
pub const NFT_METADATA_SPEC: &str = "nft-1.0.0";
#[derive(Clone, Debug, PartialEq, Eq)]
#[near(serializers=[borsh, json])]
pub struct NFTContractMetadata {
pub spec: String, pub name: String, pub symbol: String, pub icon: Option<String>, pub base_uri: Option<String>, pub reference: Option<String>, pub reference_hash: Option<Base64VecU8>, }
#[near(serializers=[borsh, json])]
#[derive(Debug, Clone, Default, PartialEq, Eq)]
pub struct TokenMetadata {
pub title: Option<String>, pub description: Option<String>, pub media: Option<String>, pub media_hash: Option<Base64VecU8>, pub copies: Option<u64>, pub issued_at: Option<String>, pub expires_at: Option<String>, pub starts_at: Option<String>, pub updated_at: Option<String>, pub extra: Option<String>, pub reference: Option<String>, pub reference_hash: Option<Base64VecU8>, }
#[ext_contract(ext_nft_metadata_provider)]
pub trait NonFungibleTokenMetadataProvider {
fn nft_metadata(&self) -> NFTContractMetadata;
}
impl NFTContractMetadata {
pub fn assert_valid(&self) {
require!(self.spec == NFT_METADATA_SPEC, "Spec is not NFT metadata");
require!(
self.reference.is_some() == self.reference_hash.is_some(),
"Reference and reference hash must be present"
);
if let Some(reference_hash) = &self.reference_hash {
require!(reference_hash.0.len() == 32, "Hash has to be 32 bytes");
}
}
}
impl TokenMetadata {
pub fn assert_valid(&self) {
require!(self.media.is_some() == self.media_hash.is_some());
if let Some(media_hash) = &self.media_hash {
require!(media_hash.0.len() == 32, "Media hash has to be 32 bytes");
}
require!(self.reference.is_some() == self.reference_hash.is_some());
if let Some(reference_hash) = &self.reference_hash {
require!(reference_hash.0.len() == 32, "Reference hash has to be 32 bytes");
}
}
}