@uniswap/universal-router-sdk 4.19.0 → 4.19.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{entities → cjs/src/entities}/Command.d.ts +12 -12
- package/dist/cjs/src/entities/Command.js +9 -0
- package/dist/cjs/src/entities/Command.js.map +1 -0
- package/dist/{entities → cjs/src/entities}/actions/index.d.ts +2 -2
- package/dist/cjs/src/entities/actions/index.js +6 -0
- package/dist/cjs/src/entities/actions/index.js.map +1 -0
- package/dist/{entities → cjs/src/entities}/actions/uniswap.d.ts +30 -30
- package/dist/cjs/src/entities/actions/uniswap.js +365 -0
- package/dist/cjs/src/entities/actions/uniswap.js.map +1 -0
- package/dist/{entities → cjs/src/entities}/actions/unwrapWETH.d.ts +12 -12
- package/dist/cjs/src/entities/actions/unwrapWETH.js +33 -0
- package/dist/cjs/src/entities/actions/unwrapWETH.js.map +1 -0
- package/dist/{entities → cjs/src/entities}/index.d.ts +2 -2
- package/dist/cjs/src/entities/index.js +6 -0
- package/dist/cjs/src/entities/index.js.map +1 -0
- package/dist/cjs/src/index.d.ts +9 -0
- package/dist/cjs/src/index.js +24 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/{swapRouter.d.ts → cjs/src/swapRouter.d.ts} +37 -37
- package/dist/cjs/src/swapRouter.js +120 -0
- package/dist/cjs/src/swapRouter.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/commandParser.d.ts +34 -34
- package/dist/cjs/src/utils/commandParser.js +144 -0
- package/dist/cjs/src/utils/commandParser.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/constants.d.ts +30 -30
- package/dist/cjs/src/utils/constants.js +373 -0
- package/dist/cjs/src/utils/constants.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/getCurrencyAddress.d.ts +2 -2
- package/dist/cjs/src/utils/getCurrencyAddress.js +9 -0
- package/dist/cjs/src/utils/getCurrencyAddress.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/inputTokens.d.ts +23 -23
- package/dist/cjs/src/utils/inputTokens.js +58 -0
- package/dist/cjs/src/utils/inputTokens.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/numbers.d.ts +6 -6
- package/dist/cjs/src/utils/numbers.js +22 -0
- package/dist/cjs/src/utils/numbers.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/pathCurrency.d.ts +3 -3
- package/dist/cjs/src/utils/pathCurrency.js +27 -0
- package/dist/cjs/src/utils/pathCurrency.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/routerCommands.d.ts +64 -64
- package/dist/cjs/src/utils/routerCommands.js +231 -0
- package/dist/cjs/src/utils/routerCommands.js.map +1 -0
- package/dist/{utils → cjs/src/utils}/routerTradeAdapter.d.ts +73 -73
- package/dist/cjs/src/utils/routerTradeAdapter.js +139 -0
- package/dist/cjs/src/utils/routerTradeAdapter.js.map +1 -0
- package/dist/esm/src/entities/Command.d.ts +12 -0
- package/dist/esm/src/entities/Command.js +6 -0
- package/dist/esm/src/entities/Command.js.map +1 -0
- package/dist/esm/src/entities/actions/index.d.ts +2 -0
- package/dist/esm/src/entities/actions/index.js +3 -0
- package/dist/esm/src/entities/actions/index.js.map +1 -0
- package/dist/esm/src/entities/actions/uniswap.d.ts +30 -0
- package/dist/esm/src/entities/actions/uniswap.js +361 -0
- package/dist/esm/src/entities/actions/uniswap.js.map +1 -0
- package/dist/esm/src/entities/actions/unwrapWETH.d.ts +12 -0
- package/dist/esm/src/entities/actions/unwrapWETH.js +28 -0
- package/dist/esm/src/entities/actions/unwrapWETH.js.map +1 -0
- package/dist/esm/src/entities/index.d.ts +2 -0
- package/dist/esm/src/entities/index.js +3 -0
- package/dist/esm/src/entities/index.js.map +1 -0
- package/dist/esm/src/index.d.ts +9 -0
- package/dist/esm/src/index.js +7 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/swapRouter.d.ts +37 -0
- package/dist/esm/src/swapRouter.js +115 -0
- package/dist/esm/src/swapRouter.js.map +1 -0
- package/dist/esm/src/utils/commandParser.d.ts +34 -0
- package/dist/esm/src/utils/commandParser.js +137 -0
- package/dist/esm/src/utils/commandParser.js.map +1 -0
- package/dist/esm/src/utils/constants.d.ts +30 -0
- package/dist/esm/src/utils/constants.js +367 -0
- package/dist/esm/src/utils/constants.js.map +1 -0
- package/dist/esm/src/utils/getCurrencyAddress.d.ts +2 -0
- package/dist/esm/src/utils/getCurrencyAddress.js +5 -0
- package/dist/esm/src/utils/getCurrencyAddress.js.map +1 -0
- package/dist/esm/src/utils/inputTokens.d.ts +23 -0
- package/dist/esm/src/utils/inputTokens.js +51 -0
- package/dist/esm/src/utils/inputTokens.js.map +1 -0
- package/dist/esm/src/utils/numbers.d.ts +6 -0
- package/dist/esm/src/utils/numbers.js +15 -0
- package/dist/esm/src/utils/numbers.js.map +1 -0
- package/dist/esm/src/utils/pathCurrency.d.ts +3 -0
- package/dist/esm/src/utils/pathCurrency.js +23 -0
- package/dist/esm/src/utils/pathCurrency.js.map +1 -0
- package/dist/esm/src/utils/routerCommands.d.ts +64 -0
- package/dist/esm/src/utils/routerCommands.js +226 -0
- package/dist/esm/src/utils/routerCommands.js.map +1 -0
- package/dist/esm/src/utils/routerTradeAdapter.d.ts +73 -0
- package/dist/esm/src/utils/routerTradeAdapter.js +134 -0
- package/dist/esm/src/utils/routerTradeAdapter.js.map +1 -0
- package/dist/types/src/entities/Command.d.ts +12 -0
- package/dist/types/src/entities/actions/index.d.ts +2 -0
- package/dist/types/src/entities/actions/uniswap.d.ts +30 -0
- package/dist/types/src/entities/actions/unwrapWETH.d.ts +12 -0
- package/dist/types/src/entities/index.d.ts +2 -0
- package/dist/types/src/index.d.ts +9 -0
- package/dist/types/src/swapRouter.d.ts +37 -0
- package/dist/types/src/utils/commandParser.d.ts +34 -0
- package/dist/types/src/utils/constants.d.ts +30 -0
- package/dist/types/src/utils/getCurrencyAddress.d.ts +2 -0
- package/dist/types/src/utils/inputTokens.d.ts +23 -0
- package/dist/types/src/utils/numbers.d.ts +6 -0
- package/dist/types/src/utils/pathCurrency.d.ts +3 -0
- package/dist/types/src/utils/routerCommands.d.ts +64 -0
- package/dist/types/src/utils/routerTradeAdapter.d.ts +73 -0
- package/package.json +17 -5
- package/dist/index.d.ts +0 -6
- package/dist/index.js +0 -8
- package/dist/test/forge/writeInterop.d.ts +0 -2
- package/dist/test/utils/addresses.d.ts +0 -5
- package/dist/test/utils/hexToDecimalString.d.ts +0 -2
- package/dist/test/utils/permit2.d.ts +0 -7
- package/dist/test/utils/uniswapData.d.ts +0 -24
- package/dist/universal-router-sdk.cjs.development.js +0 -1433
- package/dist/universal-router-sdk.cjs.development.js.map +0 -1
- package/dist/universal-router-sdk.cjs.production.min.js +0 -2
- package/dist/universal-router-sdk.cjs.production.min.js.map +0 -1
- package/dist/universal-router-sdk.esm.js +0 -1426
- package/dist/universal-router-sdk.esm.js.map +0 -1
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import invariant from 'tiny-invariant';
|
|
2
|
+
import { abi } from '@uniswap/universal-router/artifacts/contracts/UniversalRouter.sol/UniversalRouter.json';
|
|
3
|
+
import { Interface } from '@ethersproject/abi';
|
|
4
|
+
import { BigNumber } from 'ethers';
|
|
5
|
+
import { Multicall, NonfungiblePositionManager as V3PositionManager, } from '@uniswap/v3-sdk';
|
|
6
|
+
import { V4PositionManager, Pool as V4Pool, } from '@uniswap/v4-sdk';
|
|
7
|
+
import { Percent, CHAIN_TO_ADDRESSES_MAP } from '@uniswap/sdk-core';
|
|
8
|
+
import { UniswapTrade } from './entities/actions/uniswap';
|
|
9
|
+
import { RoutePlanner, CommandType } from './utils/routerCommands';
|
|
10
|
+
import { encodePermit, encodeV3PositionPermit } from './utils/inputTokens';
|
|
11
|
+
import { UNIVERSAL_ROUTER_ADDRESS, UniversalRouterVersion } from './utils/constants';
|
|
12
|
+
function isMint(options) {
|
|
13
|
+
return Object.keys(options).some((k) => k === 'recipient');
|
|
14
|
+
}
|
|
15
|
+
export class SwapRouter {
|
|
16
|
+
static swapCallParameters(trades, options) {
|
|
17
|
+
// TODO: use permit if signature included in swapOptions
|
|
18
|
+
const planner = new RoutePlanner();
|
|
19
|
+
const trade = new UniswapTrade(trades, options);
|
|
20
|
+
const inputCurrency = trade.trade.inputAmount.currency;
|
|
21
|
+
invariant(!(inputCurrency.isNative && !!options.inputTokenPermit), 'NATIVE_INPUT_PERMIT');
|
|
22
|
+
if (options.inputTokenPermit) {
|
|
23
|
+
encodePermit(planner, options.inputTokenPermit);
|
|
24
|
+
}
|
|
25
|
+
const nativeCurrencyValue = inputCurrency.isNative
|
|
26
|
+
? BigNumber.from(trade.trade.maximumAmountIn(options.slippageTolerance).quotient.toString())
|
|
27
|
+
: BigNumber.from(0);
|
|
28
|
+
trade.encode(planner, { allowRevert: false });
|
|
29
|
+
return SwapRouter.encodePlan(planner, nativeCurrencyValue, {
|
|
30
|
+
deadline: options.deadlineOrPreviousBlockhash ? BigNumber.from(options.deadlineOrPreviousBlockhash) : undefined,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Builds the call parameters for a migration from a V3 position to a V4 position.
|
|
35
|
+
* Some requirements of the parameters:
|
|
36
|
+
* - v3RemoveLiquidityOptions.collectOptions.recipient must equal v4PositionManager
|
|
37
|
+
* - v3RemoveLiquidityOptions.liquidityPercentage must be 100%
|
|
38
|
+
* - input pool and output pool must have the same tokens
|
|
39
|
+
* - V3 NFT must be approved, or valid inputV3NFTPermit must be provided with UR as spender
|
|
40
|
+
*/
|
|
41
|
+
static migrateV3ToV4CallParameters(options, positionManagerOverride) {
|
|
42
|
+
const v4Pool = options.outputPosition.pool;
|
|
43
|
+
const v3Token0 = options.inputPosition.pool.token0;
|
|
44
|
+
const v3Token1 = options.inputPosition.pool.token1;
|
|
45
|
+
const v4PositionManagerAddress = positionManagerOverride !== null && positionManagerOverride !== void 0 ? positionManagerOverride : CHAIN_TO_ADDRESSES_MAP[v4Pool.chainId].v4PositionManagerAddress;
|
|
46
|
+
// owner of the v3 nft must be the receiver of the v4 nft
|
|
47
|
+
// validate the parameters
|
|
48
|
+
if (v4Pool.currency0.isNative) {
|
|
49
|
+
invariant((v4Pool.currency0.wrapped.equals(v3Token0) && v4Pool.currency1.equals(v3Token1)) ||
|
|
50
|
+
(v4Pool.currency0.wrapped.equals(v3Token1) && v4Pool.currency1.equals(v3Token0)), 'TOKEN_MISMATCH');
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
invariant(v3Token0 === v4Pool.token0, 'TOKEN0_MISMATCH');
|
|
54
|
+
invariant(v3Token1 === v4Pool.token1, 'TOKEN1_MISMATCH');
|
|
55
|
+
}
|
|
56
|
+
invariant(options.v3RemoveLiquidityOptions.liquidityPercentage.equalTo(new Percent(100, 100)), 'FULL_REMOVAL_REQUIRED');
|
|
57
|
+
invariant(options.v3RemoveLiquidityOptions.burnToken == true, 'BURN_TOKEN_REQUIRED');
|
|
58
|
+
invariant(options.v3RemoveLiquidityOptions.collectOptions.recipient === v4PositionManagerAddress, 'RECIPIENT_NOT_POSITION_MANAGER');
|
|
59
|
+
invariant(isMint(options.v4AddLiquidityOptions), 'MINT_REQUIRED');
|
|
60
|
+
invariant(options.v4AddLiquidityOptions.migrate, 'MIGRATE_REQUIRED');
|
|
61
|
+
const planner = new RoutePlanner();
|
|
62
|
+
// to prevent reentrancy by the pool hook, we initialize the v4 pool before moving funds
|
|
63
|
+
if (options.v4AddLiquidityOptions.createPool) {
|
|
64
|
+
const poolKey = V4Pool.getPoolKey(v4Pool.currency0, v4Pool.currency1, v4Pool.fee, v4Pool.tickSpacing, v4Pool.hooks);
|
|
65
|
+
planner.addCommand(CommandType.V4_INITIALIZE_POOL, [poolKey, v4Pool.sqrtRatioX96.toString()]);
|
|
66
|
+
// remove createPool setting, so that it doesnt get encoded again later
|
|
67
|
+
delete options.v4AddLiquidityOptions.createPool;
|
|
68
|
+
}
|
|
69
|
+
// add position permit to the universal router planner
|
|
70
|
+
if (options.v3RemoveLiquidityOptions.permit) {
|
|
71
|
+
// permit spender should be UR
|
|
72
|
+
const universalRouterAddress = UNIVERSAL_ROUTER_ADDRESS(UniversalRouterVersion.V2_0, options.inputPosition.pool.chainId);
|
|
73
|
+
invariant(universalRouterAddress == options.v3RemoveLiquidityOptions.permit.spender, 'INVALID_SPENDER');
|
|
74
|
+
// don't need to transfer it because v3posm uses isApprovedOrOwner()
|
|
75
|
+
encodeV3PositionPermit(planner, options.v3RemoveLiquidityOptions.permit, options.v3RemoveLiquidityOptions.tokenId);
|
|
76
|
+
// remove permit so that multicall doesnt add it again
|
|
77
|
+
delete options.v3RemoveLiquidityOptions.permit;
|
|
78
|
+
}
|
|
79
|
+
// encode v3 withdraw
|
|
80
|
+
const v3RemoveParams = V3PositionManager.removeCallParameters(options.inputPosition, options.v3RemoveLiquidityOptions);
|
|
81
|
+
const v3Calls = Multicall.decodeMulticall(v3RemoveParams.calldata);
|
|
82
|
+
for (const v3Call of v3Calls) {
|
|
83
|
+
// slice selector - 0x + 4 bytes = 10 characters
|
|
84
|
+
const selector = v3Call.slice(0, 10);
|
|
85
|
+
invariant(selector == V3PositionManager.INTERFACE.getSighash('collect') ||
|
|
86
|
+
selector == V3PositionManager.INTERFACE.getSighash('decreaseLiquidity') ||
|
|
87
|
+
selector == V3PositionManager.INTERFACE.getSighash('burn'), 'INVALID_V3_CALL: ' + selector);
|
|
88
|
+
planner.addCommand(CommandType.V3_POSITION_MANAGER_CALL, [v3Call]);
|
|
89
|
+
}
|
|
90
|
+
// encode v4 mint
|
|
91
|
+
const v4AddParams = V4PositionManager.addCallParameters(options.outputPosition, options.v4AddLiquidityOptions);
|
|
92
|
+
// only modifyLiquidities can be called by the UniversalRouter
|
|
93
|
+
const selector = v4AddParams.calldata.slice(0, 10);
|
|
94
|
+
invariant(selector == V4PositionManager.INTERFACE.getSighash('modifyLiquidities'), 'INVALID_V4_CALL: ' + selector);
|
|
95
|
+
planner.addCommand(CommandType.V4_POSITION_MANAGER_CALL, [v4AddParams.calldata]);
|
|
96
|
+
return SwapRouter.encodePlan(planner, BigNumber.from(0), {
|
|
97
|
+
deadline: BigNumber.from(options.v4AddLiquidityOptions.deadline),
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Encodes a planned route into a method name and parameters for the Router contract.
|
|
102
|
+
* @param planner the planned route
|
|
103
|
+
* @param nativeCurrencyValue the native currency value of the planned route
|
|
104
|
+
* @param config the router config
|
|
105
|
+
*/
|
|
106
|
+
static encodePlan(planner, nativeCurrencyValue, config = {}) {
|
|
107
|
+
const { commands, inputs } = planner;
|
|
108
|
+
const functionSignature = !!config.deadline ? 'execute(bytes,bytes[],uint256)' : 'execute(bytes,bytes[])';
|
|
109
|
+
const parameters = !!config.deadline ? [commands, inputs, config.deadline] : [commands, inputs];
|
|
110
|
+
const calldata = SwapRouter.INTERFACE.encodeFunctionData(functionSignature, parameters);
|
|
111
|
+
return { calldata, value: nativeCurrencyValue.toHexString() };
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
SwapRouter.INTERFACE = new Interface(abi);
|
|
115
|
+
//# sourceMappingURL=swapRouter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"swapRouter.js","sourceRoot":"","sources":["../../../src/swapRouter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Interface } from '@ethersproject/abi';
|
|
2
|
+
import { CommandType, CommandDefinition } from '../utils/routerCommands';
|
|
3
|
+
export type Param = {
|
|
4
|
+
readonly name: string;
|
|
5
|
+
readonly value: any;
|
|
6
|
+
};
|
|
7
|
+
export type UniversalRouterCommand = {
|
|
8
|
+
readonly commandName: string;
|
|
9
|
+
readonly commandType: CommandType;
|
|
10
|
+
readonly params: readonly Param[];
|
|
11
|
+
};
|
|
12
|
+
export type UniversalRouterCall = {
|
|
13
|
+
readonly commands: readonly UniversalRouterCommand[];
|
|
14
|
+
};
|
|
15
|
+
export type V3PathItem = {
|
|
16
|
+
readonly tokenIn: string;
|
|
17
|
+
readonly tokenOut: string;
|
|
18
|
+
readonly fee: number;
|
|
19
|
+
};
|
|
20
|
+
export interface CommandsDefinition {
|
|
21
|
+
[key: number]: CommandDefinition;
|
|
22
|
+
}
|
|
23
|
+
export declare abstract class CommandParser {
|
|
24
|
+
static INTERFACE: Interface;
|
|
25
|
+
static parseCalldata(calldata: string): UniversalRouterCall;
|
|
26
|
+
}
|
|
27
|
+
export declare class GenericCommandParser {
|
|
28
|
+
private readonly commandDefinition;
|
|
29
|
+
constructor(commandDefinition: CommandsDefinition);
|
|
30
|
+
parse(commands: string, inputs: string[]): UniversalRouterCall;
|
|
31
|
+
private static getCommands;
|
|
32
|
+
}
|
|
33
|
+
export declare function parseV3PathExactIn(path: string): readonly V3PathItem[];
|
|
34
|
+
export declare function parseV3PathExactOut(path: string): readonly V3PathItem[];
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { ethers } from 'ethers';
|
|
2
|
+
import { abi } from '@uniswap/universal-router/artifacts/contracts/UniversalRouter.sol/UniversalRouter.json';
|
|
3
|
+
import { Interface } from '@ethersproject/abi';
|
|
4
|
+
import { V4BaseActionsParser } from '@uniswap/v4-sdk';
|
|
5
|
+
import { CommandType, COMMAND_DEFINITION, Subparser, Parser } from '../utils/routerCommands';
|
|
6
|
+
// Parses UniversalRouter V2 commands
|
|
7
|
+
export class CommandParser {
|
|
8
|
+
static parseCalldata(calldata) {
|
|
9
|
+
const genericParser = new GenericCommandParser(COMMAND_DEFINITION);
|
|
10
|
+
const txDescription = CommandParser.INTERFACE.parseTransaction({ data: calldata });
|
|
11
|
+
const { commands, inputs } = txDescription.args;
|
|
12
|
+
return genericParser.parse(commands, inputs);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
CommandParser.INTERFACE = new Interface(abi);
|
|
16
|
+
// Parses commands based on given command definition
|
|
17
|
+
export class GenericCommandParser {
|
|
18
|
+
constructor(commandDefinition) {
|
|
19
|
+
this.commandDefinition = commandDefinition;
|
|
20
|
+
}
|
|
21
|
+
parse(commands, inputs) {
|
|
22
|
+
const commandTypes = GenericCommandParser.getCommands(commands);
|
|
23
|
+
return {
|
|
24
|
+
commands: commandTypes.map((commandType, i) => {
|
|
25
|
+
const commandDef = this.commandDefinition[commandType];
|
|
26
|
+
if (commandDef.parser === Parser.V4Actions) {
|
|
27
|
+
const { actions } = V4BaseActionsParser.parseCalldata(inputs[i]);
|
|
28
|
+
return {
|
|
29
|
+
commandName: CommandType[commandType],
|
|
30
|
+
commandType,
|
|
31
|
+
params: v4RouterCallToParams(actions),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
else if (commandDef.parser === Parser.Abi) {
|
|
35
|
+
const abiDef = commandDef.params;
|
|
36
|
+
const rawParams = ethers.utils.defaultAbiCoder.decode(abiDef.map((command) => command.type), inputs[i]);
|
|
37
|
+
const params = rawParams.map((param, j) => {
|
|
38
|
+
switch (abiDef[j].subparser) {
|
|
39
|
+
case Subparser.V3PathExactIn:
|
|
40
|
+
return {
|
|
41
|
+
name: abiDef[j].name,
|
|
42
|
+
value: parseV3PathExactIn(param),
|
|
43
|
+
};
|
|
44
|
+
case Subparser.V3PathExactOut:
|
|
45
|
+
return {
|
|
46
|
+
name: abiDef[j].name,
|
|
47
|
+
value: parseV3PathExactOut(param),
|
|
48
|
+
};
|
|
49
|
+
default:
|
|
50
|
+
return {
|
|
51
|
+
name: abiDef[j].name,
|
|
52
|
+
value: param,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return {
|
|
57
|
+
commandName: CommandType[commandType],
|
|
58
|
+
commandType,
|
|
59
|
+
params,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
else if (commandDef.parser === Parser.V3Actions) {
|
|
63
|
+
// TODO: implement better parsing here
|
|
64
|
+
return {
|
|
65
|
+
commandName: CommandType[commandType],
|
|
66
|
+
commandType,
|
|
67
|
+
params: inputs.map((input) => ({ name: 'command', value: input })),
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
throw new Error(`Unsupported parser: ${commandDef}`);
|
|
72
|
+
}
|
|
73
|
+
}),
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
// parse command types from bytes string
|
|
77
|
+
static getCommands(commands) {
|
|
78
|
+
const commandTypes = [];
|
|
79
|
+
for (let i = 2; i < commands.length; i += 2) {
|
|
80
|
+
const byte = commands.substring(i, i + 2);
|
|
81
|
+
commandTypes.push(parseInt(byte, 16));
|
|
82
|
+
}
|
|
83
|
+
return commandTypes;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
export function parseV3PathExactIn(path) {
|
|
87
|
+
const strippedPath = path.replace('0x', '');
|
|
88
|
+
let tokenIn = ethers.utils.getAddress(strippedPath.substring(0, 40));
|
|
89
|
+
let loc = 40;
|
|
90
|
+
const res = [];
|
|
91
|
+
while (loc < strippedPath.length) {
|
|
92
|
+
const feeAndTokenOut = strippedPath.substring(loc, loc + 46);
|
|
93
|
+
const fee = parseInt(feeAndTokenOut.substring(0, 6), 16);
|
|
94
|
+
const tokenOut = ethers.utils.getAddress(feeAndTokenOut.substring(6, 46));
|
|
95
|
+
res.push({
|
|
96
|
+
tokenIn,
|
|
97
|
+
tokenOut,
|
|
98
|
+
fee,
|
|
99
|
+
});
|
|
100
|
+
tokenIn = tokenOut;
|
|
101
|
+
loc += 46;
|
|
102
|
+
}
|
|
103
|
+
return res;
|
|
104
|
+
}
|
|
105
|
+
export function parseV3PathExactOut(path) {
|
|
106
|
+
const strippedPath = path.replace('0x', '');
|
|
107
|
+
let tokenIn = ethers.utils.getAddress(strippedPath.substring(strippedPath.length - 40));
|
|
108
|
+
let loc = strippedPath.length - 86; // 86 = (20 addr + 3 fee + 20 addr) * 2 (for hex characters)
|
|
109
|
+
const res = [];
|
|
110
|
+
while (loc >= 0) {
|
|
111
|
+
const feeAndTokenOut = strippedPath.substring(loc, loc + 46);
|
|
112
|
+
const tokenOut = ethers.utils.getAddress(feeAndTokenOut.substring(0, 40));
|
|
113
|
+
const fee = parseInt(feeAndTokenOut.substring(40, 46), 16);
|
|
114
|
+
res.push({
|
|
115
|
+
tokenIn,
|
|
116
|
+
tokenOut,
|
|
117
|
+
fee,
|
|
118
|
+
});
|
|
119
|
+
tokenIn = tokenOut;
|
|
120
|
+
loc -= 46;
|
|
121
|
+
}
|
|
122
|
+
return res;
|
|
123
|
+
}
|
|
124
|
+
function v4RouterCallToParams(actions) {
|
|
125
|
+
return actions.map((action) => {
|
|
126
|
+
return {
|
|
127
|
+
name: action.actionName,
|
|
128
|
+
value: action.params.map((param) => {
|
|
129
|
+
return {
|
|
130
|
+
name: param.name,
|
|
131
|
+
value: param.value,
|
|
132
|
+
};
|
|
133
|
+
}),
|
|
134
|
+
};
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
//# sourceMappingURL=commandParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commandParser.js","sourceRoot":"","sources":["../../../../src/utils/commandParser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { BigNumber } from 'ethers';
|
|
2
|
+
export declare enum UniversalRouterVersion {
|
|
3
|
+
V1_2 = "1.2",
|
|
4
|
+
V2_0 = "2.0"
|
|
5
|
+
}
|
|
6
|
+
export type RouterConfig = {
|
|
7
|
+
address: string;
|
|
8
|
+
creationBlock: number;
|
|
9
|
+
};
|
|
10
|
+
type ChainConfig = {
|
|
11
|
+
weth: string;
|
|
12
|
+
routerConfigs: {
|
|
13
|
+
[key in UniversalRouterVersion]: RouterConfig;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export declare const CHAIN_CONFIGS: {
|
|
17
|
+
[key: number]: ChainConfig;
|
|
18
|
+
};
|
|
19
|
+
export declare const UNIVERSAL_ROUTER_ADDRESS: (version: UniversalRouterVersion, chainId: number) => string;
|
|
20
|
+
export declare const UNIVERSAL_ROUTER_CREATION_BLOCK: (version: UniversalRouterVersion, chainId: number) => number;
|
|
21
|
+
export declare const WETH_ADDRESS: (chainId: number) => string;
|
|
22
|
+
export declare const CONTRACT_BALANCE: BigNumber;
|
|
23
|
+
export declare const ETH_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
24
|
+
export declare const E_ETH_ADDRESS = "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";
|
|
25
|
+
export declare const ZERO_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
26
|
+
export declare const MAX_UINT256: BigNumber;
|
|
27
|
+
export declare const MAX_UINT160: BigNumber;
|
|
28
|
+
export declare const SENDER_AS_RECIPIENT = "0x0000000000000000000000000000000000000001";
|
|
29
|
+
export declare const ROUTER_AS_RECIPIENT = "0x0000000000000000000000000000000000000002";
|
|
30
|
+
export {};
|