Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Felix/sdk #19

Merged
merged 48 commits into from
Nov 20, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
bb5e93d
feat: add factory
FelixGibson Sep 18, 2023
e3b131f
feat: add factory abi
FelixGibson Sep 19, 2023
30b3dc1
feat: fix abi problem
FelixGibson Sep 23, 2023
af00fbb
feat: add abi
FelixGibson Sep 29, 2023
df99e0e
feat: partly finish addLiquidity
FelixGibson Sep 29, 2023
a7d86da
feat: try add test
FelixGibson Sep 29, 2023
a1d139a
feat: add interface
FelixGibson Sep 29, 2023
614d2de
feat: not finish yet
FelixGibson Sep 29, 2023
915a9f3
feat: approveForAll success
FelixGibson Sep 29, 2023
d6691b9
feat: add erc20
FelixGibson Sep 29, 2023
d9c32d3
feat: finish add liquidity, but run failed
FelixGibson Sep 30, 2023
1a393d5
feat: add may initiallize pool
FelixGibson Sep 30, 2023
8e19beb
feat: add position
FelixGibson Sep 30, 2023
b2d0c23
feat: add_liquidity pass
FelixGibson Sep 30, 2023
a256b3e
feat: add bounds when adding liquidity
FelixGibson Oct 1, 2023
84afd82
feat: add input text
FelixGibson Oct 2, 2023
d7db741
feat: add erc1155 balance check
FelixGibson Oct 2, 2023
bbe6766
feat: add erc1155 mint
FelixGibson Oct 2, 2023
bda0ae7
feat: add more input for erc1155 amount
FelixGibson Oct 2, 2023
a88e291
feat: fix order bug
FelixGibson Oct 3, 2023
91a5a15
feat: not can swap yet
FelixGibson Oct 3, 2023
17b7b43
feat: fix bugs
FelixGibson Oct 3, 2023
4aa66e0
feat: add avnu swap
FelixGibson Oct 4, 2023
f0903d4
feat: can swap
FelixGibson Oct 4, 2023
a3c6085
chore
FelixGibson Oct 5, 2023
6081938
feat: swap success
FelixGibson Oct 6, 2023
6b18424
feat: swap success from erc20
FelixGibson Oct 6, 2023
c30f410
bug: fix sqrt_ratio_limit
FelixGibson Oct 6, 2023
71071b2
sdk-refactor
huyao Oct 10, 2023
5ea051d
feat: add price
FelixGibson Oct 10, 2023
02e8447
more refactor
huyao Oct 11, 2023
51d3c51
remove useless code
huyao Oct 11, 2023
1a4a555
merge new functions and refactor
huyao Oct 12, 2023
386b266
Merge branch 'felix/sdk' into sdk-refactor
huyao Oct 12, 2023
1f64f89
Merge pull request #20 from BibliothecaDAO/sdk-refactor
FelixGibson Oct 12, 2023
64f9e22
graphql-index
huyao Oct 31, 2023
f90e0e4
Merge branch 'felix/sdk' into graphql
huyao Oct 31, 2023
a8cdb0f
Merge pull request #21 from BibliothecaDAO/graphql
FelixGibson Nov 2, 2023
396683a
linting by prettier
huyao Nov 3, 2023
4825053
remove useless code
huyao Nov 3, 2023
d5f52d0
feat: add nft address
FelixGibson Nov 4, 2023
0a963c3
add starknet.js & get-starknent for build bun on ubuntu
huyao Nov 7, 2023
c6d6479
Merge branch 'felix/sdk' of https://github.com/BibliothecaDAO/InstaSw…
huyao Nov 7, 2023
bb9c5a7
add remove liquidity method for sdk
huyao Nov 8, 2023
aaf2da7
remove expired functions
huyao Nov 8, 2023
5f36881
Merge pull request #22 from BibliothecaDAO/removeliquidity
FelixGibson Nov 8, 2023
c18ca3d
add list_liquidity api for indexer & add readme for indexer/sdk
huyao Nov 20, 2023
efb24a5
Update README.md
huyao Nov 20, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,4 @@ jobs:
- uses: software-mansion/setup-scarb@v1
with:
scarb-version: "0.7.0"
- run: cd contracts && scarb test
- run: cd contracts
1 change: 1 addition & 0 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{}
118 changes: 116 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,117 @@
## InstaSwap
# InstaSwap

### initialize sdk

To initialize sdk,fill the config first

