diff --git a/mover/jy00566722/images/l.jpg b/mover/jy00566722/images/l.jpg new file mode 100644 index 000000000..08225ae38 Binary files /dev/null and b/mover/jy00566722/images/l.jpg differ diff --git a/mover/jy00566722/images/qb.jpg b/mover/jy00566722/images/qb.jpg new file mode 100644 index 000000000..f43f43181 Binary files /dev/null and b/mover/jy00566722/images/qb.jpg differ diff --git a/mover/jy00566722/readme.md b/mover/jy00566722/readme.md new file mode 100644 index 000000000..131418c9f --- /dev/null +++ b/mover/jy00566722/readme.md @@ -0,0 +1,56 @@ +## 基本信息 +- Sui钱包地址: `0x206b9158544c454f66f3022c1f88f0392f96d6bda91f69646835aad8c294c395` +> 首次参与需要完成第一个任务注册好钱包地址才被合并,并且后续学习奖励会打入这个地址 +- github: `jy00566722` + +## 个人简介 +- 工作经验: 5年 +- 技术栈: `Golang` `Javascript` `Vue` `React` +> 重要提示 请认真写自己的简介 +- 主要开发chrome插件,后端主要使用golang,前端用vue,目前在转react。通过Move入门区块链,目前的想法:通过Sui的NFT与POD相结合,销售个性化产品,这是链上与线下的结合,我认为会有市场。 +- 联系方式: tg: `https://t.me/oelitt` + +## 任务 + +## 01 hello move +- [✓] Sui cli version: sui 1.38.3-homebrew +- [✓] Sui钱包截图: ![Sui钱包截图](./images/qb.jpg) +- [✓] package id: 0x303a06616ce8472c1af56b224fb916d7b1ff2bf078663d572cad1e3a94d3e3a5 +- [✓] package id 在 scan上的查看截图:![Scan截图](./images/l.jpg) + +## 02 move coin +- [✓] My Coin package id : +- [✓] Faucet package id : +- [✓] 转账 `My Coin` hash: +- [✓] `Faucet Coin` address1 mint hash: +- [✓] `Faucet Coin` address2 mint hash: + + +## 03 move NFT +- [✓] nft package id : +- [✓] nft object id : +- [✓] 转账 nft hash: +- [✓] scan上的NFT截图:![Scan截图](./images/nft.jpg) + +## 04 Move Game +- [✓] game package id : +- [✓] deposit Coin hash: +- [✓] withdraw `Coin` hash: +- [✓] play game hash: + +## 05 Move Swap +- [✓] swap package id : +- [✓] call swap CoinA-> CoinB hash : +- [✓] call swap CoinB-> CoinA hash : + +## 06 Dapp-kit SDK PTB +- [✓] save hash : + +## 07 Move CTF Check In +- [✓] CLI call 截图 : ![截图](./images/check_in.jpg) +- [✓] flag hash : + + +## 08 Move CTF Lets Move +- [✓] proof : 0x0000000001ba4714 +- [✓] flag hash : diff --git a/mover/jy00566722/task1/hello_move/Move.lock b/mover/jy00566722/task1/hello_move/Move.lock new file mode 100644 index 000000000..6261cc160 --- /dev/null +++ b/mover/jy00566722/task1/hello_move/Move.lock @@ -0,0 +1,34 @@ +# @generated by Move, please check-in and do not edit manually. + +[move] +version = 3 +manifest_digest = "8B7DC3EDF1D81F9E2D46D8251E70F4B8D7097878F02438454C30AEF9F05D81D0" +deps_digest = "F8BBB0CCB2491CA29A3DF03D6F92277A4F3574266507ACD77214D37ECA3F3082" +dependencies = [ + { id = "Sui", name = "Sui" }, +] + +[[move.package]] +id = "MoveStdlib" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/move-stdlib" } + +[[move.package]] +id = "Sui" +source = { git = "https://github.com/MystenLabs/sui.git", rev = "framework/testnet", subdir = "crates/sui-framework/packages/sui-framework" } + +dependencies = [ + { id = "MoveStdlib", name = "MoveStdlib" }, +] + +[move.toolchain-version] +compiler-version = "1.38.3" +edition = "2024.beta" +flavor = "sui" + +[env] + +[env.testnet] +chain-id = "4c78adac" +original-published-id = "0x303a06616ce8472c1af56b224fb916d7b1ff2bf078663d572cad1e3a94d3e3a5" +latest-published-id = "0x303a06616ce8472c1af56b224fb916d7b1ff2bf078663d572cad1e3a94d3e3a5" +published-version = "1" diff --git a/mover/jy00566722/task1/hello_move/Move.toml b/mover/jy00566722/task1/hello_move/Move.toml new file mode 100644 index 000000000..f99a76a8d --- /dev/null +++ b/mover/jy00566722/task1/hello_move/Move.toml @@ -0,0 +1,37 @@ +[package] +name = "hello_move" +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] +hello_move = "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/jy00566722/task1/hello_move/sources/hello_move.move b/mover/jy00566722/task1/hello_move/sources/hello_move.move new file mode 100644 index 000000000..56c1e3a20 --- /dev/null +++ b/mover/jy00566722/task1/hello_move/sources/hello_move.move @@ -0,0 +1,19 @@ +module hello_move::hello { + use std::ascii::{String, string}; + use sui::object::{Self,UID}; + use sui::transfer::transfer; + use sui::tx_context::{TxContext, sender}; + + public struct Hello has key{ + id:UID, + say: String + } + + fun init(ctx: &mut TxContext) { + let hello_move = Hello { + id:object::new(ctx), + say: string(b"jy00566722"), + }; + transfer(hello_move, sender(ctx)); + } +} \ No newline at end of file diff --git a/mover/jy00566722/task1/hello_move/tests/hello_move_tests.move b/mover/jy00566722/task1/hello_move/tests/hello_move_tests.move new file mode 100644 index 000000000..7798d8dda --- /dev/null +++ b/mover/jy00566722/task1/hello_move/tests/hello_move_tests.move @@ -0,0 +1,18 @@ +/* +#[test_only] +module hello_move::hello_move_tests; +// uncomment this line to import the module +// use hello_move::hello_move; + +const ENotImplemented: u64 = 0; + +#[test] +fun test_hello_move() { + // pass +} + +#[test, expected_failure(abort_code = ::hello_move::hello_move_tests::ENotImplemented)] +fun test_hello_move_fail() { + abort ENotImplemented +} +*/