-
Notifications
You must be signed in to change notification settings - Fork 888
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2127 from Heemale/main
feat: finish task5,6,7 and add follow images.
- Loading branch information
Showing
51 changed files
with
7,574 additions
and
3 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
[package] | ||
name = "task5" | ||
edition = "2024.beta" # edition = "legacy" to use legacy (pre-2024) Move | ||
# license = "" # e.g., "MIT", "GPL", "Apache 2.0" | ||
# authors = ["..."] # e.g., ["Joe Smith ([email protected])", "John Snow ([email protected])"] | ||
|
||
[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] | ||
task5 = "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" | ||
|
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,49 @@ | ||
module task5::faucet_coin { | ||
|
||
use std::string; | ||
use sui::coin::{Self, TreasuryCap}; | ||
use sui::url; | ||
|
||
public struct FAUCET_COIN has drop {} | ||
|
||
fun init(witness: FAUCET_COIN, ctx: &mut TxContext) { | ||
let (treasury, meta_data) = coin::create_currency<FAUCET_COIN>( | ||
witness, | ||
6, | ||
b"Heemale Faucet", | ||
b"Heemale Faucet Coin", | ||
b"相信的心是我们的魔法", | ||
option::some( | ||
url::new_unsafe( | ||
string::to_ascii( | ||
string::utf8( | ||
b"https://avatars.githubusercontent.com/u/57651639?s=400&u=25e8d8a5c8eed5d1408617994c5d8ea8ec0ac5c2&v=4" | ||
) | ||
) | ||
) | ||
), | ||
ctx | ||
); | ||
|
||
transfer::public_share_object(treasury); | ||
transfer::public_freeze_object(meta_data); | ||
} | ||
|
||
entry fun mint( | ||
treasury_cap: &mut TreasuryCap<FAUCET_COIN>, | ||
amount: u64, | ||
recipient: address, | ||
ctx: &mut TxContext | ||
) { | ||
let coin = coin::mint(treasury_cap, amount, ctx); | ||
transfer::public_transfer(coin, recipient); | ||
} | ||
|
||
// === Testing === | ||
|
||
#[test_only] | ||
public fun init_for_testing(ctx: &mut TxContext){ | ||
let witness = FAUCET_COIN {}; | ||
init(witness, ctx); | ||
} | ||
} |
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,49 @@ | ||
module task5::my_coin { | ||
|
||
use std::string; | ||
use sui::coin::{Self, TreasuryCap}; | ||
use sui::url; | ||
|
||
public struct MY_COIN has drop {} | ||
|
||
fun init(witness: MY_COIN, ctx: &mut TxContext) { | ||
let (treasury, meta_data) = coin::create_currency<MY_COIN>( | ||
witness, | ||
6, | ||
b"Heemale", | ||
b"Heemale Coin", | ||
b"相信的心是我们的魔法", | ||
option::some( | ||
url::new_unsafe( | ||
string::to_ascii( | ||
string::utf8( | ||
b"https://avatars.githubusercontent.com/u/57651639?s=400&u=25e8d8a5c8eed5d1408617994c5d8ea8ec0ac5c2&v=4" | ||
) | ||
) | ||
) | ||
), | ||
ctx | ||
); | ||
|
||
transfer::public_transfer(treasury, tx_context::sender(ctx)); | ||
transfer::public_freeze_object(meta_data); | ||
} | ||
|
||
entry fun mint( | ||
treasury_cap: &mut TreasuryCap<MY_COIN>, | ||
amount: u64, | ||
recipient: address, | ||
ctx: &mut TxContext | ||
) { | ||
let coin = coin::mint(treasury_cap, amount, ctx); | ||
transfer::public_transfer(coin, recipient); | ||
} | ||
|
||
// === Testing === | ||
|
||
#[test_only] | ||
public fun init_for_testing(ctx: &mut TxContext){ | ||
let witness = MY_COIN {}; | ||
init(witness, ctx); | ||
} | ||
} |
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,66 @@ | ||
module task5::swap { | ||
|
||
use sui::coin::{Self, Coin}; | ||
use sui::balance::{Self, Balance}; | ||
|
||
const ETreasuryNotEnough: u64 = 0; | ||
|
||
public struct Treasury<phantom T, phantom V> has key { | ||
id: UID, | ||
coin_a: Balance<T>, | ||
coin_b: Balance<V>, | ||
} | ||
|
||
public fun new<T, V>(ctx: &mut TxContext) { | ||
let treasury = Treasury { | ||
id: object::new(ctx), | ||
coin_a: balance::zero<T>(), | ||
coin_b: balance::zero<V>(), | ||
}; | ||
transfer::share_object(treasury); | ||
} | ||
|
||
public fun add_liquidity<T, V>(treasury: &mut Treasury<T, V>, coin_a: Coin<T>, coin_b: Coin<V>) { | ||
let (treasury_coin_a, treasury_coin_b) = get_coin_mut<T, V>(treasury); | ||
balance::join(treasury_coin_a, coin::into_balance(coin_a)); | ||
balance::join(treasury_coin_b, coin::into_balance(coin_b)); | ||
} | ||
|
||
public fun swap_a_to_b<T, V>(treasury: &mut Treasury<T, V>, coin_a: Coin<T>, ctx: &mut TxContext): Coin<V> { | ||
let (treasury_coin_a, treasury_coin_b) = get_coin_mut<T, V>(treasury); | ||
|
||
let coin_value = coin::value(&coin_a); | ||
let treasury_coin_b_value = balance::value(treasury_coin_b); | ||
assert!(treasury_coin_b_value >= coin_value, ETreasuryNotEnough); | ||
|
||
balance::join(treasury_coin_a, coin::into_balance(coin_a)); | ||
|
||
let balance_out = balance::split(treasury_coin_b, coin_value); | ||
let coin_out = coin::from_balance(balance_out, ctx); | ||
|
||
coin_out | ||
} | ||
|
||
public fun swap_b_to_a<T, V>(treasury: &mut Treasury<T, V>, coin_b: Coin<V>, ctx: &mut TxContext): Coin<T> { | ||
let (treasury_coin_a, treasury_coin_b) = get_coin_mut<T, V>(treasury); | ||
|
||
let coin_value = coin::value(&coin_b); | ||
let treasury_coin_a_value = balance::value(treasury_coin_a); | ||
assert!(treasury_coin_a_value >= coin_value, ETreasuryNotEnough); | ||
|
||
balance::join(treasury_coin_b, coin::into_balance(coin_b)); | ||
|
||
let balance_out = balance::split(treasury_coin_a, coin_value); | ||
let coin_out = coin::from_balance(balance_out, ctx); | ||
|
||
coin_out | ||
} | ||
|
||
public(package) fun get_coin_mut<T, V>(treasury: &mut Treasury<T, V>): (&mut Balance<T>, &mut Balance<V>) { | ||
(&mut treasury.coin_a, &mut treasury.coin_b) | ||
} | ||
|
||
public(package) fun get_coin<T, V>(treasury: &Treasury<T, V>): (&Balance<T>, &Balance<V>) { | ||
(&treasury.coin_a, &treasury.coin_b) | ||
} | ||
} |
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,107 @@ | ||
#[test_only] | ||
module task5::test_swap { | ||
use sui::test_scenario::{Self, ctx}; | ||
use sui::coin::{TreasuryCap, Coin}; | ||
use sui::balance::{Self}; | ||
|
||
use task5::faucet_coin::{Self, FAUCET_COIN}; | ||
use task5::my_coin::{Self, MY_COIN}; | ||
use task5::swap::{Self, Treasury}; | ||
|
||
const ADMIN: address = @0xA; | ||
|
||
#[test] | ||
fun process_for_testing() { | ||
let mut scenario = test_scenario::begin(ADMIN); | ||
|
||
// 初始化代币a合约和代币b合约 | ||
{ | ||
faucet_coin::init_for_testing(ctx(&mut scenario)); | ||
my_coin::init_for_testing(ctx(&mut scenario)); | ||
}; | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
|
||
// 获取代币a铸币权 | ||
let mut treasury_cap_a = test_scenario::take_shared<TreasuryCap<FAUCET_COIN>>(&scenario); | ||
// 获取代币b铸币权 | ||
let mut treasury_cap_b = test_scenario::take_from_address<TreasuryCap<MY_COIN>>(&scenario, ADMIN); | ||
|
||
// 创建库存 | ||
swap::new<FAUCET_COIN, MY_COIN>(ctx(&mut scenario)); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 铸造代币a | ||
faucet_coin::mint(&mut treasury_cap_a, 100_000_000_000, ADMIN, ctx(&mut scenario)); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 铸造代币b | ||
my_coin::mint(&mut treasury_cap_b, 100_000_000_000, ADMIN, ctx(&mut scenario)); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
|
||
// 获取库存对象 | ||
let mut treasury = test_scenario::take_shared<Treasury<FAUCET_COIN, MY_COIN>>(&scenario); | ||
// 获取代币a | ||
let despoit_coin_a = test_scenario::take_from_address<Coin<FAUCET_COIN>>(&scenario, ADMIN); | ||
// 获取代币b | ||
let despoit_coin_b = test_scenario::take_from_address<Coin<MY_COIN>>(&scenario, ADMIN); | ||
|
||
// === add_liquidity === | ||
|
||
// 添加流动性 | ||
swap::add_liquidity<FAUCET_COIN, MY_COIN>( | ||
&mut treasury, | ||
despoit_coin_a, | ||
despoit_coin_b, | ||
); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 查看资金 | ||
{ | ||
let (treasury_coin_a, treasury_coin_b) = swap::get_coin_mut<FAUCET_COIN, MY_COIN>(&mut treasury); | ||
assert!(balance::value(treasury_coin_a) == 100_000_000_000, 0); | ||
assert!(balance::value(treasury_coin_b) == 100_000_000_000, 0); | ||
}; | ||
|
||
// === swap_a_to_b === | ||
|
||
// 获取代币a | ||
faucet_coin::mint(&mut treasury_cap_a, 100, ADMIN, ctx(&mut scenario)); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 获取代币a | ||
let input_coin_a = test_scenario::take_from_address<Coin<FAUCET_COIN>>(&scenario, ADMIN); | ||
// 代币a兑换代币b | ||
{ | ||
let out_coin = swap::swap_a_to_b<FAUCET_COIN, MY_COIN>(&mut treasury, input_coin_a, ctx(&mut scenario)); | ||
transfer::public_transfer(out_coin, ADMIN); | ||
}; | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 查看资金 | ||
{ | ||
let (treasury_coin_a, treasury_coin_b) = swap::get_coin_mut<FAUCET_COIN, MY_COIN>(&mut treasury); | ||
assert!(balance::value(treasury_coin_a) == 100_000_000_000 + 100, 0); | ||
assert!(balance::value(treasury_coin_b) == 100_000_000_000 - 100, 0); | ||
}; | ||
|
||
// === swap_b_to_a === | ||
|
||
// 铸造代币b | ||
my_coin::mint(&mut treasury_cap_b, 100, ADMIN, ctx(&mut scenario)); | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 获取代币b | ||
let input_coin_b = test_scenario::take_from_address<Coin<MY_COIN>>(&scenario, ADMIN); | ||
// 代币b兑换代币a | ||
{ | ||
let out_coin = swap::swap_b_to_a<FAUCET_COIN, MY_COIN>(&mut treasury, input_coin_b, ctx(&mut scenario)); | ||
transfer::public_transfer(out_coin, ADMIN); | ||
}; | ||
test_scenario::next_tx(&mut scenario, ADMIN); | ||
// 查看资金 | ||
{ | ||
let (treasury_coin_a, treasury_coin_b) = swap::get_coin_mut<FAUCET_COIN, MY_COIN>(&mut treasury); | ||
assert!(balance::value(treasury_coin_a) == 100_000_000_000 + 100 - 100, 0); | ||
assert!(balance::value(treasury_coin_b) == 100_000_000_000 - 100 + 100, 0); | ||
}; | ||
|
||
test_scenario::return_shared(treasury_cap_a); | ||
transfer::public_transfer(treasury_cap_b, ADMIN); | ||
test_scenario::return_shared(treasury); | ||
test_scenario::end(scenario); | ||
} | ||
} |
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 @@ | ||
NEXT_PUBLIC_NETWORK=mainnet |
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,21 @@ | ||
MIT License | ||
|
||
Copyright (c) 2024 Mindfrog | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
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,3 @@ | ||
# task6 | ||
|
||
This is a Next.js Sui dApp project... |
Binary file not shown.
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 @@ | ||
import localFont from "next/font/local"; | ||
|
||
export const geistSans = localFont({ | ||
src: "./fonts/GeistVF.woff", | ||
variable: "--font-geist-sans", | ||
weight: "100 900", | ||
}); | ||
|
||
export const geistMono = localFont({ | ||
src: "./fonts/GeistMonoVF.woff", | ||
variable: "--font-geist-mono", | ||
weight: "100 900", | ||
}); |
Binary file not shown.
Binary file not shown.
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,7 @@ | ||
@tailwind base; | ||
@tailwind components; | ||
@tailwind utilities; | ||
|
||
body { | ||
font-family: Arial, Helvetica, sans-serif; | ||
} |
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,23 @@ | ||
import type { Metadata } from "next"; | ||
import "./globals.css"; | ||
import { geistSans, geistMono } from "./fonts"; | ||
import { Providers } from "./providers"; | ||
|
||
export const metadata: Metadata = { | ||
title: "Create Next App", | ||
description: "Generated by create next app", | ||
}; | ||
|
||
export default function RootLayout({ | ||
children, | ||
}: Readonly<{ | ||
children: React.ReactNode; | ||
}>) { | ||
return ( | ||
<html lang="en"> | ||
<body className={`${geistSans.variable} ${geistMono.variable} antialiased`}> | ||
<Providers>{children}</Providers> | ||
</body> | ||
</html> | ||
); | ||
} |
Oops, something went wrong.