일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Vue
- ethers
- 컨트렉트 배포 자동화
- 오블완
- 스마트컨트렉트 함수이름 중복 호출
- 컨트렉트 동일한 함수이름 호출
- 스마트컨트렉트테스트
- Vue.js
- 머신러닝기초
- 스마트컨트렉트 예약어 함수이름 중복
- ethers type
- 티스토리챌린지
- 체인의정석
- ethers typescript
- vue기초
- multicall
- erc4337
- 러스트기초
- chainlink 설명
- SBT표준
- 러스트 기초 학습
- git rebase
- ethers v6
- 러스트 기초
- ambiguous function description
- 계정추상화
- 스마트 컨트렉트 함수이름 중복
- ethers websocket
- rust 기초
- erc4337 contract
Archives
- Today
- Total
체인의정석
Uniswap V3 - multicall, ethers & typescript로 사용해 보기 본문
728x90
반응형
유니스왑 V3를 보면 multicall이 내장되어 있다.
따라서 서비스를 만들 때 해당 멀티콜을 써서 다양한 트랜잭션을 보내주거나 조회해 올 수 있는데
ethers와 typescript를 사용해서 멀티콜을 하는 부분을 사용하는 부분을 기록해 두려고 한다.
struct를 encode 하는 부분 참고 소스코드는 다음과 같다.
const a = '0x...';
const b = '123123123123132123123';
const c = true;
const myStructData = ethers.utils.AbiCoder.prototype.encode(
['address', 'uint', 'bool'],
[a, b, c]
);
const tx = await myContract.myFunction(
myStructData,
{ gasLimit: ethers.utils.parseUnits('1000000', 'wei') }
);
https://github.com/ethers-io/ethers.js/issues/1007
그러던 중 찾게된 더 간결한 코드가 있는데 인터페이스로 부터 함수를 인코딩 하는 함수이다.
var abi = [ { name: 'foo', type: 'function', inputs: [ { type: 'uint256' } ], outputs: [ { type: 'uint8' }] } ];
var iface = new ethers.Interface(abi)
// Example
var calldata = iface.functions.foo.encode(42);
// "0x2fbebd38000000000000000000000000000000000000000000000000000000000000002a"
// Parsing call response
var response = "0x000000000000000000000000000000000000000000000000000000000000002b";
var result = iface.functions.foo.decode(response);
// 43
https://github.com/ethers-io/ethers.js/issues/211
위 코드들을 참고해서 유니스왑 v3에 적용해보았다.
async function multicall() {
const signer = await getAllSigners(0);
const contractAddressNftManager = devAddress.nftPositionManager;
const nonfungiblePositionManager = await ethers.getContractAt("NonfungiblePositionManager",contractAddressNftManager,signer) as NonfungiblePositionManager;
const currentBlock = await ethers.provider.getBlockNumber();
const blockTimestamp = (await ethers.provider.getBlock(currentBlock)).timestamp + 1000000;
const increaseLiqidityParams: IncreaseLiquidtyParams = {
tokenId: 19,
amount0Desired: toEthValue(1,18),
amount1Desired: toEthValue(1,18),
amount0Min: 0,
amount1Min: 0,
deadline: blockTimestamp
}
const decreaseLiquidityParams: DecreaseLiquidtyParams = {
tokenId: 19,
liquidity: 1000000,
amount0Min: 0,
amount1Min: 0,
deadline: blockTimestamp
}
const calldataIncrease = nonfungiblePositionManager.interface.encodeFunctionData("increaseLiquidity", [increaseLiqidityParams]);
const calldataDecrease = nonfungiblePositionManager.interface.encodeFunctionData("decreaseLiquidity", [decreaseLiquidityParams]);
console.log(calldataIncrease);
console.log(calldataDecrease);
const increaseAndDecrease = await nonfungiblePositionManager.multicall([calldataIncrease,calldataIncrease,calldataIncrease]);
console.log(increaseAndDecrease);
}
시행착오 끝에 완성시켰는데 설명을 남기자면
우선 해당 멀티콜이 있는 컨트렉트는 uniswapV3의 nonfungiblePositionManage 인데 이렇게 구조체를 먼저 만들어 주고 해당 구조체를 인터페이스를 가져와서 인코딩 시켜주면 된다.
getContractAt을 통해서 가져온다면 .interface를 통해서 더 쉽게 인터페이스를 가져올 수 있고
그 후에 encodeFunctionData를 사용하게 되면 값들을 인코딩 할 수 있다.
위의 문법들을 참고하면 다중 입력값도 가능할 것이다.
728x90
반응형
'블록체인 > 디파이' 카테고리의 다른 글
Uniswap V3 - Liquidity 살펴보기 (Setup & Mint & Fee & Decrease liquidity & increase Liquidity) (0) | 2023.07.15 |
---|---|
Uniswap V3 - SWAP 살펴보기 (Single Swap, Multihop Swap) (0) | 2023.07.14 |
Uniswap V2 컨셉 & Uniswap V3 컨셉 (0) | 2023.07.04 |
compound 청산로직 추가 자료 (0) | 2022.12.27 |
컴파운드 분석 3편 - CToken & Comptroller (transfer, 유동성체크, 이자율 체크, 청산) (0) | 2022.12.16 |
Comments