Uniswap Interface 连接私有链
对Uniswap SDK 和 Interface进行修改,私有化部署Uniswap Interface v3.2.20,使其融合私有链。
修改uniswap-sdk并上传
使用node v13.14.0 (npm v6.14.4)
nvm use 13
clone uniswap-sdk
git clone https://github.com/Fu-XDU/uniswap-sdk.git
使用编辑器打开uniswap-sdk项目,方便修改,我们需要修改以下代码:
- 添加
ChainID
,并修改src/constants.ts
文件中FACTORY_ADDRESS
和INIT_CODE_HASH
data:image/s3,"s3://crabby-images/f5557/f555790437d903c6696be02c2b95c9281b2a593f" alt="image-20250117014946145"
- 在
src/entities/token.ts
中添加WETH合约地址:
data:image/s3,"s3://crabby-images/e0b99/e0b995668b317b5dabbd1caeda8bf606674ab4fe" alt="image-20250117014835332"
- 修改sdk的package.json,修改一下库的名称及版本:
data:image/s3,"s3://crabby-images/d474e/d474e502f4b0ebe99aabfea55279711b3ad9d337" alt="image-20250117014911551"
- 安装tsdx和其他依赖:
npm install -g tsdx
npm install
- 登陆并发布
npm login --registry=https://registry.npmjs.org/
npm publish --registry=https://registry.npmjs.org/ --access=public
修改interface
下载interface v3.2.20
代码:https://github.com/Uniswap/interface/releases/tag/v3.2.20
- 修改
package.json
,添加我们自己的sdk
库信息
data:image/s3,"s3://crabby-images/c9ac4/c9ac41321c802bd2e1344383673016dcce9aae84" alt="image-20250117015430631"
- 全局替换
@uniswap/sdk
为我们自己的库名称:
data:image/s3,"s3://crabby-images/98b43/98b430d4f4da2feea8ce650794b2f81cafaf54db" alt="image-20250117015551636"
- 修改
src/constants/index.ts
中修改路由合约地址ROUTER_ADDRESS
,并添加链名:
data:image/s3,"s3://crabby-images/1c808/1c808e31cc9c5c8246fc2ba0c3e5e0ec0ecfe417" alt="image-20250117010605508"
data:image/s3,"s3://crabby-images/40c40/40c401e92a7f0d78632c91b678b354b102824698" alt="image-20250117010622968"
- 在
src/connectors/index.ts
中添加支持的链id:
data:image/s3,"s3://crabby-images/ddad1/ddad124b29f719757c8e8dd5d00652deb72c4bda" alt="image-20250117010653998"
- 在
src/constants/multicall/index.tx
中添加multicall地址:
data:image/s3,"s3://crabby-images/9b0b5/9b0b585dc2a4029e0e0fbd263f8646f7db4dcdee" alt="image-20250117021123527"
- 在
src/componets/Header/index.tsx
中添加NETWORK_LABELS
:
data:image/s3,"s3://crabby-images/168ab/168abc98d640ab25979ced69c7a4e464ee26d6b8" alt="image-20250117011854610"
- 在
src/constants/v1/index.ts
中添加V1_FACTORY_ADDRESSES
,我们并未使用v1,随便写一个不存在的地址:
data:image/s3,"s3://crabby-images/f6240/f6240609af7eab51accc42a8961096cc32f156c5" alt="image-20250117021023839"
- 在
src/state/lists/hooks.ts
添加EMPTY_LIST:
data:image/s3,"s3://crabby-images/7ea49/7ea493bbb16c9c2df2ea81195f7d66f6eb2d7585" alt="image-20250117012024582"
添加TokenAddressMap
:
data:image/s3,"s3://crabby-images/7ee02/7ee02b4926a4d09b5944e43920951b751e26269c" alt="image-20250117012118731"
- 在
src/utils/index.ts
添加ETHERSCAN_PREFIXES
,没有区块链浏览器,所以复制goerli网络的:
data:image/s3,"s3://crabby-images/14110/14110bc350d399e0517370aae52978138af74874" alt="image-20250122062051881"
- 修改启动脚本,添加
export NODE_OPTIONS=--openssl-legacy-provider &&
:
data:image/s3,"s3://crabby-images/950db/950dbe7dbc98c593fe01d7959d77c218a28967ff" alt="image-20250117015900107"
- 此版本有一个Bug,Swap 时会因为过小的 deadline 而导致失败,需要将
src/hooks/useTransactionDeadline.ts
作如下修改:
data:image/s3,"s3://crabby-images/995b0/995b0c9bd37b12f595508920b479b7bf079d17b9" alt="image-20250124001811617"
启动interface
# yarn 版本 1.22.22
yarn
yarn start
data:image/s3,"s3://crabby-images/a5dbc/a5dbc2ead5e06c8f2310c38bd74e0bb9aba86465" alt="image-20250117015945813"
添加代币列表
现在 uniswap v2 已经成功部署了,如果我们需要在交易所添加自己的代币。
uniswap v2 前端显示的代币列表配置在 uniswap-interface/src/constants/lists.ts
文件中的 DEFAULT_LIST_OF_LISTS 常量数组,数组元素的值可以是一个 http地址、ifps地址 和 ENS name。地址返回结果必须是指定结构的 json 文件,我们可以通过向 DEFAULT_LIST_OF_LISTS 常量数组添加新的地址达到添加自定义代币的目的。
下面就来通过添加一个代币详细描述这个过程。
1. 创建 tokens.json 文件
文件格式如下:
{
"name": "Test Tokens List",
"version": {
"major": 1,
"minor": 0,
"patch": 0
},
"logoURI": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x7D1AfA7B718fb893dB30A3aBc0Cfc608AaCfeBB0/logo.png",
"timestamp": "2025-01-17 02:18:00.000+08:00",
"tokens": [
{
"chainId": 1337,
"address": "0x5d4E9CF09A183c5565a444BB52242cE53a58017b",
"name": "WETH",
"symbol": "WETH",
"decimals": 18,
"logoURI": "https://raw.githubusercontent.com/Uniswap/assets/master/blockchains/ethereum/assets/0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2/logo.png"
}
]
}
tokens
字段是一个数组类型,它负责描述代币列表包含的所有代币。我们在里面添加了一个 WETH
(当然也可以添加多个代币),符号是 WETH
,合约地址是 0x5d4E9CF09A183c5565a444BB52242cE53a58017b
。请注意里面有一个 chainId
字段,值为 1337
,这是因为 我们的测试网络的 chainId 是 1337,前端只有在钱包连接网络的 chainId 为 1337 时才会显示这个代币。
2. 上传 tokens.json 文件
tokens.json 文件完成编辑后就可以上传至服务器了。随便上传到哪里都可以,比如你自己的 HTTP 文件服务器,只要能够公网访问就行,可以将它上传到gist.github.com (需要翻墙)。
3. 在前端添加 Tokens List
填写地址:https://asset.flxdu.cn/dev/tokens.json
data:image/s3,"s3://crabby-images/0c492/0c4927063a32df954fcdfe324891c5b4fde65e07" alt="image-20250117020027491"
随后即可添加流动性,进行兑换等操作。