```js

import { Provider, constants } from "starknet";
import { useAccount } from "@starknet-react/core";
....

const provider = new Provider({
sequencer: { network: constants.NetworkName.SN_GOERLI },
});

const config = {
erc1155Address: "0x03467674358c444d5868e40b4de2c8b08f0146cbdb4f77242bd7619efcf3c0a6",
werc20Address: "0x06b09e4c92a08076222b392c77e7eab4af5d127188082713aeecbe9013003bf4",
erc20Address: "0x049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc7",
ekuboPositionAddress: "0x73fa8432bf59f8ed535f29acfd89a7020758bda7be509e00dfed8a9fde12ddc",
ekuboCoreAddress: "0x031e8a7ab6a6a556548ac85cbb8b5f56e8905696e9f13e9a858142b8ee0cc221",
quoterAddress: "0x042aa743335663ed9c7b52b331ab7f81cc8d65280d311506653f9b5cc22be7cb",
provider: provider,
account: useAccount(),
};

const wrap = new Wrap(config);
...
```

### Initialize pool

```js
const initialize_tick = { mag: 0n, sign: false };

const { transaction_hash } = await wrap.mayInitializePool(
FeeAmount.LOWEST,
initialize_tick,
);
```

### Add liquidity

```js
const params = {
erc1155Amount: [erc1155 amount],
erc20Amount: [erc20 amount],
fee: [fee],
lowerPrice: [lowerBound],
upperPrice: [upperBound],
};

wrap.addLiquidity(params);

```



### Withdraw Liquidity

```js
wrap.withdrawLiquidity(positionId,liquidity);
```




### Simple wrap

- from erc115 to erc20

```js

const params = {
amountIn: [erc1155 amount for swap],
minERC20AmountOut: [min amount],
simpleSwapperAddress: [simple swapper address],
userAddress:[user address],
fee: [fee],
slippage: [slippage],
};

wrap.swapSimple(
SwapDirection.ERC1155_TO_ERC20,
params,
);


```

- from erc20 to erc1155

```js
const params = {
amountIn: [erc20 amount for swap],
minERC20AmountOut: [min amount],
simpleSwapperAddress: [simple swapper address],
userAddress:[user address],
fee: [fee],
slippage: [slippage],
};

wrap.swapSimple(
SwapDirection.ERC20_TO_ERC1155,
params,
);

```

### Withdraw erc1155

```js
wrap.withdraw(erc1155Num);
```


##
17 changes: 11 additions & 6 deletions contracts/deploy/starknet-devnet.md
Original file line number Diff line number Diff line change
@@ -1,29 +1,34 @@
### Export ENV
``` bash

```bash
export STARKNET_NETWORK=alpha-goerli
export STARKNET_WALLET=starkware.starknet.wallets.open_zeppelin.OpenZeppelinAccount
```

### Setup accounts
``` bash

```bash
starknet new_account --account with_testnet_eth --gateway_url http://localhost:5050 --feeder_gateway_url http://localhost:5050
starknet deploy_account --gateway_url http://localhost:5050 --feeder_gateway_url http://localhost:5050 --account with_testnet_eth
```

### Check txn status

ps. replace with your own hash

``` bash
```bash
starknet tx_status --hash 0x2b221bc1aab675e99189692fd530003d269eb099abba70ebd29c3fb5ab10187 --gateway_url http://localhost:5050 --feeder_gateway_url http://localhost:5050
```

### Declare contracts on dev-net
``` bash

```bash
starknet declare --contract target/dev/instaswap_InstaSwapPair.sierra.json --account devnet_account1 --max_fee 10000000000000000 --gateway_url http://localhost:5050 --feeder_gateway_url http://localhost:5050
```

### Deploy contracts on dev-net
``` bash

```bash
starknet deploy --class_hash 0x11e3711dbd08dd49631efa3a80faa28457cc193d1c620708331e1780e4b6b6e --account devnet_account1 --max_fee 100000000000000000 --gateway_url http://localhost:5050 --feeder_gateway_url http://localhost:5050

```
```
75 changes: 75 additions & 0 deletions contracts/src/wrap_factory.cairo
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@

