near-non-transferrable-token

Crates.ionear-non-transferrable-token
lib.rsnear-non-transferrable-token
version0.0.4
sourcesrc
created_at2022-09-19 13:52:05.713193
updated_at2022-12-08 08:52:18.143034
descriptionNEAR smart contracts library.
homepagehttps://popula.io
repositoryhttps://github.com/beepopula/near-non-transferrable-token
max_upload_size
id669155
size47,036
Jimmy Bai (bhc8521)

documentation

README

near-non-transferrable-token

Popula Library for Non-transferrable Token.

Crates.io version Download Reference Documentation

Example

use near_non_transferrable_token::{impl_fungible_token_core, impl_fungible_token_storage};

#[near_bindgen]
impl Contract {
    #[init]
    pub fn new(
        owner_id: AccountId,
        metadata: FungibleTokenMetadata,
    ) -> Self {
        assert!(!env::state_exists(), "Already initialized");
        metadata.assert_valid();
        let mut this = Self {
            token: FungibleToken::new(b"a".to_vec()),
            metadata: LazyOption::new(b"m".to_vec(), Some(&metadata)),
            owner_id,
            white_list: HashSet::new()
        };
        this
    }
}

impl_fungible_token_core!(Contract, token);
impl_fungible_token_storage!(Contract, token);


#[near_bindgen]
impl FungibleTokenMetadataProvider for Contract {
    fn ft_metadata(&self) -> FungibleTokenMetadata {
        self.metadata.get().unwrap()
    }
}

See https://github.com/beepopula/Drip-contract for more details.

Features

Account Book

Separate Balances for different contracts:

#[derive(BorshDeserialize, BorshSerialize)]
pub struct Account {
    pub contract_ids: UnorderedMap<Option<AccountId>, Balance>,
    pub deposit_map: UnorderedMap<AccountId, HashMap<Option<AccountId>, Balance>>  //key: specific community drip
}

NOTES:

  • If the key for contract_ids is None then it represent the sum of Balance.
  • Deposit is a derivative function for proving that you have such balance for only once, preventing infinite proving. And the ownership should remain the same.

Versioning

Semantic Versioning

This crate follows Cargo's semver guidelines.

State breaking changes (low-level serialization format of any data type) will be avoided at all costs. If a change like this were to happen, it would come with a major version and come with a compiler error. If you encounter one that does not, open an issue!

MSRV

The minimum supported Rust version is currently 1.56. There are no guarantees that this will be upheld if a security patch release needs to come in that requires a Rust toolchain increase.

Commit count: 0

cargo fmt