-
Notifications
You must be signed in to change notification settings - Fork 3.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[move-examples] pre-minted managed FA
- Loading branch information
Showing
14 changed files
with
229 additions
and
216 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
# Fungible Asset | ||
|
||
* Managed fungible asset: A full-fledged fungible asset with customizable management capabilities and associated functions, based on which a light example is provided to show how to issue coin. | ||
* Managed fungible token: A fungible token example that adds token resource to the metadata object. | ||
* Simple managed coin: an all-in-one module implementing managed coin using fungible asset with limited functionalities (only deal with primary fungible stores). | ||
* Pre-minted managed coin: An example issuing pre-minting coin based on managed fungible asset. |
12 changes: 12 additions & 0 deletions
12
aptos-move/move-examples/fungible_asset/managed_fungible_asset/Move.toml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
[package] | ||
name = "ManagedFungibleAsset" | ||
version = "0.0.0" | ||
|
||
[addresses] | ||
aptos_framework = "0x1" | ||
aptos_token_objects = "0x4" | ||
example_addr = "_" | ||
|
||
[dependencies] | ||
AptosFramework = { local = "../../../framework/aptos-framework" } | ||
AptosTokenObjects = { local = "../../../framework/aptos-token-objects" } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
13 changes: 13 additions & 0 deletions
13
aptos-move/move-examples/fungible_asset/managed_fungible_token/Move.toml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
[package] | ||
name = "ManagedFungibleToken" | ||
version = "0.0.0" | ||
|
||
[addresses] | ||
aptos_framework = "0x1" | ||
aptos_token_objects = "0x4" | ||
example_addr = "_" | ||
|
||
[dependencies] | ||
AptosFramework = { local = "../../../framework/aptos-framework" } | ||
AptosTokenObjects = { local = "../../../framework/aptos-token-objects" } | ||
ManagedFungibleAsset = { local = "../managed_fungible_asset" } |
63 changes: 63 additions & 0 deletions
63
...e/move-examples/fungible_asset/managed_fungible_token/sources/managed_fungible_token.move
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
/// An example combining fungible assets with token as fungible token. In this example, a token object is used as | ||
/// metadata to create fungible units, aka, fungible tokens. | ||
module example_addr::managed_fungible_token { | ||
use aptos_framework::fungible_asset::Metadata; | ||
use aptos_framework::object::{Self, Object}; | ||
use std::string::{utf8, String}; | ||
use std::option; | ||
use aptos_token_objects::token::{create_named_token, create_token_seed}; | ||
use aptos_token_objects::collection::create_fixed_collection; | ||
use example_addr::managed_fungible_asset; | ||
|
||
const ASSET_SYMBOL: vector<u8> = b"YOLO"; | ||
|
||
/// Initialize metadata object and store the refs. | ||
fun init_module(admin: &signer) { | ||
let collection_name: String = utf8(b"test collection name"); | ||
let token_name: String = utf8(b"test token name"); | ||
create_fixed_collection( | ||
admin, | ||
utf8(b"test collection description"), | ||
1, | ||
collection_name, | ||
option::none(), | ||
utf8(b"http://aptoslabs.com/collection"), | ||
); | ||
let constructor_ref = &create_named_token(admin, | ||
collection_name, | ||
utf8(b"test token description"), | ||
token_name, | ||
option::none(), | ||
utf8(b"http://aptoslabs.com/token"), | ||
); | ||
|
||
managed_fungible_asset::initialize( | ||
constructor_ref, | ||
0, /* maximum_supply. 0 means no maximum */ | ||
utf8(b"test fungible token"), /* name */ | ||
utf8(ASSET_SYMBOL), /* symbol */ | ||
0, /* decimals */ | ||
utf8(b"http://example.com/favicon.ico"), /* icon */ | ||
utf8(b"http://example.com"), /* project */ | ||
vector[true, true, true], /* mint_ref, transfer_ref, burn_ref */ | ||
); | ||
} | ||
|
||
#[view] | ||
/// Return the address of the managed fungible asset that's created when this module is deployed. | ||
/// This function is optional as a helper function for offline applications. | ||
public fun get_metadata(): Object<Metadata> { | ||
let collection_name: String = utf8(b"test collection name"); | ||
let token_name: String = utf8(b"test token name"); | ||
let asset_address = object::create_object_address( | ||
&@example_addr, | ||
create_token_seed(&collection_name, &token_name) | ||
); | ||
object::address_to_object<Metadata>(asset_address) | ||
} | ||
|
||
#[test(creator = @example_addr)] | ||
fun test_init(creator: &signer) { | ||
init_module(creator); | ||
} | ||
} |
11 changes: 11 additions & 0 deletions
11
aptos-move/move-examples/fungible_asset/preminted_managed_coin/Move.toml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
[package] | ||
name = "ManagedFungibleToken" | ||
version = "0.0.0" | ||
|
||
[addresses] | ||
aptos_framework = "0x1" | ||
example_addr = "_" | ||
|
||
[dependencies] | ||
AptosFramework = { local = "../../../framework/aptos-framework" } | ||
ManagedFungibleAsset = { local = "../managed_fungible_asset" } |
63 changes: 63 additions & 0 deletions
63
...e/move-examples/fungible_asset/preminted_managed_coin/sources/preminted_managed_coin.move
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
/// This module shows an example how to issue preminted coin with only `transfer` and `burn` managing capabilities. | ||
/// It leveraged `managed_fungible_asset` module with only `TransferRef` and `BurnRef` stored after pre-minting a | ||
/// pre-defined totally supply to a reserve account. After the initialization, the total supply can increase by no means | ||
/// since `MintRef` of this fungible asset does not exist anymore. | ||
/// The `init_module()` code can be modified to customize the managing refs as needed. | ||
module example_addr::preminted_managed_coin { | ||
use aptos_framework::fungible_asset::{Self, Metadata}; | ||
use aptos_framework::object::{Self, Object}; | ||
use aptos_framework::primary_fungible_store; | ||
use example_addr::managed_fungible_asset; | ||
use std::signer; | ||
use std::string::utf8; | ||
|
||
const ASSET_SYMBOL: vector<u8> = b"MEME"; | ||
const PRE_MINTED_TOTAL_SUPPLY: u64 = 10000; | ||
|
||
/// Initialize metadata object and store the refs. | ||
fun init_module(admin: &signer) { | ||
let constructor_ref = &object::create_named_object(admin, ASSET_SYMBOL); | ||
managed_fungible_asset::initialize( | ||
constructor_ref, | ||
1000000000, /* maximum_supply */ | ||
utf8(b"preminted coin"), /* name */ | ||
utf8(ASSET_SYMBOL), /* symbol */ | ||
8, /* decimals */ | ||
utf8(b"http://example.com/favicon.ico"), /* icon */ | ||
utf8(b"http://example.com"), /* project */ | ||
vector[false, true, true], /* mint_ref, transfer_ref, burn_ref */ | ||
); | ||
|
||
// Create mint ref to premint fungible asset with a fixed supply volume into a specific account. | ||
// This account can be any account including normal user account, resource account, multi-sig account, etc. | ||
// We just use the creator account to show the proof of concept. | ||
let mint_ref = fungible_asset::generate_mint_ref(constructor_ref); | ||
let admin_primary_store = primary_fungible_store::ensure_primary_store_exists( | ||
signer::address_of(admin), | ||
get_metadata() | ||
); | ||
fungible_asset::mint_to(&mint_ref, admin_primary_store, PRE_MINTED_TOTAL_SUPPLY); | ||
} | ||
|
||
#[view] | ||
/// Return the address of the metadata that's created when this module is deployed. | ||
/// This function is optional as a helper function for offline applications. | ||
public fun get_metadata(): Object<Metadata> { | ||
let metadata_address = object::create_object_address(&@example_addr, ASSET_SYMBOL); | ||
object::address_to_object<Metadata>(metadata_address) | ||
} | ||
|
||
#[test_only] | ||
use std::option; | ||
|
||
#[test(creator = @example_addr)] | ||
#[expected_failure(abort_code = 0x60004, location = example_addr::managed_fungible_asset)] | ||
fun test_basic_flow(creator: &signer) { | ||
init_module(creator); | ||
let creator_address = signer::address_of(creator); | ||
let metadata = get_metadata(); | ||
|
||
assert!(option::destroy_some(fungible_asset::supply(metadata)) == (PRE_MINTED_TOTAL_SUPPLY as u128), 1); | ||
managed_fungible_asset::mint_to_primary_stores(creator, metadata, vector[creator_address], vector[100]); | ||
} | ||
} |
4 changes: 2 additions & 2 deletions
4
...ve/move-examples/fungible_asset/Move.toml → ...gible_asset/simple_managed_coin/Move.toml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,10 @@ | ||
[package] | ||
name = "FungibleAsset" | ||
name = "SimpleManagedCoin" | ||
version = "0.0.0" | ||
|
||
[addresses] | ||
aptos_framework = "0x1" | ||
example_addr = "_" | ||
|
||
[dependencies] | ||
AptosFramework = { local = "../../framework/aptos-framework" } | ||
AptosFramework = { local = "../../../framework/aptos-framework" } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.