本教程介绍了如何编译、部署和铸造 Moon Coin 代币。
从 Git 安装 CLIarrow-up-right
克隆 aptos-core:
Copy git clone < https://github.com/aptos-labs/aptos-core.gi t > 第 3.1 步:SDK 特定示例
Typescript
导航至 Typescript SDK 目录:
Copy cd ~/aptos-core/ecosystem/typescript/sdk 安装必要的依赖项
运行 your_coin 示例:
Copy yarn your_coin ~/aptos-core/aptos-move/move-examples/moon_coin Python
导航至 Python SDK 目录:
Copy cd ~/aptos-core/ecosystem/python/sdk 安装必要的依赖项
Copy curl -sSL < https://install.python-poetry.or g > | python3
poetry update 运行 your_coin 示例:
Copy poetry run python -m examples.your-coin ~/aptos-core/aptos-move/move-examples/moon_coin 进行到一半时,demo 会暂停并显示以下输出:
此时,打开另一个终端并将目录更改为 MoonCoin 包的目录
现在使用 CLI 构建包:
--named-addresses 是一个必须转译的地址映射表,让编译后的软件包能够存储到 Alice 的帐户中。注意 MoonCoin 是如何被设置为上面显示的 Alice 地址的。另外,为了发布软件包,还需要 --save-metadata。
返回前面的提示,按回车键,现在软件包已经准备好发布了。
应用程序将完成,显示:
第 4 步:深入了解 MoonCoin
第 4.1 步:构建和发布 MoonCoin 包
Move 软件或合约实际上是一组被称为包的模块。在部署或升级一个新的软件包时,必须用 --save-metadata 来调用编译器,以便发布该软件包。在 MoonCoin 的案例中,以下输出文件是至关重要的:
build/Examples/package-metadata.bcs ——与软件包相关的元数据
build/Examples/bytecode_modules/moon_coin.mv —— moon_coin.move 模块的字节码
这些都由示例读取并发布到区块链上:
第 4.2 步:了解 MoonCoin 模块
MoonCoin 模块定义了 MoonCoin 结构,即不同的代币类型。此外,它还包含一个叫做 init_module 的函数。 init_module 在模块发布时被调用。在这种情况下,MoonCoin 将MoonCoin 币种初始化为 ManagedCoin,该币种由帐户所有者维护。[ManagedCoin](<https://github.com/aptos-labs/aptos-core/blob/f81ccb01f00227f9c0f36856fead4879f185a9f6/aptos-move/framework/aptos-framework/sources/managed_coin.move#L1>) 是一个简单的 代币管理框架,由用户直接管理代币。它为铸造和销毁提供了便捷的包装。
代币有几个基本要素:
冻结——阻止一个帐户在 CoinStore 中储存代币
注册——在一个帐户上创建一个用于存储代币的 CoinStore 资源
创建一个新代币的实体也有铸造、销毁和冻结代币的能力。
为了转移、提取或存入代币,必须有一个为特定代币注册的 CoinStore。在本教程中,这就是 CoinStore<MoonCoin>
第 4.3.1 步:初始化代币
一旦代币类型发布到区块链上,发布该代币的实体可以初始化代币:
这样可以确保这种代币类型之前未被初始化过,注意检查以确保初始化的调用者确实发布了这个模块,并且他们的帐户上没有存储 CoinInfo。如果这两个条件都符合,那么就会存储一个 CoinInfo,调用者就会获得销毁、冻结和铸造的能力。
MoonCoin 软件包发布时自动调用这个函数。
实体必须在他们的帐户上为代币注册一个 CoinStore 才能使用代币:
由于这是一个 public fun 而不是一个 public entry fun ,代币需要提供注册方式,或者用户可以构建 Move 脚本来调用该功能。
MoonCoin 使用 ManagedCoin,它提供了一个入口函数封装器:managed_coin::register
铸造代币需要初始化时产生的铸造能力。它接受该功能和数量并返回一个包含代币数量的 Coin<T> 结构。它将在代币跟踪供应时更新。
ManagedCoin 通过提供一个入口函数 managed_coin::mint 让这个过程变得更容易。
Aptos 提供了几个构建块来支持转移:
coin::deposit<CoinType>允许任何实体将代币存入已经调用 coin::register<CoinType> 的帐户
coin::withdraw<CoinType>允许任何实体从其帐户中提取代币金额
coin::transfer<CoinType>利用提款和存款来执行端到端的转账
Aptos 不会发出转账事件,而是利用提款和存款事件。