#[starknet::contract]
mod WrapFactory {
use openzeppelin::token::erc20::erc20::ERC20;
use starknet::ContractAddress;
use starknet::{ get_caller_address, get_contract_address};
use zeroable::Zeroable;
use instaswap::erc1155::{IERC1155, IERC1155Dispatcher, IERC1155DispatcherTrait};
use starknet::class_hash::ClassHash;

#[event]
#[derive(Drop, starknet::Event)]
enum Event {
CreateWrapAddress: CreateWrapAddress,
}

#[derive(Drop, starknet::Event)]
struct CreateWrapAddress {
erc1155_address: ContractAddress,
token_id: u256,
wrap_address: ContractAddress,
}

#[storage]
struct Storage {
map: LegacyMap::<(ContractAddress, u256), ContractAddress>, // map of (erc1155_address, token_id) to wrap_address
wrap_hash: felt252, // hash of Wrap class
}

#[constructor]
fn constructor(
ref self: ContractState,
wrap_hash_: felt252,
) {
self.wrap_hash.write(wrap_hash_);
}

#[external(v0)]
#[generate_trait]
impl WrapFactoryInterfaceImpl of WrapFactoryInterface {
fn create_wrap_address(ref self: ContractState, erc1155_address: ContractAddress, token_id: u256, name: felt252, symbol: felt252) {
let wrap_address = self.map.read((erc1155_address, token_id));
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should move this to helper fn

let wrap_hash = self.wrap_hash.read();
assert(wrap_address.is_zero(), 'Already wrapped');
let mut calldata = Default::default();
erc1155_address.serialize(ref calldata);
token_id.serialize(ref calldata);
name.serialize(ref calldata);
symbol.serialize(ref calldata);
let (address, _) = starknet::deploy_syscall(wrap_hash.try_into().unwrap(), 0, calldata.span(), false)
.unwrap();
// emit event
self
.emit(
Event::CreateWrapAddress(
CreateWrapAddress {
erc1155_address: erc1155_address,
token_id: token_id,
wrap_address: address,
}
)
);
self.map.write((erc1155_address, token_id), address);

}

fn get_wrap_address(self: @ContractState, erc1155_address: ContractAddress, token_id: u256) -> ContractAddress {
let wrap_address = self.map.read((erc1155_address, token_id));
assert(!wrap_address.is_zero(), 'Not wrapped');
wrap_address
}

}

}
20 changes: 20 additions & 0 deletions examples/interface/.eslintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
{
"env": {
"browser": true,
"es2021": true
},
"extends": ["eslint:recommended", "plugin:@typescript-eslint/recommended"],
"overrides": [],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaVersion": "latest",
"project": "./tsconfig.json",
"sourceType": "module"
},
"plugins": ["react", "@typescript-eslint"],
"root": true,
"rules": {
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": ["off"]
}
}
24 changes: 24 additions & 0 deletions examples/interface/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
Binary file added examples/interface/bun.lockb
Binary file not shown.
13 changes: 13 additions & 0 deletions examples/interface/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Create Starknet</title>
</head>
<body>
<div id="root"></div>
<script type="module" src="/src/main.tsx"></script>
</body>
</html>
31 changes: 31 additions & 0 deletions examples/interface/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
{
"name": "interface",
"private": true,
"version": "0.0.0",
"type": "module",
"scripts": {
"dev": "vite",
"build": "tsc && vite build",
"preview": "vite preview"
},
"dependencies": {
"@bibliothecadao/instaswap-core": "link:instaswap/packages/instaswap-core",
"@starknet-react/core": "^1.0.1",
"get-starknet": "^3.0.1",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"starknet": "next"
},
"devDependencies": {
"@types/react": "^18.0.27",
"@types/react-dom": "^18.0.10",
"@typescript-eslint/eslint-plugin": "^6.7.3",
"@vitejs/plugin-react": "^3.1.0",
"bun-types": "^1.0.8",
"eslint": "^8.26.0",
"eslint-plugin-react": "^7.31.4",
"typescript": "^5.2.2",
"vite": "^4.1.0",
"vite-plugin-checker": "^0.5.1"
}
}
1 change: 1 addition & 0 deletions examples/interface/public/vite.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
30 changes: 30 additions & 0 deletions examples/interface/src/App.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import { useBlock } from "@starknet-react/core";
import WalletBar from "./components/WalletBar";
import { BlockNumber, BlockTag } from "starknet";

function App() {
const latestBlockNumber: BlockNumber = BlockTag.latest;
const { data, isLoading, isError } = useBlock({
refetchInterval: 3000,
blockIdentifier: latestBlockNumber,
});

return (
<main>
<p>
Get started by editing&nbsp;
<code>pages/index.tsx</code>
</p>
<div>
{isLoading
? "Loading..."
: isError
? "Error while fetching the latest block hash"
: `Latest block hash: ${data?.block_hash}`}
</div>
<WalletBar />
</main>
);
}

export default App;
Loading
Loading