diff --git a/mover/0xhutou/code/task3/myfirstnft/Move.lock b/mover/0xhutou/code/task3/myfirstnft/Move.lock index 179404d2d..18218c2b1 100644 --- a/mover/0xhutou/code/task3/myfirstnft/Move.lock +++ b/mover/0xhutou/code/task3/myfirstnft/Move.lock @@ -21,7 +21,7 @@ dependencies = [ ] [move.toolchain-version] -compiler-version = "1.25.1" +compiler-version = "1.29.2" edition = "2024.beta" flavor = "sui" @@ -32,3 +32,9 @@ chain-id = "35834a8a" original-published-id = "0x700945ac0913a6f8659d0e440857fb74fa0959d9c7003501d8b311f7536978a8" latest-published-id = "0x700945ac0913a6f8659d0e440857fb74fa0959d9c7003501d8b311f7536978a8" published-version = "1" + +[env.testnet] +chain-id = "4c78adac" +original-published-id = "0x6e30e2e240c97917fd2b7c7ca5a591f2ca79e74fe2e1092b413687ea88adc230" +latest-published-id = "0x6e30e2e240c97917fd2b7c7ca5a591f2ca79e74fe2e1092b413687ea88adc230" +published-version = "1" diff --git a/mover/0xhutou/code/task3/myfirstnft/sources/myfirstnft.move b/mover/0xhutou/code/task3/myfirstnft/sources/myfirstnft.move index 4d9f487a9..188ce9e83 100644 --- a/mover/0xhutou/code/task3/myfirstnft/sources/myfirstnft.move +++ b/mover/0xhutou/code/task3/myfirstnft/sources/myfirstnft.move @@ -15,13 +15,6 @@ module myfirstnft::myfirstnft { /// One-Time-Witness for the module. public struct MYFIRSTNFT has drop {} - /// In the module initializer one claims the `Publisher` object - /// to then create a `Display`. The `Display` is initialized with - /// a set of fields (but can be modified later) and published via - /// the `update_version` call. - /// - /// Keys and values are set in the initializer but could also be - /// set after publishing if a `Publisher` object was created. fun init(otw: MYFIRSTNFT, ctx: &mut TxContext) { let keys = vector[ utf8(b"name"), diff --git a/mover/1pzq/code/task2/coinfacet/Move.lock b/mover/1pzq/code/task2/coinfacet/Move.lock new file mode 100644 index 000000000..6b976c14c --- /dev/null +++ b/mover/1pzq/code/task2/coinfacet/Move.lock @@ -0,0 +1,40 @@ +# @generated by Move, please check-in and do not edit manually. + +[move] +version = 2 +manifest_digest = "CB2C1B89FDD217A7F39235AF8A973C638FE27F14B1F262AF5A61F8DF4F7DBC8D" +deps_digest = "F8BBB0CCB2491CA29A3DF03D6F92277A4F3574266507ACD77214D37ECA3F3082" +dependencies = [ + { name = "Sui" }, +] + +[[move.package]] +name = "MoveStdlib" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/move-stdlib" } + +[[move.package]] +name = "Sui" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/sui-framework" } + +dependencies = [ + { name = "MoveStdlib" }, +] + +[move.toolchain-version] +compiler-version = "1.27.0" +edition = "2024.beta" +flavor = "sui" + +[env] + +[env.testnet] +chain-id = "4c78adac" +original-published-id = "0x1e82eb8bcd4886bd004861c034725449882d8a25a25c94b17d41bb950522e869" +latest-published-id = "0x1e82eb8bcd4886bd004861c034725449882d8a25a25c94b17d41bb950522e869" +published-version = "1" + +[env.mainnet] +chain-id = "35834a8a" +original-published-id = "0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb" +latest-published-id = "0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb" +published-version = "1" diff --git a/mover/1pzq/code/task2/coinfacet/Move.toml b/mover/1pzq/code/task2/coinfacet/Move.toml new file mode 100644 index 000000000..ba2122cfb --- /dev/null +++ b/mover/1pzq/code/task2/coinfacet/Move.toml @@ -0,0 +1,37 @@ +[package] +name = "coinfacet" +edition = "2024.beta" # edition = "legacy" to use legacy (pre-2024) Move +# license = "" # e.g., "MIT", "GPL", "Apache 2.0" +# authors = ["..."] # e.g., ["Joe Smith (joesmith@noemail.com)", "John Snow (johnsnow@noemail.com)"] + +[dependencies] +Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "framework/testnet" } + +# For remote import, use the `{ git = "...", subdir = "...", rev = "..." }`. +# Revision can be a branch, a tag, and a commit hash. +# MyRemotePackage = { git = "https://some.remote/host.git", subdir = "remote/path", rev = "main" } + +# For local dependencies use `local = path`. Path is relative to the package root +# Local = { local = "../path/to" } + +# To resolve a version conflict and force a specific version for dependency +# override use `override = true` +# Override = { local = "../conflicting/version", override = true } + +[addresses] +coinfacet = "0x0" + +# Named addresses will be accessible in Move as `@name`. They're also exported: +# for example, `std = "0x1"` is exported by the Standard Library. +# alice = "0xA11CE" + +[dev-dependencies] +# The dev-dependencies section allows overriding dependencies for `--test` and +# `--dev` modes. You can introduce test-only dependencies here. +# Local = { local = "../path/to/dev-build" } + +[dev-addresses] +# The dev-addresses section allows overwriting named addresses for the `--test` +# and `--dev` modes. +# alice = "0xB0B" + diff --git a/mover/1pzq/code/task2/coinfacet/sources/coinfacet.move b/mover/1pzq/code/task2/coinfacet/sources/coinfacet.move new file mode 100644 index 000000000..b646c2a20 --- /dev/null +++ b/mover/1pzq/code/task2/coinfacet/sources/coinfacet.move @@ -0,0 +1,36 @@ +/// Module: coinfacet +module coinfacet::coinfacet { + + use sui::coin::{Self, TreasuryCap}; + use sui::tx_context::TxContext; + + public struct COINFACET has drop {} + + fun init(witness: COINFACET, ctx: &mut TxContext) { + let (mint_id, metadata) = coin::create_currency(witness, 6, b"COINFACET", b"", b"", std::option::none(), ctx); + transfer::public_freeze_object(metadata); + transfer::public_share_object(mint_id) + } + + public entry fun mint( + treasury_cap: &mut TreasuryCap, + ctx: &mut TxContext, + ) { + let coinfacet_coin = coin::mint(treasury_cap, 10000000, ctx); + transfer::public_transfer(coinfacet_coin, tx_context::sender(ctx)) + } + +} +/* +Package: +0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb + + +TreasuryCap: +0x8d9061370db68049ef268ac8c9566f15b827a1dfbe19332872db45477af6cb94 +ObjectType: 0x2::coin::TreasuryCap<0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb::coinfacet::COINFACET> + +CoinMetadata: +0x46e95586f401866658384d5bfa363c49a886d25edcd95376ba7032b0272fbf45 +ObjectType: 0x2::coin::CoinMetadata<0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb::coinfacet::COINFACET> +*/ diff --git a/mover/1pzq/code/task2/coinfacet/tests/coinfacet_tests.move b/mover/1pzq/code/task2/coinfacet/tests/coinfacet_tests.move new file mode 100644 index 000000000..0ab88f9c1 --- /dev/null +++ b/mover/1pzq/code/task2/coinfacet/tests/coinfacet_tests.move @@ -0,0 +1,19 @@ +/* +#[test_only] +module coinfacet::coinfacet_tests { + // uncomment this line to import the module + // use coinfacet::coinfacet; + + const ENotImplemented: u64 = 0; + + #[test] + fun test_coinfacet() { + // pass + } + + #[test, expected_failure(abort_code = ::coinfacet::coinfacet_tests::ENotImplemented)] + fun test_coinfacet_fail() { + abort ENotImplemented + } +} +*/ diff --git a/mover/1pzq/code/task2/my_coin/Move.lock b/mover/1pzq/code/task2/my_coin/Move.lock new file mode 100644 index 000000000..8936f3fd4 --- /dev/null +++ b/mover/1pzq/code/task2/my_coin/Move.lock @@ -0,0 +1,40 @@ +# @generated by Move, please check-in and do not edit manually. + +[move] +version = 2 +manifest_digest = "0A4652D38CF3C3FDB79EC6C1C98FCFF7B2E933E12B84A1DA267DB28F66AFECE3" +deps_digest = "F8BBB0CCB2491CA29A3DF03D6F92277A4F3574266507ACD77214D37ECA3F3082" +dependencies = [ + { name = "Sui" }, +] + +[[move.package]] +name = "MoveStdlib" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/move-stdlib" } + +[[move.package]] +name = "Sui" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/sui-framework" } + +dependencies = [ + { name = "MoveStdlib" }, +] + +[move.toolchain-version] +compiler-version = "1.27.0" +edition = "2024.beta" +flavor = "sui" + +[env] + +[env.testnet] +chain-id = "4c78adac" +original-published-id = "0x4c88555871f8dff31216f31cbe925952bf54be64eba4efb8edbb8965dc07426d" +latest-published-id = "0x4c88555871f8dff31216f31cbe925952bf54be64eba4efb8edbb8965dc07426d" +published-version = "1" + +[env.mainnet] +chain-id = "35834a8a" +original-published-id = "0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b" +latest-published-id = "0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b" +published-version = "1" diff --git a/mover/1pzq/code/task2/Move.toml b/mover/1pzq/code/task2/my_coin/Move.toml similarity index 97% rename from mover/1pzq/code/task2/Move.toml rename to mover/1pzq/code/task2/my_coin/Move.toml index 6a6098d99..b9ca003f8 100644 --- a/mover/1pzq/code/task2/Move.toml +++ b/mover/1pzq/code/task2/my_coin/Move.toml @@ -1,5 +1,5 @@ [package] -name = "task2" +name = "my_coin" edition = "2024.beta" # edition = "legacy" to use legacy (pre-2024) Move # license = "" # e.g., "MIT", "GPL", "Apache 2.0" # authors = ["..."] # e.g., ["Joe Smith (joesmith@noemail.com)", "John Snow (johnsnow@noemail.com)"] @@ -19,7 +19,7 @@ Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-fram # Override = { local = "../conflicting/version", override = true } [addresses] -task2 = "0x0" +my_coin = "0x0" # Named addresses will be accessible in Move as `@name`. They're also exported: # for example, `std = "0x1"` is exported by the Standard Library. diff --git a/mover/1pzq/code/task2/my_coin/sources/my_coin.move b/mover/1pzq/code/task2/my_coin/sources/my_coin.move new file mode 100644 index 000000000..ca453219b --- /dev/null +++ b/mover/1pzq/code/task2/my_coin/sources/my_coin.move @@ -0,0 +1,40 @@ +// Module: my_coin +module my_coin::my_coin { + use std::option; + use sui::coin::{Self, Coin, TreasuryCap}; + use sui::transfer; + use sui::tx_context::{Self, TxContext}; + + public struct MY_COIN has drop {} + + fun init(witness: MY_COIN, ctx: &mut TxContext) { + let (treasury_cap, metadata) = coin::create_currency( + witness, + 2, + b"MY", + b"MYCOIN", + b"MY COIN", + option::none(), + ctx + ); + transfer::public_freeze_object(metadata); + transfer::public_transfer(treasury_cap, tx_context::sender(ctx)); + + } + + public entry fun mint(treasury_cap: &mut TreasuryCap, amount: u64, recipient: address, ctx: &mut TxContext){ + coin::mint_and_transfer(treasury_cap, amount, recipient, ctx); + } + + public entry fun burn(treasury_cap: &mut TreasuryCap, coin: Coin) { + coin::burn(treasury_cap, coin); + } +} + +/* +Package 0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b +CoinMetadata 0xb5cbfad7b7b25d6c671b5f449ea5c3e90c743659970291914e1b56d1ff204962 +ObjectType: 0x2::coin::CoinMetadata<0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b::my_coin::MY_COIN> │ +TreasuryCap 0xd6133909f2e796df397d5826ee6c0375ed4e743ee1ba38f7bf26f06f607983fa +ObjectType: 0x2::coin::TreasuryCap<0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b::my_coin::MY_COIN> │ │ +*/ \ No newline at end of file diff --git a/mover/1pzq/code/task2/my_coin/tests/my_coin_tests.move b/mover/1pzq/code/task2/my_coin/tests/my_coin_tests.move new file mode 100644 index 000000000..4be556acf --- /dev/null +++ b/mover/1pzq/code/task2/my_coin/tests/my_coin_tests.move @@ -0,0 +1,19 @@ +/* +#[test_only] +module my_coin::my_coin_tests { + // uncomment this line to import the module + // use my_coin::my_coin; + + const ENotImplemented: u64 = 0; + + #[test] + fun test_my_coin() { + // pass + } + + #[test, expected_failure(abort_code = ::my_coin::my_coin_tests::ENotImplemented)] + fun test_my_coin_fail() { + abort ENotImplemented + } +} +*/ diff --git a/mover/1pzq/code/task2/sources/task2.move b/mover/1pzq/code/task2/sources/task2.move deleted file mode 100644 index 2f21721a7..000000000 --- a/mover/1pzq/code/task2/sources/task2.move +++ /dev/null @@ -1,7 +0,0 @@ -/* -/// Module: task2 -module task2::task2 { - -} -*/ - diff --git a/mover/1pzq/code/task2/tests/task2_tests.move b/mover/1pzq/code/task2/tests/task2_tests.move deleted file mode 100644 index 81e8c886d..000000000 --- a/mover/1pzq/code/task2/tests/task2_tests.move +++ /dev/null @@ -1,19 +0,0 @@ -/* -#[test_only] -module task2::task2_tests { - // uncomment this line to import the module - // use task2::task2; - - const ENotImplemented: u64 = 0; - - #[test] - fun test_task2() { - // pass - } - - #[test, expected_failure(abort_code = ::task2::task2_tests::ENotImplemented)] - fun test_task2_fail() { - abort ENotImplemented - } -} -*/ diff --git a/mover/1pzq/code/task3/my_nft/Move.lock b/mover/1pzq/code/task3/my_nft/Move.lock new file mode 100644 index 000000000..1e6c285db --- /dev/null +++ b/mover/1pzq/code/task3/my_nft/Move.lock @@ -0,0 +1,40 @@ +# @generated by Move, please check-in and do not edit manually. + +[move] +version = 2 +manifest_digest = "9787EC7B3F0B631FD328C6E69F0E6D1B03DD3363C3819C95ACE51411F0B92394" +deps_digest = "F8BBB0CCB2491CA29A3DF03D6F92277A4F3574266507ACD77214D37ECA3F3082" +dependencies = [ + { name = "Sui" }, +] + +[[move.package]] +name = "MoveStdlib" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/move-stdlib" } + +[[move.package]] +name = "Sui" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/sui-framework" } + +dependencies = [ + { name = "MoveStdlib" }, +] + +[move.toolchain-version] +compiler-version = "1.29.2" +edition = "2024.beta" +flavor = "sui" + +[env] + +[env.testnet] +chain-id = "4c78adac" +original-published-id = "0x2248d5ab22fd89d3790742f6182307f53b3c42872e4b28147e8c749808ecf67e" +latest-published-id = "0x2248d5ab22fd89d3790742f6182307f53b3c42872e4b28147e8c749808ecf67e" +published-version = "1" + +[env.mainnet] +chain-id = "35834a8a" +original-published-id = "0xae98f7099f2417d0a32e1089d6ea36f138926a62a7eba85f57cda01815a530cf" +latest-published-id = "0xae98f7099f2417d0a32e1089d6ea36f138926a62a7eba85f57cda01815a530cf" +published-version = "1" diff --git a/mover/1pzq/code/task3/my_nft/Move.toml b/mover/1pzq/code/task3/my_nft/Move.toml new file mode 100644 index 000000000..5d27afceb --- /dev/null +++ b/mover/1pzq/code/task3/my_nft/Move.toml @@ -0,0 +1,38 @@ +[package] +name = "my_nft" +edition = "2024.beta" # edition = "legacy" to use legacy (pre-2024) Move +# license = "" # e.g., "MIT", "GPL", "Apache 2.0" +# authors = ["..."] # e.g., ["Joe Smith (joesmith@noemail.com)", "John Snow (johnsnow@noemail.com)"] + +[dependencies] +Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "framework/testnet" } + +# For remote import, use the `{ git = "...", subdir = "...", rev = "..." }`. +# Revision can be a branch, a tag, and a commit hash. +# MyRemotePackage = { git = "https://some.remote/host.git", subdir = "remote/path", rev = "main" } + +# For local dependencies use `local = path`. Path is relative to the package root +# Local = { local = "../path/to" } + +# To resolve a version conflict and force a specific version for dependency +# override use `override = true` +# Override = { local = "../conflicting/version", override = true } + +[addresses] +my_nft = "0x0" +nft_protocol = "0xbdd1811dd6e8feb2c7311d193bbf92cb45d3d6a8fb2b6ec60dc19adf20c18796" + +# Named addresses will be accessible in Move as `@name`. They're also exported: +# for example, `std = "0x1"` is exported by the Standard Library. +# alice = "0xA11CE" + +[dev-dependencies] +# The dev-dependencies section allows overriding dependencies for `--test` and +# `--dev` modes. You can introduce test-only dependencies here. +# Local = { local = "../path/to/dev-build" } + +[dev-addresses] +# The dev-addresses section allows overwriting named addresses for the `--test` +# and `--dev` modes. +# alice = "0xB0B" + diff --git a/mover/1pzq/code/task3/my_nft/sources/kite.move b/mover/1pzq/code/task3/my_nft/sources/kite.move new file mode 100644 index 000000000..9dd1b3496 --- /dev/null +++ b/mover/1pzq/code/task3/my_nft/sources/kite.move @@ -0,0 +1,74 @@ +module my_nft::kite { + use sui::tx_context::{sender, TxContext}; + use std::string::{utf8, String}; + use sui::transfer::public_transfer; + use sui::object::UID; + + use sui::package; + use sui::display; + + public struct Hero has key, store { + id: UID, + name: String, + image_url: String, + } + + public struct KITE has drop {} + + fun init(otw: KITE, ctx: &mut TxContext) { + let keys = vector[ + utf8(b"name"), + utf8(b"link"), + utf8(b"image_url"), + utf8(b"description"), + utf8(b"project_url"), + utf8(b"creator"), + ]; + + let values = vector[ + utf8(b"{name}"), + utf8(b"https://sui-heroes.io/hero/{id}"), + utf8(b"{image_url}"), + utf8(b"A true Hero of the Sui ecosystem!"), + utf8(b"https://sui-heroes.io"), + utf8(b"Unknown Sui Fan") + ]; + + let publisher = package::claim(otw, ctx); + + let mut display = display::new_with_fields( + &publisher, keys, values, ctx + ); + + display::update_version(&mut display); + + public_transfer(publisher, sender(ctx)); + public_transfer(display, sender(ctx)); + } + + public fun mint(name: String, image_url: String, ctx: &mut TxContext) { + let id = object::new(ctx); + transfer::public_transfer(Hero { id, name, image_url },sender(ctx)) + } + + public entry fun transfer_nft( + nft: Hero, + recipient: address, + _: &mut TxContext + ) { + transfer::public_transfer(nft, recipient); + } +} +/* +Transaction Digest: 41qRoqcNHKga4Pe5omDX1YXogBBecoWEuZ59f2WqnUZA + PackageID + +0xae98f7099f2417d0a32e1089d6ea36f138926a62a7eba85f57cda01815a530cf + +minthash 9nzkgf24R5orUQ62QUBADoQ9dMfmV4pcy78GvxscStmx + objectID1 0xb92d62ee0a1c32b128404dba3c79216d7de2e310f3210e4ab767845ce89e8215 + + + transferhash 94FEeT5PqGQcXL7dH9LRQzp4KszhRzwB9EhzZQFYPaC9 + +*/ \ No newline at end of file diff --git a/mover/1pzq/code/task3/my_nft/sources/my_nft.move b/mover/1pzq/code/task3/my_nft/sources/my_nft.move new file mode 100644 index 000000000..e54e2654a --- /dev/null +++ b/mover/1pzq/code/task3/my_nft/sources/my_nft.move @@ -0,0 +1,6 @@ +/* +/// Module: my_nft +module my_nft::my_nft { + +} +*/ diff --git a/mover/1pzq/code/task3/my_nft/tests/my_nft_tests.move b/mover/1pzq/code/task3/my_nft/tests/my_nft_tests.move new file mode 100644 index 000000000..5d3a60230 --- /dev/null +++ b/mover/1pzq/code/task3/my_nft/tests/my_nft_tests.move @@ -0,0 +1,19 @@ +/* +#[test_only] +module my_nft::my_nft_tests { + // uncomment this line to import the module + // use my_nft::my_nft; + + const ENotImplemented: u64 = 0; + + #[test] + fun test_my_nft() { + // pass + } + + #[test, expected_failure(abort_code = ::my_nft::my_nft_tests::ENotImplemented)] + fun test_my_nft_fail() { + abort ENotImplemented + } +} +*/ diff --git a/mover/1pzq/images/task21.jpg b/mover/1pzq/images/task21.jpg new file mode 100644 index 000000000..e9b50c4c4 Binary files /dev/null and b/mover/1pzq/images/task21.jpg differ diff --git a/mover/1pzq/images/task22.jpg b/mover/1pzq/images/task22.jpg new file mode 100644 index 000000000..062ed5aa8 Binary files /dev/null and b/mover/1pzq/images/task22.jpg differ diff --git a/mover/1pzq/images/task31.png b/mover/1pzq/images/task31.png new file mode 100644 index 000000000..abc7a2bd0 Binary files /dev/null and b/mover/1pzq/images/task31.png differ diff --git a/mover/1pzq/readme.md b/mover/1pzq/readme.md index b218c7f67..1e668e8b8 100644 --- a/mover/1pzq/readme.md +++ b/mover/1pzq/readme.md @@ -19,17 +19,17 @@ - [x] package id 在 scan上的查看截图:![Scan截图](./images/task11.jpg) ## 02 move coin -- [] My Coin package id : -- [] Faucet package id : -- [] 转账 `My Coin` hash: -- [] `Faucet Coin` address1 mint hash: -- [] `Faucet Coin` address2 mint hash: +- [x] My Coin package id : 0xe9f70ff13eefa964cdd63460da595d87048f974d62cb9aa92adcebc57998043b +- [x] Faucet package id : 0x7840c8e3c523f0a2f4e8795ff7ab8269eeda12be297b54f9ed9ce80aa178bccb +- [x] 转账 `My Coin` hash:6CrDweobAXtiFqnQPc8HJdT9j6Gz28FMFzwwdQkvD6fx +- [x] `Faucet Coin` address1 mint hash:9dBmnUmXD5Ry5daYaV7LvKD7TT7wjdZNYhdiaFqPn2Nq +- [x] `Faucet Coin` address2 mint hash:DDnCwMynRpA6Ns8zgd93AQXrfnGAGk3PB23LjQFBMBTL ## 03 move NFT -- [] nft package id : -- [] nft object id : -- [] 转账 nft hash: -- [] scan上的NFT截图:![Scan截图](./images/你的图片地址) +- [x] nft package id :0xae98f7099f2417d0a32e1089d6ea36f138926a62a7eba85f57cda01815a530cf +- [x] nft object id : 0xb92d62ee0a1c32b128404dba3c79216d7de2e310f3210e4ab767845ce89e8215 +- [x] 转账 nft hash:94FEeT5PqGQcXL7dH9LRQzp4KszhRzwB9EhzZQFYPaC9 +- [x] scan上的NFT截图:![Scan截图](./images/task31.png) ## 04 Move Game - [] game package id :