@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.
Files changed (119) hide show
  1. package/dist/{entities → cjs/src/entities}/Command.d.ts +12 -12
  2. package/dist/cjs/src/entities/Command.js +9 -0
  3. package/dist/cjs/src/entities/Command.js.map +1 -0
  4. package/dist/{entities → cjs/src/entities}/actions/index.d.ts +2 -2
  5. package/dist/cjs/src/entities/actions/index.js +6 -0
  6. package/dist/cjs/src/entities/actions/index.js.map +1 -0
  7. package/dist/{entities → cjs/src/entities}/actions/uniswap.d.ts +30 -30
  8. package/dist/cjs/src/entities/actions/uniswap.js +365 -0
  9. package/dist/cjs/src/entities/actions/uniswap.js.map +1 -0
  10. package/dist/{entities → cjs/src/entities}/actions/unwrapWETH.d.ts +12 -12
  11. package/dist/cjs/src/entities/actions/unwrapWETH.js +33 -0
  12. package/dist/cjs/src/entities/actions/unwrapWETH.js.map +1 -0
  13. package/dist/{entities → cjs/src/entities}/index.d.ts +2 -2
  14. package/dist/cjs/src/entities/index.js +6 -0
  15. package/dist/cjs/src/entities/index.js.map +1 -0
  16. package/dist/cjs/src/index.d.ts +9 -0
  17. package/dist/cjs/src/index.js +24 -0
  18. package/dist/cjs/src/index.js.map +1 -0
  19. package/dist/{swapRouter.d.ts → cjs/src/swapRouter.d.ts} +37 -37
  20. package/dist/cjs/src/swapRouter.js +120 -0
  21. package/dist/cjs/src/swapRouter.js.map +1 -0
  22. package/dist/{utils → cjs/src/utils}/commandParser.d.ts +34 -34
  23. package/dist/cjs/src/utils/commandParser.js +144 -0
  24. package/dist/cjs/src/utils/commandParser.js.map +1 -0
  25. package/dist/{utils → cjs/src/utils}/constants.d.ts +30 -30
  26. package/dist/cjs/src/utils/constants.js +373 -0
  27. package/dist/cjs/src/utils/constants.js.map +1 -0
  28. package/dist/{utils → cjs/src/utils}/getCurrencyAddress.d.ts +2 -2
  29. package/dist/cjs/src/utils/getCurrencyAddress.js +9 -0
  30. package/dist/cjs/src/utils/getCurrencyAddress.js.map +1 -0
  31. package/dist/{utils → cjs/src/utils}/inputTokens.d.ts +23 -23
  32. package/dist/cjs/src/utils/inputTokens.js +58 -0
  33. package/dist/cjs/src/utils/inputTokens.js.map +1 -0
  34. package/dist/{utils → cjs/src/utils}/numbers.d.ts +6 -6
  35. package/dist/cjs/src/utils/numbers.js +22 -0
  36. package/dist/cjs/src/utils/numbers.js.map +1 -0
  37. package/dist/{utils → cjs/src/utils}/pathCurrency.d.ts +3 -3
  38. package/dist/cjs/src/utils/pathCurrency.js +27 -0
  39. package/dist/cjs/src/utils/pathCurrency.js.map +1 -0
  40. package/dist/{utils → cjs/src/utils}/routerCommands.d.ts +64 -64
  41. package/dist/cjs/src/utils/routerCommands.js +231 -0
  42. package/dist/cjs/src/utils/routerCommands.js.map +1 -0
  43. package/dist/{utils → cjs/src/utils}/routerTradeAdapter.d.ts +73 -73
  44. package/dist/cjs/src/utils/routerTradeAdapter.js +139 -0
  45. package/dist/cjs/src/utils/routerTradeAdapter.js.map +1 -0
  46. package/dist/esm/src/entities/Command.d.ts +12 -0
  47. package/dist/esm/src/entities/Command.js +6 -0
  48. package/dist/esm/src/entities/Command.js.map +1 -0
  49. package/dist/esm/src/entities/actions/index.d.ts +2 -0
  50. package/dist/esm/src/entities/actions/index.js +3 -0
  51. package/dist/esm/src/entities/actions/index.js.map +1 -0
  52. package/dist/esm/src/entities/actions/uniswap.d.ts +30 -0
  53. package/dist/esm/src/entities/actions/uniswap.js +361 -0
  54. package/dist/esm/src/entities/actions/uniswap.js.map +1 -0
  55. package/dist/esm/src/entities/actions/unwrapWETH.d.ts +12 -0
  56. package/dist/esm/src/entities/actions/unwrapWETH.js +28 -0
  57. package/dist/esm/src/entities/actions/unwrapWETH.js.map +1 -0
  58. package/dist/esm/src/entities/index.d.ts +2 -0
  59. package/dist/esm/src/entities/index.js +3 -0
  60. package/dist/esm/src/entities/index.js.map +1 -0
  61. package/dist/esm/src/index.d.ts +9 -0
  62. package/dist/esm/src/index.js +7 -0
  63. package/dist/esm/src/index.js.map +1 -0
  64. package/dist/esm/src/swapRouter.d.ts +37 -0
  65. package/dist/esm/src/swapRouter.js +115 -0
  66. package/dist/esm/src/swapRouter.js.map +1 -0
  67. package/dist/esm/src/utils/commandParser.d.ts +34 -0
  68. package/dist/esm/src/utils/commandParser.js +137 -0
  69. package/dist/esm/src/utils/commandParser.js.map +1 -0
  70. package/dist/esm/src/utils/constants.d.ts +30 -0
  71. package/dist/esm/src/utils/constants.js +367 -0
  72. package/dist/esm/src/utils/constants.js.map +1 -0
  73. package/dist/esm/src/utils/getCurrencyAddress.d.ts +2 -0
  74. package/dist/esm/src/utils/getCurrencyAddress.js +5 -0
  75. package/dist/esm/src/utils/getCurrencyAddress.js.map +1 -0
  76. package/dist/esm/src/utils/inputTokens.d.ts +23 -0
  77. package/dist/esm/src/utils/inputTokens.js +51 -0
  78. package/dist/esm/src/utils/inputTokens.js.map +1 -0
  79. package/dist/esm/src/utils/numbers.d.ts +6 -0
  80. package/dist/esm/src/utils/numbers.js +15 -0
  81. package/dist/esm/src/utils/numbers.js.map +1 -0
  82. package/dist/esm/src/utils/pathCurrency.d.ts +3 -0
  83. package/dist/esm/src/utils/pathCurrency.js +23 -0
  84. package/dist/esm/src/utils/pathCurrency.js.map +1 -0
  85. package/dist/esm/src/utils/routerCommands.d.ts +64 -0
  86. package/dist/esm/src/utils/routerCommands.js +226 -0
  87. package/dist/esm/src/utils/routerCommands.js.map +1 -0
  88. package/dist/esm/src/utils/routerTradeAdapter.d.ts +73 -0
  89. package/dist/esm/src/utils/routerTradeAdapter.js +134 -0
  90. package/dist/esm/src/utils/routerTradeAdapter.js.map +1 -0
  91. package/dist/types/src/entities/Command.d.ts +12 -0
  92. package/dist/types/src/entities/actions/index.d.ts +2 -0
  93. package/dist/types/src/entities/actions/uniswap.d.ts +30 -0
  94. package/dist/types/src/entities/actions/unwrapWETH.d.ts +12 -0
  95. package/dist/types/src/entities/index.d.ts +2 -0
  96. package/dist/types/src/index.d.ts +9 -0
  97. package/dist/types/src/swapRouter.d.ts +37 -0
  98. package/dist/types/src/utils/commandParser.d.ts +34 -0
  99. package/dist/types/src/utils/constants.d.ts +30 -0
  100. package/dist/types/src/utils/getCurrencyAddress.d.ts +2 -0
  101. package/dist/types/src/utils/inputTokens.d.ts +23 -0
  102. package/dist/types/src/utils/numbers.d.ts +6 -0
  103. package/dist/types/src/utils/pathCurrency.d.ts +3 -0
  104. package/dist/types/src/utils/routerCommands.d.ts +64 -0
  105. package/dist/types/src/utils/routerTradeAdapter.d.ts +73 -0
  106. package/package.json +17 -5
  107. package/dist/index.d.ts +0 -6
  108. package/dist/index.js +0 -8
  109. package/dist/test/forge/writeInterop.d.ts +0 -2
  110. package/dist/test/utils/addresses.d.ts +0 -5
  111. package/dist/test/utils/hexToDecimalString.d.ts +0 -2
  112. package/dist/test/utils/permit2.d.ts +0 -7
  113. package/dist/test/utils/uniswapData.d.ts +0 -24
  114. package/dist/universal-router-sdk.cjs.development.js +0 -1433
  115. package/dist/universal-router-sdk.cjs.development.js.map +0 -1
  116. package/dist/universal-router-sdk.cjs.production.min.js +0 -2
  117. package/dist/universal-router-sdk.cjs.production.min.js.map +0 -1
  118. package/dist/universal-router-sdk.esm.js +0 -1426
  119. package/dist/universal-router-sdk.esm.js.map +0 -1
@@ -1,1433 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
6
-
7
- var invariant = _interopDefault(require('tiny-invariant'));
8
- var UniversalRouter_json = require('@uniswap/universal-router/artifacts/contracts/UniversalRouter.sol/UniversalRouter.json');
9
- var abi = require('@ethersproject/abi');
10
- var ethers = require('ethers');
11
- var v3Sdk = require('@uniswap/v3-sdk');
12
- var v4Sdk = require('@uniswap/v4-sdk');
13
- var sdkCore = require('@uniswap/sdk-core');
14
- var utils = require('ethers/lib/utils');
15
- var v2Sdk = require('@uniswap/v2-sdk');
16
- var routerSdk = require('@uniswap/router-sdk');
17
- require('jsbi');
18
- require('bignumber.js');
19
-
20
- function _toPrimitive(t, r) {
21
- if ("object" != typeof t || !t) return t;
22
- var e = t[Symbol.toPrimitive];
23
- if (void 0 !== e) {
24
- var i = e.call(t, r || "default");
25
- if ("object" != typeof i) return i;
26
- throw new TypeError("@@toPrimitive must return a primitive value.");
27
- }
28
- return ("string" === r ? String : Number)(t);
29
- }
30
- function _toPropertyKey(t) {
31
- var i = _toPrimitive(t, "string");
32
- return "symbol" == typeof i ? i : String(i);
33
- }
34
- function _defineProperties(target, props) {
35
- for (var i = 0; i < props.length; i++) {
36
- var descriptor = props[i];
37
- descriptor.enumerable = descriptor.enumerable || false;
38
- descriptor.configurable = true;
39
- if ("value" in descriptor) descriptor.writable = true;
40
- Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);
41
- }
42
- }
43
- function _createClass(Constructor, protoProps, staticProps) {
44
- if (protoProps) _defineProperties(Constructor.prototype, protoProps);
45
- if (staticProps) _defineProperties(Constructor, staticProps);
46
- Object.defineProperty(Constructor, "prototype", {
47
- writable: false
48
- });
49
- return Constructor;
50
- }
51
- function _unsupportedIterableToArray(o, minLen) {
52
- if (!o) return;
53
- if (typeof o === "string") return _arrayLikeToArray(o, minLen);
54
- var n = Object.prototype.toString.call(o).slice(8, -1);
55
- if (n === "Object" && o.constructor) n = o.constructor.name;
56
- if (n === "Map" || n === "Set") return Array.from(o);
57
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
58
- }
59
- function _arrayLikeToArray(arr, len) {
60
- if (len == null || len > arr.length) len = arr.length;
61
- for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
62
- return arr2;
63
- }
64
- function _createForOfIteratorHelperLoose(o, allowArrayLike) {
65
- var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
66
- if (it) return (it = it.call(o)).next.bind(it);
67
- if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
68
- if (it) o = it;
69
- var i = 0;
70
- return function () {
71
- if (i >= o.length) return {
72
- done: true
73
- };
74
- return {
75
- done: false,
76
- value: o[i++]
77
- };
78
- };
79
- }
80
- throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
81
- }
82
-
83
- var _COMMAND_DEFINITION;
84
- (function (CommandType) {
85
- CommandType[CommandType["V3_SWAP_EXACT_IN"] = 0] = "V3_SWAP_EXACT_IN";
86
- CommandType[CommandType["V3_SWAP_EXACT_OUT"] = 1] = "V3_SWAP_EXACT_OUT";
87
- CommandType[CommandType["PERMIT2_TRANSFER_FROM"] = 2] = "PERMIT2_TRANSFER_FROM";
88
- CommandType[CommandType["PERMIT2_PERMIT_BATCH"] = 3] = "PERMIT2_PERMIT_BATCH";
89
- CommandType[CommandType["SWEEP"] = 4] = "SWEEP";
90
- CommandType[CommandType["TRANSFER"] = 5] = "TRANSFER";
91
- CommandType[CommandType["PAY_PORTION"] = 6] = "PAY_PORTION";
92
- CommandType[CommandType["V2_SWAP_EXACT_IN"] = 8] = "V2_SWAP_EXACT_IN";
93
- CommandType[CommandType["V2_SWAP_EXACT_OUT"] = 9] = "V2_SWAP_EXACT_OUT";
94
- CommandType[CommandType["PERMIT2_PERMIT"] = 10] = "PERMIT2_PERMIT";
95
- CommandType[CommandType["WRAP_ETH"] = 11] = "WRAP_ETH";
96
- CommandType[CommandType["UNWRAP_WETH"] = 12] = "UNWRAP_WETH";
97
- CommandType[CommandType["PERMIT2_TRANSFER_FROM_BATCH"] = 13] = "PERMIT2_TRANSFER_FROM_BATCH";
98
- CommandType[CommandType["BALANCE_CHECK_ERC20"] = 14] = "BALANCE_CHECK_ERC20";
99
- CommandType[CommandType["V4_SWAP"] = 16] = "V4_SWAP";
100
- CommandType[CommandType["V3_POSITION_MANAGER_PERMIT"] = 17] = "V3_POSITION_MANAGER_PERMIT";
101
- CommandType[CommandType["V3_POSITION_MANAGER_CALL"] = 18] = "V3_POSITION_MANAGER_CALL";
102
- CommandType[CommandType["V4_INITIALIZE_POOL"] = 19] = "V4_INITIALIZE_POOL";
103
- CommandType[CommandType["V4_POSITION_MANAGER_CALL"] = 20] = "V4_POSITION_MANAGER_CALL";
104
- CommandType[CommandType["EXECUTE_SUB_PLAN"] = 33] = "EXECUTE_SUB_PLAN";
105
- })(exports.CommandType || (exports.CommandType = {}));
106
- (function (Subparser) {
107
- Subparser[Subparser["V3PathExactIn"] = 0] = "V3PathExactIn";
108
- Subparser[Subparser["V3PathExactOut"] = 1] = "V3PathExactOut";
109
- })(exports.Subparser || (exports.Subparser = {}));
110
- (function (Parser) {
111
- Parser[Parser["Abi"] = 0] = "Abi";
112
- Parser[Parser["V4Actions"] = 1] = "V4Actions";
113
- Parser[Parser["V3Actions"] = 2] = "V3Actions";
114
- })(exports.Parser || (exports.Parser = {}));
115
- var ALLOW_REVERT_FLAG = 0x80;
116
- var REVERTIBLE_COMMANDS = /*#__PURE__*/new Set([exports.CommandType.EXECUTE_SUB_PLAN]);
117
- var PERMIT_STRUCT = '((address token,uint160 amount,uint48 expiration,uint48 nonce) details,address spender,uint256 sigDeadline)';
118
- var PERMIT_BATCH_STRUCT = '((address token,uint160 amount,uint48 expiration,uint48 nonce)[] details,address spender,uint256 sigDeadline)';
119
- var POOL_KEY_STRUCT = '(address currency0,address currency1,uint24 fee,int24 tickSpacing,address hooks)';
120
- var PERMIT2_TRANSFER_FROM_STRUCT = '(address from,address to,uint160 amount,address token)';
121
- var PERMIT2_TRANSFER_FROM_BATCH_STRUCT = PERMIT2_TRANSFER_FROM_STRUCT + '[]';
122
- var COMMAND_DEFINITION = (_COMMAND_DEFINITION = {}, _COMMAND_DEFINITION[exports.CommandType.EXECUTE_SUB_PLAN] = {
123
- parser: exports.Parser.Abi,
124
- params: [{
125
- name: 'commands',
126
- type: 'bytes'
127
- }, {
128
- name: 'inputs',
129
- type: 'bytes[]'
130
- }]
131
- }, _COMMAND_DEFINITION[exports.CommandType.PERMIT2_PERMIT] = {
132
- parser: exports.Parser.Abi,
133
- params: [{
134
- name: 'permit',
135
- type: PERMIT_STRUCT
136
- }, {
137
- name: 'signature',
138
- type: 'bytes'
139
- }]
140
- }, _COMMAND_DEFINITION[exports.CommandType.PERMIT2_PERMIT_BATCH] = {
141
- parser: exports.Parser.Abi,
142
- params: [{
143
- name: 'permit',
144
- type: PERMIT_BATCH_STRUCT
145
- }, {
146
- name: 'signature',
147
- type: 'bytes'
148
- }]
149
- }, _COMMAND_DEFINITION[exports.CommandType.PERMIT2_TRANSFER_FROM] = {
150
- parser: exports.Parser.Abi,
151
- params: [{
152
- name: 'token',
153
- type: 'address'
154
- }, {
155
- name: 'recipient',
156
- type: 'address'
157
- }, {
158
- name: 'amount',
159
- type: 'uint160'
160
- }]
161
- }, _COMMAND_DEFINITION[exports.CommandType.PERMIT2_TRANSFER_FROM_BATCH] = {
162
- parser: exports.Parser.Abi,
163
- params: [{
164
- name: 'transferFrom',
165
- type: PERMIT2_TRANSFER_FROM_BATCH_STRUCT
166
- }]
167
- }, _COMMAND_DEFINITION[exports.CommandType.V3_SWAP_EXACT_IN] = {
168
- parser: exports.Parser.Abi,
169
- params: [{
170
- name: 'recipient',
171
- type: 'address'
172
- }, {
173
- name: 'amountIn',
174
- type: 'uint256'
175
- }, {
176
- name: 'amountOutMin',
177
- type: 'uint256'
178
- }, {
179
- name: 'path',
180
- subparser: exports.Subparser.V3PathExactIn,
181
- type: 'bytes'
182
- }, {
183
- name: 'payerIsUser',
184
- type: 'bool'
185
- }]
186
- }, _COMMAND_DEFINITION[exports.CommandType.V3_SWAP_EXACT_OUT] = {
187
- parser: exports.Parser.Abi,
188
- params: [{
189
- name: 'recipient',
190
- type: 'address'
191
- }, {
192
- name: 'amountOut',
193
- type: 'uint256'
194
- }, {
195
- name: 'amountInMax',
196
- type: 'uint256'
197
- }, {
198
- name: 'path',
199
- subparser: exports.Subparser.V3PathExactOut,
200
- type: 'bytes'
201
- }, {
202
- name: 'payerIsUser',
203
- type: 'bool'
204
- }]
205
- }, _COMMAND_DEFINITION[exports.CommandType.V2_SWAP_EXACT_IN] = {
206
- parser: exports.Parser.Abi,
207
- params: [{
208
- name: 'recipient',
209
- type: 'address'
210
- }, {
211
- name: 'amountIn',
212
- type: 'uint256'
213
- }, {
214
- name: 'amountOutMin',
215
- type: 'uint256'
216
- }, {
217
- name: 'path',
218
- type: 'address[]'
219
- }, {
220
- name: 'payerIsUser',
221
- type: 'bool'
222
- }]
223
- }, _COMMAND_DEFINITION[exports.CommandType.V2_SWAP_EXACT_OUT] = {
224
- parser: exports.Parser.Abi,
225
- params: [{
226
- name: 'recipient',
227
- type: 'address'
228
- }, {
229
- name: 'amountOut',
230
- type: 'uint256'
231
- }, {
232
- name: 'amountInMax',
233
- type: 'uint256'
234
- }, {
235
- name: 'path',
236
- type: 'address[]'
237
- }, {
238
- name: 'payerIsUser',
239
- type: 'bool'
240
- }]
241
- }, _COMMAND_DEFINITION[exports.CommandType.V4_SWAP] = {
242
- parser: exports.Parser.V4Actions
243
- }, _COMMAND_DEFINITION[exports.CommandType.WRAP_ETH] = {
244
- parser: exports.Parser.Abi,
245
- params: [{
246
- name: 'recipient',
247
- type: 'address'
248
- }, {
249
- name: 'amount',
250
- type: 'uint256'
251
- }]
252
- }, _COMMAND_DEFINITION[exports.CommandType.UNWRAP_WETH] = {
253
- parser: exports.Parser.Abi,
254
- params: [{
255
- name: 'recipient',
256
- type: 'address'
257
- }, {
258
- name: 'amountMin',
259
- type: 'uint256'
260
- }]
261
- }, _COMMAND_DEFINITION[exports.CommandType.SWEEP] = {
262
- parser: exports.Parser.Abi,
263
- params: [{
264
- name: 'token',
265
- type: 'address'
266
- }, {
267
- name: 'recipient',
268
- type: 'address'
269
- }, {
270
- name: 'amountMin',
271
- type: 'uint256'
272
- }]
273
- }, _COMMAND_DEFINITION[exports.CommandType.TRANSFER] = {
274
- parser: exports.Parser.Abi,
275
- params: [{
276
- name: 'token',
277
- type: 'address'
278
- }, {
279
- name: 'recipient',
280
- type: 'address'
281
- }, {
282
- name: 'value',
283
- type: 'uint256'
284
- }]
285
- }, _COMMAND_DEFINITION[exports.CommandType.PAY_PORTION] = {
286
- parser: exports.Parser.Abi,
287
- params: [{
288
- name: 'token',
289
- type: 'address'
290
- }, {
291
- name: 'recipient',
292
- type: 'address'
293
- }, {
294
- name: 'bips',
295
- type: 'uint256'
296
- }]
297
- }, _COMMAND_DEFINITION[exports.CommandType.BALANCE_CHECK_ERC20] = {
298
- parser: exports.Parser.Abi,
299
- params: [{
300
- name: 'owner',
301
- type: 'address'
302
- }, {
303
- name: 'token',
304
- type: 'address'
305
- }, {
306
- name: 'minBalance',
307
- type: 'uint256'
308
- }]
309
- }, _COMMAND_DEFINITION[exports.CommandType.V4_INITIALIZE_POOL] = {
310
- parser: exports.Parser.Abi,
311
- params: [{
312
- name: 'poolKey',
313
- type: POOL_KEY_STRUCT
314
- }, {
315
- name: 'sqrtPriceX96',
316
- type: 'uint160'
317
- }]
318
- }, _COMMAND_DEFINITION[exports.CommandType.V3_POSITION_MANAGER_PERMIT] = {
319
- parser: exports.Parser.V3Actions
320
- }, _COMMAND_DEFINITION[exports.CommandType.V3_POSITION_MANAGER_CALL] = {
321
- parser: exports.Parser.V3Actions
322
- }, _COMMAND_DEFINITION[exports.CommandType.V4_POSITION_MANAGER_CALL] = {
323
- parser: exports.Parser.V4Actions
324
- }, _COMMAND_DEFINITION);
325
- var RoutePlanner = /*#__PURE__*/function () {
326
- function RoutePlanner() {
327
- this.commands = '0x';
328
- this.inputs = [];
329
- }
330
- var _proto = RoutePlanner.prototype;
331
- _proto.addSubPlan = function addSubPlan(subplan) {
332
- this.addCommand(exports.CommandType.EXECUTE_SUB_PLAN, [subplan.commands, subplan.inputs], true);
333
- return this;
334
- };
335
- _proto.addCommand = function addCommand(type, parameters, allowRevert) {
336
- if (allowRevert === void 0) {
337
- allowRevert = false;
338
- }
339
- var command = createCommand(type, parameters);
340
- this.inputs.push(command.encodedInput);
341
- if (allowRevert) {
342
- if (!REVERTIBLE_COMMANDS.has(command.type)) {
343
- throw new Error("command type: " + command.type + " cannot be allowed to revert");
344
- }
345
- command.type = command.type | ALLOW_REVERT_FLAG;
346
- }
347
- this.commands = this.commands.concat(command.type.toString(16).padStart(2, '0'));
348
- return this;
349
- };
350
- return RoutePlanner;
351
- }();
352
- function createCommand(type, parameters) {
353
- var commandDef = COMMAND_DEFINITION[type];
354
- switch (commandDef.parser) {
355
- case exports.Parser.Abi:
356
- var encodedInput = utils.defaultAbiCoder.encode(commandDef.params.map(function (abi) {
357
- return abi.type;
358
- }), parameters);
359
- return {
360
- type: type,
361
- encodedInput: encodedInput
362
- };
363
- case exports.Parser.V4Actions:
364
- // v4 swap data comes pre-encoded at index 0
365
- return {
366
- type: type,
367
- encodedInput: parameters[0]
368
- };
369
- case exports.Parser.V3Actions:
370
- // v4 swap data comes pre-encoded at index 0
371
- return {
372
- type: type,
373
- encodedInput: parameters[0]
374
- };
375
- }
376
- }
377
-
378
- function getPathCurrency(currency, pool) {
379
- // return currency if the currency matches a currency of the pool
380
- if (pool.involvesToken(currency)) {
381
- return currency;
382
- // return if currency.wrapped if pool involves wrapped currency
383
- } else if (pool.involvesToken(currency.wrapped)) {
384
- return currency.wrapped;
385
- // return native currency if pool involves native version of wrapped currency (only applies to V4)
386
- } else if (pool instanceof v4Sdk.Pool && pool.token0.wrapped.equals(currency)) {
387
- return pool.token0;
388
- } else if (pool instanceof v4Sdk.Pool && pool.token1.wrapped.equals(currency)) {
389
- return pool.token1;
390
- } else {
391
- throw new Error("Expected currency " + currency.symbol + " to be either " + pool.token0.symbol + " or " + pool.token1.symbol);
392
- }
393
- }
394
-
395
- (function (RouterActionType) {
396
- RouterActionType["UniswapTrade"] = "UniswapTrade";
397
- RouterActionType["UnwrapWETH"] = "UnwrapWETH";
398
- })(exports.RouterActionType || (exports.RouterActionType = {}));
399
-
400
- var _routerConfigs, _routerConfigs2, _routerConfigs3, _routerConfigs4, _routerConfigs5, _routerConfigs6, _routerConfigs7, _routerConfigs8, _routerConfigs9, _routerConfigs10, _routerConfigs11, _routerConfigs12, _routerConfigs13, _routerConfigs14, _routerConfigs15, _routerConfigs16, _routerConfigs17, _routerConfigs18, _routerConfigs19, _routerConfigs20, _routerConfigs21, _routerConfigs22, _routerConfigs23, _routerConfigs24, _CHAIN_CONFIGS;
401
- (function (UniversalRouterVersion) {
402
- UniversalRouterVersion["V1_2"] = "1.2";
403
- UniversalRouterVersion["V2_0"] = "2.0";
404
- })(exports.UniversalRouterVersion || (exports.UniversalRouterVersion = {}));
405
- var WETH_NOT_SUPPORTED_ON_CHAIN = '0x0000000000000000000000000000000000000000';
406
- // Todo: Change `CHAIN_CONFIGS` to pull the UR address with v4
407
- var CHAIN_CONFIGS = (_CHAIN_CONFIGS = {}, _CHAIN_CONFIGS[1] = {
408
- weth: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
409
- routerConfigs: (_routerConfigs = {}, _routerConfigs[exports.UniversalRouterVersion.V1_2] = {
410
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
411
- creationBlock: 17143817
412
- }, _routerConfigs[exports.UniversalRouterVersion.V2_0] = {
413
- address: '0x66a9893cc07d91d95644aedd05d03f95e1dba8af',
414
- creationBlock: 1737658355
415
- }, _routerConfigs)
416
- }, _CHAIN_CONFIGS[5] = {
417
- weth: '0xb4fbf271143f4fbf7b91a5ded31805e42b2208d6',
418
- routerConfigs: (_routerConfigs2 = {}, _routerConfigs2[exports.UniversalRouterVersion.V1_2] = {
419
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
420
- creationBlock: 8940568
421
- }, _routerConfigs2[exports.UniversalRouterVersion.V2_0] = {
422
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
423
- creationBlock: 8940568
424
- }, _routerConfigs2)
425
- }, _CHAIN_CONFIGS[11155111] = {
426
- weth: '0xfFf9976782d46CC05630D1f6eBAb18b2324d6B14',
427
- routerConfigs: (_routerConfigs3 = {}, _routerConfigs3[exports.UniversalRouterVersion.V1_2] = {
428
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
429
- creationBlock: 3543575
430
- }, _routerConfigs3[exports.UniversalRouterVersion.V2_0] = {
431
- address: '0x3a9d48ab9751398bbfa63ad67599bb04e4bdf98b',
432
- creationBlock: 7259601
433
- }, _routerConfigs3)
434
- }, _CHAIN_CONFIGS[137] = {
435
- weth: '0x0d500B1d8E8eF31E21C99d1Db9A6444d3ADf1270',
436
- routerConfigs: (_routerConfigs4 = {}, _routerConfigs4[exports.UniversalRouterVersion.V1_2] = {
437
- address: '0xec7BE89e9d109e7e3Fec59c222CF297125FEFda2',
438
- creationBlock: 52210153
439
- }, _routerConfigs4[exports.UniversalRouterVersion.V2_0] = {
440
- address: '0x1095692a6237d83c6a72f3f5efedb9a670c49223',
441
- creationBlock: 1737492197
442
- }, _routerConfigs4)
443
- }, _CHAIN_CONFIGS[80001] = {
444
- weth: '0x9c3C9283D3e44854697Cd22D3Faa240Cfb032889',
445
- routerConfigs: (_routerConfigs5 = {}, _routerConfigs5[exports.UniversalRouterVersion.V1_2] = {
446
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
447
- creationBlock: 35176052
448
- }, _routerConfigs5[exports.UniversalRouterVersion.V2_0] = {
449
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
450
- creationBlock: 35176052
451
- }, _routerConfigs5)
452
- }, _CHAIN_CONFIGS[10] = {
453
- weth: '0x4200000000000000000000000000000000000006',
454
- routerConfigs: (_routerConfigs6 = {}, _routerConfigs6[exports.UniversalRouterVersion.V1_2] = {
455
- address: '0xCb1355ff08Ab38bBCE60111F1bb2B784bE25D7e8',
456
- creationBlock: 114702266
457
- }, _routerConfigs6[exports.UniversalRouterVersion.V2_0] = {
458
- address: '0x851116d9223fabed8e56c0e6b8ad0c31d98b3507',
459
- creationBlock: 1737494278
460
- }, _routerConfigs6)
461
- }, _CHAIN_CONFIGS[420] = {
462
- weth: '0x4200000000000000000000000000000000000006',
463
- routerConfigs: (_routerConfigs7 = {}, _routerConfigs7[exports.UniversalRouterVersion.V1_2] = {
464
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
465
- creationBlock: 8887728
466
- }, _routerConfigs7[exports.UniversalRouterVersion.V2_0] = {
467
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
468
- creationBlock: 8887728
469
- }, _routerConfigs7)
470
- }, _CHAIN_CONFIGS[42161] = {
471
- weth: '0x82aF49447D8a07e3bd95BD0d56f35241523fBab1',
472
- routerConfigs: (_routerConfigs8 = {}, _routerConfigs8[exports.UniversalRouterVersion.V1_2] = {
473
- address: '0x5E325eDA8064b456f4781070C0738d849c824258',
474
- creationBlock: 169472836
475
- }, _routerConfigs8[exports.UniversalRouterVersion.V2_0] = {
476
- address: '0xa51afafe0263b40edaef0df8781ea9aa03e381a3',
477
- creationBlock: 1737487458
478
- }, _routerConfigs8)
479
- }, _CHAIN_CONFIGS[421613] = {
480
- weth: '0xe39Ab88f8A4777030A534146A9Ca3B52bd5D43A3',
481
- routerConfigs: (_routerConfigs9 = {}, _routerConfigs9[exports.UniversalRouterVersion.V1_2] = {
482
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
483
- creationBlock: 18815277
484
- }, _routerConfigs9[exports.UniversalRouterVersion.V2_0] = {
485
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
486
- creationBlock: 18815277
487
- }, _routerConfigs9)
488
- }, _CHAIN_CONFIGS[42220] = {
489
- weth: WETH_NOT_SUPPORTED_ON_CHAIN,
490
- routerConfigs: (_routerConfigs10 = {}, _routerConfigs10[exports.UniversalRouterVersion.V1_2] = {
491
- address: '0x643770e279d5d0733f21d6dc03a8efbabf3255b4',
492
- creationBlock: 21407637
493
- }, _routerConfigs10[exports.UniversalRouterVersion.V2_0] = {
494
- address: '0x643770e279d5d0733f21d6dc03a8efbabf3255b4',
495
- creationBlock: 21407637
496
- }, _routerConfigs10)
497
- }, _CHAIN_CONFIGS[44787] = {
498
- weth: WETH_NOT_SUPPORTED_ON_CHAIN,
499
- routerConfigs: (_routerConfigs11 = {}, _routerConfigs11[exports.UniversalRouterVersion.V1_2] = {
500
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
501
- creationBlock: 17566658
502
- }, _routerConfigs11[exports.UniversalRouterVersion.V2_0] = {
503
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
504
- creationBlock: 17566658
505
- }, _routerConfigs11)
506
- }, _CHAIN_CONFIGS[56] = {
507
- weth: '0xbb4CdB9CBd36B01bD1cBaEBF2De08d9173bc095c',
508
- routerConfigs: (_routerConfigs12 = {}, _routerConfigs12[exports.UniversalRouterVersion.V1_2] = {
509
- address: '0x4Dae2f939ACf50408e13d58534Ff8c2776d45265',
510
- creationBlock: 35160263
511
- }, _routerConfigs12[exports.UniversalRouterVersion.V2_0] = {
512
- address: '0x1906c1d672b88cd1b9ac7593301ca990f94eae07',
513
- creationBlock: 1737493275
514
- }, _routerConfigs12)
515
- }, _CHAIN_CONFIGS[43114] = {
516
- weth: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7',
517
- routerConfigs: (_routerConfigs13 = {}, _routerConfigs13[exports.UniversalRouterVersion.V1_2] = {
518
- address: '0x4Dae2f939ACf50408e13d58534Ff8c2776d45265',
519
- creationBlock: 40237257
520
- }, _routerConfigs13[exports.UniversalRouterVersion.V2_0] = {
521
- address: '0x94b75331ae8d42c1b61065089b7d48fe14aa73b7',
522
- creationBlock: 1737558236
523
- }, _routerConfigs13)
524
- }, _CHAIN_CONFIGS[84531] = {
525
- weth: '0x4200000000000000000000000000000000000006',
526
- routerConfigs: (_routerConfigs14 = {}, _routerConfigs14[exports.UniversalRouterVersion.V1_2] = {
527
- address: '0xd0872d928672ae2ff74bdb2f5130ac12229cafaf',
528
- creationBlock: 6915289
529
- }, _routerConfigs14[exports.UniversalRouterVersion.V2_0] = {
530
- address: '0xd0872d928672ae2ff74bdb2f5130ac12229cafaf',
531
- creationBlock: 6915289
532
- }, _routerConfigs14)
533
- }, _CHAIN_CONFIGS[8453] = {
534
- weth: '0x4200000000000000000000000000000000000006',
535
- routerConfigs: (_routerConfigs15 = {}, _routerConfigs15[exports.UniversalRouterVersion.V1_2] = {
536
- address: '0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD',
537
- creationBlock: 9107268
538
- }, _routerConfigs15[exports.UniversalRouterVersion.V2_0] = {
539
- address: '0x6ff5693b99212da76ad316178a184ab56d299b43',
540
- creationBlock: 1737491485
541
- }, _routerConfigs15)
542
- }, _CHAIN_CONFIGS[81457] = {
543
- weth: '0x4300000000000000000000000000000000000004',
544
- routerConfigs: (_routerConfigs16 = {}, _routerConfigs16[exports.UniversalRouterVersion.V1_2] = {
545
- address: '0x643770E279d5D0733F21d6DC03A8efbABf3255B4',
546
- creationBlock: 1116444
547
- }, _routerConfigs16[exports.UniversalRouterVersion.V2_0] = {
548
- address: '0xeabbcb3e8e415306207ef514f660a3f820025be3',
549
- creationBlock: 1737564586
550
- }, _routerConfigs16)
551
- }, _CHAIN_CONFIGS[7777777] = {
552
- weth: '0x4200000000000000000000000000000000000006',
553
- routerConfigs: (_routerConfigs17 = {}, _routerConfigs17[exports.UniversalRouterVersion.V1_2] = {
554
- address: '0x2986d9721A49838ab4297b695858aF7F17f38014',
555
- creationBlock: 11832155
556
- }, _routerConfigs17[exports.UniversalRouterVersion.V2_0] = {
557
- address: '0x3315ef7ca28db74abadc6c44570efdf06b04b020',
558
- creationBlock: 1737562927
559
- }, _routerConfigs17)
560
- }, _CHAIN_CONFIGS[324] = {
561
- weth: '0x5aea5775959fbc2557cc8789bc1bf90a239d9a91',
562
- routerConfigs: (_routerConfigs18 = {}, _routerConfigs18[exports.UniversalRouterVersion.V1_2] = {
563
- address: '0x28731BCC616B5f51dD52CF2e4dF0E78dD1136C06',
564
- creationBlock: 12640979
565
- }, _routerConfigs18[exports.UniversalRouterVersion.V2_0] = {
566
- address: '0x28731BCC616B5f51dD52CF2e4dF0E78dD1136C06',
567
- creationBlock: 12640979
568
- }, _routerConfigs18)
569
- }, _CHAIN_CONFIGS[480] = {
570
- weth: '0x4200000000000000000000000000000000000006',
571
- routerConfigs: (_routerConfigs19 = {}, _routerConfigs19[exports.UniversalRouterVersion.V1_2] = {
572
- address: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D',
573
- creationBlock: 4063979
574
- }, _routerConfigs19[exports.UniversalRouterVersion.V2_0] = {
575
- address: '0x8ac7bee993bb44dab564ea4bc9ea67bf9eb5e743',
576
- creationBlock: 1737559557
577
- }, _routerConfigs19)
578
- }, _CHAIN_CONFIGS[1301] = {
579
- weth: '0x4200000000000000000000000000000000000006',
580
- routerConfigs: (_routerConfigs20 = {}, _routerConfigs20[exports.UniversalRouterVersion.V1_2] = {
581
- address: '0x8909Dc15e40173Ff4699343b6eB8132c65e18eC6',
582
- creationBlock: 1241811
583
- }, _routerConfigs20[exports.UniversalRouterVersion.V2_0] = {
584
- address: '0xf70536b3bcc1bd1a972dc186a2cf84cc6da6be5d',
585
- creationBlock: 7100543
586
- }, _routerConfigs20)
587
- }, _CHAIN_CONFIGS[130] = {
588
- weth: '0x4200000000000000000000000000000000000006',
589
- routerConfigs: (_routerConfigs21 = {}, _routerConfigs21[exports.UniversalRouterVersion.V1_2] = {
590
- address: '0x4D73A4411CA1c660035e4AECC8270E5DdDEC8C17',
591
- creationBlock: 23678
592
- }, _routerConfigs21[exports.UniversalRouterVersion.V2_0] = {
593
- address: '0xef740bf23acae26f6492b10de645d6b98dc8eaf3',
594
- creationBlock: 1737568156
595
- }, _routerConfigs21)
596
- }, _CHAIN_CONFIGS[10143] = {
597
- weth: '0x760AfE86e5de5fa0Ee542fc7B7B713e1c5425701',
598
- routerConfigs: (_routerConfigs22 = {}, _routerConfigs22[exports.UniversalRouterVersion.V1_2] = {
599
- address: '0x3ae6d8a282d67893e17aa70ebffb33ee5aa65893',
600
- creationBlock: 23678
601
- }, _routerConfigs22[exports.UniversalRouterVersion.V2_0] = {
602
- address: '0x3ae6d8a282d67893e17aa70ebffb33ee5aa65893',
603
- creationBlock: 23678
604
- }, _routerConfigs22)
605
- }, _CHAIN_CONFIGS[84532] = {
606
- weth: '0x4200000000000000000000000000000000000006',
607
- routerConfigs: (_routerConfigs23 = {}, _routerConfigs23[exports.UniversalRouterVersion.V1_2] = {
608
- address: '0x492e6456d9528771018deb9e87ef7750ef184104',
609
- creationBlock: 20216585
610
- }, _routerConfigs23[exports.UniversalRouterVersion.V2_0] = {
611
- address: '0x492e6456d9528771018deb9e87ef7750ef184104',
612
- creationBlock: 20216585
613
- }, _routerConfigs23)
614
- }, _CHAIN_CONFIGS[1868] = {
615
- weth: '0x4200000000000000000000000000000000000006',
616
- routerConfigs: (_routerConfigs24 = {}, _routerConfigs24[exports.UniversalRouterVersion.V1_2] = {
617
- address: '0x0e2850543f69f678257266e0907ff9a58b3f13de',
618
- creationBlock: 3254782
619
- }, _routerConfigs24[exports.UniversalRouterVersion.V2_0] = {
620
- address: '0x0e2850543f69f678257266e0907ff9a58b3f13de',
621
- creationBlock: 3254782
622
- }, _routerConfigs24)
623
- }, _CHAIN_CONFIGS);
624
- var UNIVERSAL_ROUTER_ADDRESS = function UNIVERSAL_ROUTER_ADDRESS(version, chainId) {
625
- if (!(chainId in CHAIN_CONFIGS)) throw new Error("Universal Router not deployed on chain " + chainId);
626
- return CHAIN_CONFIGS[chainId].routerConfigs[version].address;
627
- };
628
- var UNIVERSAL_ROUTER_CREATION_BLOCK = function UNIVERSAL_ROUTER_CREATION_BLOCK(version, chainId) {
629
- if (!(chainId in CHAIN_CONFIGS)) throw new Error("Universal Router not deployed on chain " + chainId);
630
- return CHAIN_CONFIGS[chainId].routerConfigs[version].creationBlock;
631
- };
632
- var WETH_ADDRESS = function WETH_ADDRESS(chainId) {
633
- if (!(chainId in CHAIN_CONFIGS)) throw new Error("Universal Router not deployed on chain " + chainId);
634
- if (CHAIN_CONFIGS[chainId].weth == WETH_NOT_SUPPORTED_ON_CHAIN) throw new Error("Chain " + chainId + " does not have WETH");
635
- return CHAIN_CONFIGS[chainId].weth;
636
- };
637
- var CONTRACT_BALANCE = /*#__PURE__*/ethers.BigNumber.from(2).pow(255);
638
- var ETH_ADDRESS = '0x0000000000000000000000000000000000000000';
639
- var E_ETH_ADDRESS = '0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee';
640
- var SENDER_AS_RECIPIENT = '0x0000000000000000000000000000000000000001';
641
- var ROUTER_AS_RECIPIENT = '0x0000000000000000000000000000000000000002';
642
-
643
- function getCurrencyAddress(currency) {
644
- return currency.isNative ? ETH_ADDRESS : currency.wrapped.address;
645
- }
646
-
647
- function encodeFeeBips(fee) {
648
- return v3Sdk.toHex(fee.multiply(10000).quotient);
649
- }
650
-
651
- var REFUND_ETH_PRICE_IMPACT_THRESHOLD = /*#__PURE__*/new sdkCore.Percent(50, 100);
652
- // Wrapper for uniswap router-sdk trade entity to encode swaps for Universal Router
653
- // also translates trade objects from previous (v2, v3) SDKs
654
- var UniswapTrade = /*#__PURE__*/function () {
655
- function UniswapTrade(trade, options) {
656
- this.trade = trade;
657
- this.options = options;
658
- this.tradeType = exports.RouterActionType.UniswapTrade;
659
- if (!!options.fee && !!options.flatFee) throw new Error('Only one fee option permitted');
660
- if (this.inputRequiresWrap || this.inputRequiresUnwrap || this.options.useRouterBalance) {
661
- this.payerIsUser = false;
662
- } else {
663
- this.payerIsUser = true;
664
- }
665
- }
666
- var _proto = UniswapTrade.prototype;
667
- _proto.encode = function encode(planner, _config) {
668
- var _this$options$recipie;
669
- // If the input currency is the native currency, we need to wrap it with the router as the recipient
670
- if (this.inputRequiresWrap) {
671
- // TODO: optimize if only one v2 pool we can directly send this to the pool
672
- planner.addCommand(exports.CommandType.WRAP_ETH, [ROUTER_AS_RECIPIENT, this.trade.maximumAmountIn(this.options.slippageTolerance).quotient.toString()]);
673
- } else if (this.inputRequiresUnwrap) {
674
- // send wrapped token to router to unwrap
675
- planner.addCommand(exports.CommandType.PERMIT2_TRANSFER_FROM, [this.trade.inputAmount.currency.address, ROUTER_AS_RECIPIENT, this.trade.maximumAmountIn(this.options.slippageTolerance).quotient.toString()]);
676
- planner.addCommand(exports.CommandType.UNWRAP_WETH, [ROUTER_AS_RECIPIENT, 0]);
677
- }
678
- // The overall recipient at the end of the trade, SENDER_AS_RECIPIENT uses the msg.sender
679
- this.options.recipient = (_this$options$recipie = this.options.recipient) != null ? _this$options$recipie : SENDER_AS_RECIPIENT;
680
- // flag for whether we want to perform slippage check on aggregate output of multiple routes
681
- // 1. when there are >2 exact input trades. this is only a heuristic,
682
- // as it's still more gas-expensive even in this case, but has benefits
683
- // in that the reversion probability is lower
684
- var performAggregatedSlippageCheck = this.trade.tradeType === sdkCore.TradeType.EXACT_INPUT && this.trade.routes.length > 2;
685
- var routerMustCustody = performAggregatedSlippageCheck || this.outputRequiresTransition || hasFeeOption(this.options);
686
- for (var _iterator = _createForOfIteratorHelperLoose(this.trade.swaps), _step; !(_step = _iterator()).done;) {
687
- var swap = _step.value;
688
- switch (swap.route.protocol) {
689
- case routerSdk.Protocol.V2:
690
- addV2Swap(planner, swap, this.trade.tradeType, this.options, this.payerIsUser, routerMustCustody);
691
- break;
692
- case routerSdk.Protocol.V3:
693
- addV3Swap(planner, swap, this.trade.tradeType, this.options, this.payerIsUser, routerMustCustody);
694
- break;
695
- case routerSdk.Protocol.V4:
696
- addV4Swap(planner, swap, this.trade.tradeType, this.options, this.payerIsUser, routerMustCustody);
697
- break;
698
- case routerSdk.Protocol.MIXED:
699
- addMixedSwap(planner, swap, this.trade.tradeType, this.options, this.payerIsUser, routerMustCustody);
700
- break;
701
- default:
702
- throw new Error('UNSUPPORTED_TRADE_PROTOCOL');
703
- }
704
- }
705
- var minimumAmountOut = ethers.BigNumber.from(this.trade.minimumAmountOut(this.options.slippageTolerance).quotient.toString());
706
- // The router custodies for 3 reasons: to unwrap, to take a fee, and/or to do a slippage check
707
- if (routerMustCustody) {
708
- var pools = this.trade.swaps[0].route.pools;
709
- var pathOutputCurrencyAddress = getCurrencyAddress(getPathCurrency(this.trade.outputAmount.currency, pools[pools.length - 1]));
710
- // If there is a fee, that percentage is sent to the fee recipient
711
- // In the case where ETH is the output currency, the fee is taken in WETH (for gas reasons)
712
- if (!!this.options.fee) {
713
- var feeBips = encodeFeeBips(this.options.fee.fee);
714
- planner.addCommand(exports.CommandType.PAY_PORTION, [pathOutputCurrencyAddress, this.options.fee.recipient, feeBips]);
715
- // If the trade is exact output, and a fee was taken, we must adjust the amount out to be the amount after the fee
716
- // Otherwise we continue as expected with the trade's normal expected output
717
- if (this.trade.tradeType === sdkCore.TradeType.EXACT_OUTPUT) {
718
- minimumAmountOut = minimumAmountOut.sub(minimumAmountOut.mul(feeBips).div(10000));
719
- }
720
- }
721
- // If there is a flat fee, that absolute amount is sent to the fee recipient
722
- // In the case where ETH is the output currency, the fee is taken in WETH (for gas reasons)
723
- if (!!this.options.flatFee) {
724
- var feeAmount = this.options.flatFee.amount;
725
- if (minimumAmountOut.lt(feeAmount)) throw new Error('Flat fee amount greater than minimumAmountOut');
726
- planner.addCommand(exports.CommandType.TRANSFER, [pathOutputCurrencyAddress, this.options.flatFee.recipient, feeAmount]);
727
- // If the trade is exact output, and a fee was taken, we must adjust the amount out to be the amount after the fee
728
- // Otherwise we continue as expected with the trade's normal expected output
729
- if (this.trade.tradeType === sdkCore.TradeType.EXACT_OUTPUT) {
730
- minimumAmountOut = minimumAmountOut.sub(feeAmount);
731
- }
732
- }
733
- // The remaining tokens that need to be sent to the user after the fee is taken will be caught
734
- // by this if-else clause.
735
- if (this.outputRequiresUnwrap) {
736
- planner.addCommand(exports.CommandType.UNWRAP_WETH, [this.options.recipient, minimumAmountOut]);
737
- } else if (this.outputRequiresWrap) {
738
- planner.addCommand(exports.CommandType.WRAP_ETH, [this.options.recipient, CONTRACT_BALANCE]);
739
- } else {
740
- planner.addCommand(exports.CommandType.SWEEP, [getCurrencyAddress(this.trade.outputAmount.currency), this.options.recipient, minimumAmountOut]);
741
- }
742
- }
743
- // for exactOutput swaps with native input or that perform an inputToken transition (wrap or unwrap)
744
- // we need to send back the change to the user
745
- if (this.trade.tradeType === sdkCore.TradeType.EXACT_OUTPUT || riskOfPartialFill(this.trade)) {
746
- if (this.inputRequiresWrap) {
747
- planner.addCommand(exports.CommandType.UNWRAP_WETH, [this.options.recipient, 0]);
748
- } else if (this.inputRequiresUnwrap) {
749
- planner.addCommand(exports.CommandType.WRAP_ETH, [this.options.recipient, CONTRACT_BALANCE]);
750
- } else if (this.trade.inputAmount.currency.isNative) {
751
- // must refund extra native currency sent along for native v4 trades (no input transition)
752
- planner.addCommand(exports.CommandType.SWEEP, [ETH_ADDRESS, this.options.recipient, 0]);
753
- }
754
- }
755
- if (this.options.safeMode) planner.addCommand(exports.CommandType.SWEEP, [ETH_ADDRESS, this.options.recipient, 0]);
756
- };
757
- _createClass(UniswapTrade, [{
758
- key: "isAllV4",
759
- get: function get() {
760
- var result = true;
761
- for (var _iterator2 = _createForOfIteratorHelperLoose(this.trade.swaps), _step2; !(_step2 = _iterator2()).done;) {
762
- var swap = _step2.value;
763
- result = result && swap.route.protocol == routerSdk.Protocol.V4;
764
- }
765
- return result;
766
- }
767
- }, {
768
- key: "inputRequiresWrap",
769
- get: function get() {
770
- if (this.isAllV4) {
771
- return this.trade.inputAmount.currency.isNative && !this.trade.swaps[0].route.pathInput.isNative;
772
- } else {
773
- return this.trade.inputAmount.currency.isNative;
774
- }
775
- }
776
- }, {
777
- key: "inputRequiresUnwrap",
778
- get: function get() {
779
- if (this.isAllV4) {
780
- return !this.trade.inputAmount.currency.isNative && this.trade.swaps[0].route.pathInput.isNative;
781
- }
782
- return false;
783
- }
784
- }, {
785
- key: "outputRequiresWrap",
786
- get: function get() {
787
- if (this.isAllV4) {
788
- return !this.trade.outputAmount.currency.isNative && this.trade.swaps[0].route.pathOutput.isNative;
789
- }
790
- return false;
791
- }
792
- }, {
793
- key: "outputRequiresUnwrap",
794
- get: function get() {
795
- if (this.isAllV4) {
796
- return this.trade.outputAmount.currency.isNative && !this.trade.swaps[0].route.pathOutput.isNative;
797
- } else {
798
- return this.trade.outputAmount.currency.isNative;
799
- }
800
- }
801
- }, {
802
- key: "outputRequiresTransition",
803
- get: function get() {
804
- return this.outputRequiresWrap || this.outputRequiresUnwrap;
805
- }
806
- }]);
807
- return UniswapTrade;
808
- }();
809
- // encode a uniswap v2 swap
810
- function addV2Swap(planner, _ref, tradeType, options, payerIsUser, routerMustCustody) {
811
- var route = _ref.route,
812
- inputAmount = _ref.inputAmount,
813
- outputAmount = _ref.outputAmount;
814
- var trade = new v2Sdk.Trade(route, tradeType == sdkCore.TradeType.EXACT_INPUT ? inputAmount : outputAmount, tradeType);
815
- if (tradeType == sdkCore.TradeType.EXACT_INPUT) {
816
- planner.addCommand(exports.CommandType.V2_SWAP_EXACT_IN, [
817
- // if native, we have to unwrap so keep in the router for now
818
- routerMustCustody ? ROUTER_AS_RECIPIENT : options.recipient, trade.maximumAmountIn(options.slippageTolerance).quotient.toString(),
819
- // if router will custody funds, we do aggregated slippage check from router
820
- routerMustCustody ? 0 : trade.minimumAmountOut(options.slippageTolerance).quotient.toString(), route.path.map(function (token) {
821
- return token.wrapped.address;
822
- }), payerIsUser]);
823
- } else if (tradeType == sdkCore.TradeType.EXACT_OUTPUT) {
824
- planner.addCommand(exports.CommandType.V2_SWAP_EXACT_OUT, [routerMustCustody ? ROUTER_AS_RECIPIENT : options.recipient, trade.minimumAmountOut(options.slippageTolerance).quotient.toString(), trade.maximumAmountIn(options.slippageTolerance).quotient.toString(), route.path.map(function (token) {
825
- return token.wrapped.address;
826
- }), payerIsUser]);
827
- }
828
- }
829
- // encode a uniswap v3 swap
830
- function addV3Swap(planner, _ref2, tradeType, options, payerIsUser, routerMustCustody) {
831
- var route = _ref2.route,
832
- inputAmount = _ref2.inputAmount,
833
- outputAmount = _ref2.outputAmount;
834
- var trade = v3Sdk.Trade.createUncheckedTrade({
835
- route: route,
836
- inputAmount: inputAmount,
837
- outputAmount: outputAmount,
838
- tradeType: tradeType
839
- });
840
- var path = v3Sdk.encodeRouteToPath(route, trade.tradeType === sdkCore.TradeType.EXACT_OUTPUT);
841
- if (tradeType == sdkCore.TradeType.EXACT_INPUT) {
842
- planner.addCommand(exports.CommandType.V3_SWAP_EXACT_IN, [routerMustCustody ? ROUTER_AS_RECIPIENT : options.recipient, trade.maximumAmountIn(options.slippageTolerance).quotient.toString(), routerMustCustody ? 0 : trade.minimumAmountOut(options.slippageTolerance).quotient.toString(), path, payerIsUser]);
843
- } else if (tradeType == sdkCore.TradeType.EXACT_OUTPUT) {
844
- planner.addCommand(exports.CommandType.V3_SWAP_EXACT_OUT, [routerMustCustody ? ROUTER_AS_RECIPIENT : options.recipient, trade.minimumAmountOut(options.slippageTolerance).quotient.toString(), trade.maximumAmountIn(options.slippageTolerance).quotient.toString(), path, payerIsUser]);
845
- }
846
- }
847
- function addV4Swap(planner, _ref3, tradeType, options, payerIsUser, routerMustCustody) {
848
- var _options$recipient;
849
- var inputAmount = _ref3.inputAmount,
850
- outputAmount = _ref3.outputAmount,
851
- route = _ref3.route;
852
- // create a deep copy of pools since v4Planner encoding tampers with array
853
- var pools = route.pools.map(function (p) {
854
- return p;
855
- });
856
- var v4Route = new v4Sdk.Route(pools, inputAmount.currency, outputAmount.currency);
857
- var trade = v4Sdk.Trade.createUncheckedTrade({
858
- route: v4Route,
859
- inputAmount: inputAmount,
860
- outputAmount: outputAmount,
861
- tradeType: tradeType
862
- });
863
- var slippageToleranceOnSwap = routerMustCustody && tradeType == sdkCore.TradeType.EXACT_INPUT ? undefined : options.slippageTolerance;
864
- var v4Planner = new v4Sdk.V4Planner();
865
- v4Planner.addTrade(trade, slippageToleranceOnSwap);
866
- v4Planner.addSettle(trade.route.pathInput, payerIsUser);
867
- v4Planner.addTake(trade.route.pathOutput, routerMustCustody ? ROUTER_AS_RECIPIENT : (_options$recipient = options.recipient) != null ? _options$recipient : SENDER_AS_RECIPIENT);
868
- planner.addCommand(exports.CommandType.V4_SWAP, [v4Planner.finalize()]);
869
- }
870
- // encode a mixed route swap, i.e. including both v2 and v3 pools
871
- function addMixedSwap(planner, swap, tradeType, options, payerIsUser, routerMustCustody) {
872
- var _options$recipient2;
873
- var route = swap.route;
874
- var inputAmount = swap.inputAmount;
875
- var outputAmount = swap.outputAmount;
876
- var tradeRecipient = routerMustCustody ? ROUTER_AS_RECIPIENT : (_options$recipient2 = options.recipient) != null ? _options$recipient2 : SENDER_AS_RECIPIENT;
877
- // single hop, so it can be reduced to plain swap logic for one protocol version
878
- if (route.pools.length === 1) {
879
- if (route.pools[0] instanceof v4Sdk.Pool) {
880
- return addV4Swap(planner, swap, tradeType, options, payerIsUser, routerMustCustody);
881
- } else if (route.pools[0] instanceof v3Sdk.Pool) {
882
- return addV3Swap(planner, swap, tradeType, options, payerIsUser, routerMustCustody);
883
- } else if (route.pools[0] instanceof v2Sdk.Pair) {
884
- return addV2Swap(planner, swap, tradeType, options, payerIsUser, routerMustCustody);
885
- } else {
886
- throw new Error('Invalid route type');
887
- }
888
- }
889
- var trade = routerSdk.MixedRouteTrade.createUncheckedTrade({
890
- route: route,
891
- inputAmount: inputAmount,
892
- outputAmount: outputAmount,
893
- tradeType: tradeType
894
- });
895
- var amountIn = trade.maximumAmountIn(options.slippageTolerance, inputAmount).quotient.toString();
896
- var amountOut = routerMustCustody ? 0 : trade.minimumAmountOut(options.slippageTolerance, outputAmount).quotient.toString();
897
- // logic from
898
- // https://github.com/Uniswap/router-sdk/blob/d8eed164e6c79519983844ca8b6a3fc24ebcb8f8/src/swapRouter.ts#L276
899
- var sections = routerSdk.partitionMixedRouteByProtocol(route);
900
- var isLastSectionInRoute = function isLastSectionInRoute(i) {
901
- return i === sections.length - 1;
902
- };
903
- var inputToken = route.pathInput;
904
- for (var i = 0; i < sections.length; i++) {
905
- var section = sections[i];
906
- var routePool = section[0];
907
- var outputToken = routerSdk.getOutputOfPools(section, inputToken);
908
- var subRoute = new routerSdk.MixedRoute(new routerSdk.MixedRouteSDK([].concat(section), inputToken, outputToken));
909
- var nextInputToken = void 0;
910
- var swapRecipient = void 0;
911
- if (isLastSectionInRoute(i)) {
912
- nextInputToken = outputToken;
913
- swapRecipient = tradeRecipient;
914
- } else {
915
- var nextPool = sections[i + 1][0];
916
- nextInputToken = getPathCurrency(outputToken, nextPool);
917
- var v2PoolIsSwapRecipient = nextPool instanceof v2Sdk.Pair && outputToken.equals(nextInputToken);
918
- swapRecipient = v2PoolIsSwapRecipient ? nextPool.liquidityToken.address : ROUTER_AS_RECIPIENT;
919
- }
920
- if (routePool instanceof v4Sdk.Pool) {
921
- var v4Planner = new v4Sdk.V4Planner();
922
- var v4SubRoute = new v4Sdk.Route(section, subRoute.input, subRoute.output);
923
- v4Planner.addSettle(inputToken, payerIsUser && i === 0, i == 0 ? amountIn : CONTRACT_BALANCE);
924
- v4Planner.addAction(v4Sdk.Actions.SWAP_EXACT_IN, [{
925
- currencyIn: inputToken.isNative ? ETH_ADDRESS : inputToken.address,
926
- path: v4Sdk.encodeRouteToPath(v4SubRoute),
927
- amountIn: 0,
928
- amountOutMinimum: !isLastSectionInRoute(i) ? 0 : amountOut
929
- }]);
930
- v4Planner.addTake(outputToken, swapRecipient);
931
- planner.addCommand(exports.CommandType.V4_SWAP, [v4Planner.finalize()]);
932
- } else if (routePool instanceof v3Sdk.Pool) {
933
- planner.addCommand(exports.CommandType.V3_SWAP_EXACT_IN, [swapRecipient, i == 0 ? amountIn : CONTRACT_BALANCE, !isLastSectionInRoute(i) ? 0 : amountOut, routerSdk.encodeMixedRouteToPath(subRoute), payerIsUser && i === 0]);
934
- } else if (routePool instanceof v2Sdk.Pair) {
935
- planner.addCommand(exports.CommandType.V2_SWAP_EXACT_IN, [swapRecipient, i === 0 ? amountIn : CONTRACT_BALANCE, !isLastSectionInRoute(i) ? 0 : amountOut, subRoute.path.map(function (token) {
936
- return token.wrapped.address;
937
- }), payerIsUser && i === 0]);
938
- } else {
939
- throw new Error('Unexpected Pool Type');
940
- }
941
- // perform a token transition (wrap/unwrap if necessary)
942
- if (!isLastSectionInRoute(i)) {
943
- if (outputToken.isNative && !nextInputToken.isNative) {
944
- planner.addCommand(exports.CommandType.WRAP_ETH, [ROUTER_AS_RECIPIENT, CONTRACT_BALANCE]);
945
- } else if (!outputToken.isNative && nextInputToken.isNative) {
946
- planner.addCommand(exports.CommandType.UNWRAP_WETH, [ROUTER_AS_RECIPIENT, 0]);
947
- }
948
- }
949
- inputToken = nextInputToken;
950
- }
951
- }
952
- // if price impact is very high, there's a chance of hitting max/min prices resulting in a partial fill of the swap
953
- function riskOfPartialFill(trade) {
954
- return trade.priceImpact.greaterThan(REFUND_ETH_PRICE_IMPACT_THRESHOLD);
955
- }
956
- function hasFeeOption(swapOptions) {
957
- return !!swapOptions.fee || !!swapOptions.flatFee;
958
- }
959
-
960
- var SIGNATURE_LENGTH = 65;
961
- var EIP_2098_SIGNATURE_LENGTH = 64;
962
- function encodePermit(planner, permit2) {
963
- var signature = permit2.signature;
964
- var length = ethers.ethers.utils.arrayify(permit2.signature).length;
965
- // signature data provided for EIP-1271 may have length different from ECDSA signature
966
- if (length === SIGNATURE_LENGTH || length === EIP_2098_SIGNATURE_LENGTH) {
967
- // sanitizes signature to cover edge cases of malformed EIP-2098 sigs and v used as recovery id
968
- signature = ethers.ethers.utils.joinSignature(ethers.ethers.utils.splitSignature(permit2.signature));
969
- }
970
- planner.addCommand(exports.CommandType.PERMIT2_PERMIT, [permit2, signature]);
971
- }
972
- function encodeV3PositionPermit(planner, permit, tokenId) {
973
- var calldata = v3Sdk.NonfungiblePositionManager.INTERFACE.encodeFunctionData('permit', [sdkCore.validateAndParseAddress(permit.spender), tokenId, permit.deadline, permit.v, permit.r, permit.s]);
974
- planner.addCommand(exports.CommandType.V3_POSITION_MANAGER_PERMIT, [calldata]);
975
- }
976
- // Handles the encoding of commands needed to gather input tokens for a trade
977
- // Approval: The router approving another address to take tokens.
978
- // note: Only seaport and sudoswap support this action. Approvals are left open.
979
- // Permit: A Permit2 signature-based Permit to allow the router to access a user's tokens
980
- // Transfer: A Permit2 TransferFrom of tokens from a user to either the router or another address
981
- function encodeInputTokenOptions(planner, options) {
982
- // first ensure that all tokens provided for encoding are the same
983
- if (!!options.permit2TransferFrom && !!options.permit2Permit) !(options.permit2TransferFrom.token === options.permit2Permit.details.token) ? invariant(false, "inconsistent token") : void 0;
984
- // if this order has a options.permit2Permit, encode it
985
- if (!!options.permit2Permit) {
986
- encodePermit(planner, options.permit2Permit);
987
- }
988
- if (!!options.permit2TransferFrom) {
989
- planner.addCommand(exports.CommandType.PERMIT2_TRANSFER_FROM, [options.permit2TransferFrom.token, options.permit2TransferFrom.recipient ? options.permit2TransferFrom.recipient : ROUTER_AS_RECIPIENT, options.permit2TransferFrom.amount]);
990
- }
991
- }
992
-
993
- function isMint(options) {
994
- return Object.keys(options).some(function (k) {
995
- return k === 'recipient';
996
- });
997
- }
998
- var SwapRouter = /*#__PURE__*/function () {
999
- function SwapRouter() {}
1000
- SwapRouter.swapCallParameters = function swapCallParameters(trades, options) {
1001
- // TODO: use permit if signature included in swapOptions
1002
- var planner = new RoutePlanner();
1003
- var trade = new UniswapTrade(trades, options);
1004
- var inputCurrency = trade.trade.inputAmount.currency;
1005
- !!(inputCurrency.isNative && !!options.inputTokenPermit) ? invariant(false, 'NATIVE_INPUT_PERMIT') : void 0;
1006
- if (options.inputTokenPermit) {
1007
- encodePermit(planner, options.inputTokenPermit);
1008
- }
1009
- var nativeCurrencyValue = inputCurrency.isNative ? ethers.BigNumber.from(trade.trade.maximumAmountIn(options.slippageTolerance).quotient.toString()) : ethers.BigNumber.from(0);
1010
- trade.encode(planner, {
1011
- allowRevert: false
1012
- });
1013
- return SwapRouter.encodePlan(planner, nativeCurrencyValue, {
1014
- deadline: options.deadlineOrPreviousBlockhash ? ethers.BigNumber.from(options.deadlineOrPreviousBlockhash) : undefined
1015
- });
1016
- }
1017
- /**
1018
- * Builds the call parameters for a migration from a V3 position to a V4 position.
1019
- * Some requirements of the parameters:
1020
- * - v3RemoveLiquidityOptions.collectOptions.recipient must equal v4PositionManager
1021
- * - v3RemoveLiquidityOptions.liquidityPercentage must be 100%
1022
- * - input pool and output pool must have the same tokens
1023
- * - V3 NFT must be approved, or valid inputV3NFTPermit must be provided with UR as spender
1024
- */;
1025
- SwapRouter.migrateV3ToV4CallParameters = function migrateV3ToV4CallParameters(options, positionManagerOverride) {
1026
- var v4Pool = options.outputPosition.pool;
1027
- var v3Token0 = options.inputPosition.pool.token0;
1028
- var v3Token1 = options.inputPosition.pool.token1;
1029
- var v4PositionManagerAddress = positionManagerOverride != null ? positionManagerOverride : sdkCore.CHAIN_TO_ADDRESSES_MAP[v4Pool.chainId].v4PositionManagerAddress;
1030
- // owner of the v3 nft must be the receiver of the v4 nft
1031
- // validate the parameters
1032
- if (v4Pool.currency0.isNative) {
1033
- !(v4Pool.currency0.wrapped.equals(v3Token0) && v4Pool.currency1.equals(v3Token1) || v4Pool.currency0.wrapped.equals(v3Token1) && v4Pool.currency1.equals(v3Token0)) ? invariant(false, 'TOKEN_MISMATCH') : void 0;
1034
- } else {
1035
- !(v3Token0 === v4Pool.token0) ? invariant(false, 'TOKEN0_MISMATCH') : void 0;
1036
- !(v3Token1 === v4Pool.token1) ? invariant(false, 'TOKEN1_MISMATCH') : void 0;
1037
- }
1038
- !options.v3RemoveLiquidityOptions.liquidityPercentage.equalTo(new sdkCore.Percent(100, 100)) ? invariant(false, 'FULL_REMOVAL_REQUIRED') : void 0;
1039
- !(options.v3RemoveLiquidityOptions.burnToken == true) ? invariant(false, 'BURN_TOKEN_REQUIRED') : void 0;
1040
- !(options.v3RemoveLiquidityOptions.collectOptions.recipient === v4PositionManagerAddress) ? invariant(false, 'RECIPIENT_NOT_POSITION_MANAGER') : void 0;
1041
- !isMint(options.v4AddLiquidityOptions) ? invariant(false, 'MINT_REQUIRED') : void 0;
1042
- !options.v4AddLiquidityOptions.migrate ? invariant(false, 'MIGRATE_REQUIRED') : void 0;
1043
- var planner = new RoutePlanner();
1044
- // to prevent reentrancy by the pool hook, we initialize the v4 pool before moving funds
1045
- if (options.v4AddLiquidityOptions.createPool) {
1046
- var poolKey = v4Sdk.Pool.getPoolKey(v4Pool.currency0, v4Pool.currency1, v4Pool.fee, v4Pool.tickSpacing, v4Pool.hooks);
1047
- planner.addCommand(exports.CommandType.V4_INITIALIZE_POOL, [poolKey, v4Pool.sqrtRatioX96.toString()]);
1048
- // remove createPool setting, so that it doesnt get encoded again later
1049
- delete options.v4AddLiquidityOptions.createPool;
1050
- }
1051
- // add position permit to the universal router planner
1052
- if (options.v3RemoveLiquidityOptions.permit) {
1053
- // permit spender should be UR
1054
- var universalRouterAddress = UNIVERSAL_ROUTER_ADDRESS(exports.UniversalRouterVersion.V2_0, options.inputPosition.pool.chainId);
1055
- !(universalRouterAddress == options.v3RemoveLiquidityOptions.permit.spender) ? invariant(false, 'INVALID_SPENDER') : void 0;
1056
- // don't need to transfer it because v3posm uses isApprovedOrOwner()
1057
- encodeV3PositionPermit(planner, options.v3RemoveLiquidityOptions.permit, options.v3RemoveLiquidityOptions.tokenId);
1058
- // remove permit so that multicall doesnt add it again
1059
- delete options.v3RemoveLiquidityOptions.permit;
1060
- }
1061
- // encode v3 withdraw
1062
- var v3RemoveParams = v3Sdk.NonfungiblePositionManager.removeCallParameters(options.inputPosition, options.v3RemoveLiquidityOptions);
1063
- var v3Calls = v3Sdk.Multicall.decodeMulticall(v3RemoveParams.calldata);
1064
- for (var _iterator = _createForOfIteratorHelperLoose(v3Calls), _step; !(_step = _iterator()).done;) {
1065
- var v3Call = _step.value;
1066
- // slice selector - 0x + 4 bytes = 10 characters
1067
- var _selector = v3Call.slice(0, 10);
1068
- !(_selector == v3Sdk.NonfungiblePositionManager.INTERFACE.getSighash('collect') || _selector == v3Sdk.NonfungiblePositionManager.INTERFACE.getSighash('decreaseLiquidity') || _selector == v3Sdk.NonfungiblePositionManager.INTERFACE.getSighash('burn')) ? invariant(false, 'INVALID_V3_CALL: ' + _selector) : void 0;
1069
- planner.addCommand(exports.CommandType.V3_POSITION_MANAGER_CALL, [v3Call]);
1070
- }
1071
- // encode v4 mint
1072
- var v4AddParams = v4Sdk.V4PositionManager.addCallParameters(options.outputPosition, options.v4AddLiquidityOptions);
1073
- // only modifyLiquidities can be called by the UniversalRouter
1074
- var selector = v4AddParams.calldata.slice(0, 10);
1075
- !(selector == v4Sdk.V4PositionManager.INTERFACE.getSighash('modifyLiquidities')) ? invariant(false, 'INVALID_V4_CALL: ' + selector) : void 0;
1076
- planner.addCommand(exports.CommandType.V4_POSITION_MANAGER_CALL, [v4AddParams.calldata]);
1077
- return SwapRouter.encodePlan(planner, ethers.BigNumber.from(0), {
1078
- deadline: ethers.BigNumber.from(options.v4AddLiquidityOptions.deadline)
1079
- });
1080
- }
1081
- /**
1082
- * Encodes a planned route into a method name and parameters for the Router contract.
1083
- * @param planner the planned route
1084
- * @param nativeCurrencyValue the native currency value of the planned route
1085
- * @param config the router config
1086
- */;
1087
- SwapRouter.encodePlan = function encodePlan(planner, nativeCurrencyValue, config) {
1088
- if (config === void 0) {
1089
- config = {};
1090
- }
1091
- var commands = planner.commands,
1092
- inputs = planner.inputs;
1093
- var functionSignature = !!config.deadline ? 'execute(bytes,bytes[],uint256)' : 'execute(bytes,bytes[])';
1094
- var parameters = !!config.deadline ? [commands, inputs, config.deadline] : [commands, inputs];
1095
- var calldata = SwapRouter.INTERFACE.encodeFunctionData(functionSignature, parameters);
1096
- return {
1097
- calldata: calldata,
1098
- value: nativeCurrencyValue.toHexString()
1099
- };
1100
- };
1101
- return SwapRouter;
1102
- }();
1103
- SwapRouter.INTERFACE = /*#__PURE__*/new abi.Interface(UniversalRouter_json.abi);
1104
-
1105
- var UnwrapWETH = /*#__PURE__*/function () {
1106
- function UnwrapWETH(amount, chainId, permit2) {
1107
- this.tradeType = exports.RouterActionType.UnwrapWETH;
1108
- this.wethAddress = WETH_ADDRESS(chainId);
1109
- this.amount = amount;
1110
- if (!!permit2) {
1111
- !(permit2.details.token.toLowerCase() === this.wethAddress.toLowerCase()) ? invariant(false, "must be permitting WETH address: " + this.wethAddress) : void 0;
1112
- !(permit2.details.amount >= amount) ? invariant(false, "Did not permit enough WETH for unwrapWETH transaction") : void 0;
1113
- this.permit2Data = permit2;
1114
- }
1115
- }
1116
- var _proto = UnwrapWETH.prototype;
1117
- _proto.encode = function encode(planner, _) {
1118
- encodeInputTokenOptions(planner, {
1119
- permit2Permit: this.permit2Data,
1120
- permit2TransferFrom: {
1121
- token: this.wethAddress,
1122
- amount: this.amount.toString()
1123
- }
1124
- });
1125
- planner.addCommand(exports.CommandType.UNWRAP_WETH, [ROUTER_AS_RECIPIENT, this.amount]);
1126
- };
1127
- return UnwrapWETH;
1128
- }();
1129
-
1130
- (function (PoolType) {
1131
- PoolType["V2Pool"] = "v2-pool";
1132
- PoolType["V3Pool"] = "v3-pool";
1133
- PoolType["V4Pool"] = "v4-pool";
1134
- })(exports.PoolType || (exports.PoolType = {}));
1135
- var isNativeCurrency = function isNativeCurrency(address) {
1136
- return address.toLowerCase() === ETH_ADDRESS.toLowerCase() || address.toLowerCase() === E_ETH_ADDRESS.toLowerCase();
1137
- };
1138
- // Helper class to convert routing-specific quote entities to RouterTrade entities
1139
- // the returned RouterTrade can then be used to build the UniswapTrade entity in this package
1140
- var RouterTradeAdapter = /*#__PURE__*/function () {
1141
- function RouterTradeAdapter() {}
1142
- // Generate a RouterTrade using fields from a classic quote response
1143
- RouterTradeAdapter.fromClassicQuote = function fromClassicQuote(quote) {
1144
- var route = quote.route,
1145
- tokenIn = quote.tokenIn,
1146
- tokenOut = quote.tokenOut;
1147
- if (!route) throw new Error('Expected route to be present');
1148
- if (!route.length) throw new Error('Expected there to be at least one route');
1149
- if (route.some(function (r) {
1150
- return !r.length;
1151
- })) throw new Error('Expected all routes to have at least one pool');
1152
- var firstRoute = route[0];
1153
- var tokenInData = firstRoute[0].tokenIn;
1154
- var tokenOutData = firstRoute[firstRoute.length - 1].tokenOut;
1155
- if (!tokenInData || !tokenOutData) throw new Error('Expected both tokenIn and tokenOut to be present');
1156
- if (tokenInData.chainId !== tokenOutData.chainId) throw new Error('Expected tokenIn and tokenOut to be have same chainId');
1157
- var parsedCurrencyIn = RouterTradeAdapter.toCurrency(isNativeCurrency(tokenIn), tokenInData);
1158
- var parsedCurrencyOut = RouterTradeAdapter.toCurrency(isNativeCurrency(tokenOut), tokenOutData);
1159
- var typedRoutes = route.map(function (subRoute) {
1160
- var rawAmountIn = subRoute[0].amountIn;
1161
- var rawAmountOut = subRoute[subRoute.length - 1].amountOut;
1162
- if (!rawAmountIn || !rawAmountOut) {
1163
- throw new Error('Expected both raw amountIn and raw amountOut to be present');
1164
- }
1165
- var inputAmount = sdkCore.CurrencyAmount.fromRawAmount(parsedCurrencyIn, rawAmountIn);
1166
- var outputAmount = sdkCore.CurrencyAmount.fromRawAmount(parsedCurrencyOut, rawAmountOut);
1167
- var isOnlyV2 = RouterTradeAdapter.isVersionedRoute(exports.PoolType.V2Pool, subRoute);
1168
- var isOnlyV3 = RouterTradeAdapter.isVersionedRoute(exports.PoolType.V3Pool, subRoute);
1169
- var isOnlyV4 = RouterTradeAdapter.isVersionedRoute(exports.PoolType.V4Pool, subRoute);
1170
- return {
1171
- routev4: isOnlyV4 ? new v4Sdk.Route(subRoute.map(RouterTradeAdapter.toV4Pool), parsedCurrencyIn, parsedCurrencyOut) : null,
1172
- routev3: isOnlyV3 ? new v3Sdk.Route(subRoute.map(RouterTradeAdapter.toV3Pool), parsedCurrencyIn, parsedCurrencyOut) : null,
1173
- routev2: isOnlyV2 ? new v2Sdk.Route(subRoute.map(RouterTradeAdapter.toPair), parsedCurrencyIn, parsedCurrencyOut) : null,
1174
- mixedRoute: !isOnlyV4 && !isOnlyV3 && !isOnlyV2 ? new routerSdk.MixedRouteSDK(subRoute.map(RouterTradeAdapter.toPoolOrPair), parsedCurrencyIn, parsedCurrencyOut) : null,
1175
- inputAmount: inputAmount,
1176
- outputAmount: outputAmount
1177
- };
1178
- });
1179
- return new routerSdk.Trade({
1180
- v2Routes: typedRoutes.filter(function (route) {
1181
- return route.routev2;
1182
- }).map(function (route) {
1183
- return {
1184
- routev2: route.routev2,
1185
- inputAmount: route.inputAmount,
1186
- outputAmount: route.outputAmount
1187
- };
1188
- }),
1189
- v3Routes: typedRoutes.filter(function (route) {
1190
- return route.routev3;
1191
- }).map(function (route) {
1192
- return {
1193
- routev3: route.routev3,
1194
- inputAmount: route.inputAmount,
1195
- outputAmount: route.outputAmount
1196
- };
1197
- }),
1198
- v4Routes: typedRoutes.filter(function (route) {
1199
- return route.routev4;
1200
- }).map(function (route) {
1201
- return {
1202
- routev4: route.routev4,
1203
- inputAmount: route.inputAmount,
1204
- outputAmount: route.outputAmount
1205
- };
1206
- }),
1207
- mixedRoutes: typedRoutes.filter(function (route) {
1208
- return route.mixedRoute;
1209
- }).map(function (route) {
1210
- return {
1211
- mixedRoute: route.mixedRoute,
1212
- inputAmount: route.inputAmount,
1213
- outputAmount: route.outputAmount
1214
- };
1215
- }),
1216
- tradeType: quote.tradeType
1217
- });
1218
- };
1219
- RouterTradeAdapter.toCurrency = function toCurrency(isNative, token) {
1220
- if (isNative) {
1221
- return sdkCore.Ether.onChain(token.chainId);
1222
- }
1223
- return this.toToken(token);
1224
- };
1225
- RouterTradeAdapter.toToken = function toToken(token) {
1226
- var chainId = token.chainId,
1227
- address = token.address,
1228
- decimals = token.decimals,
1229
- symbol = token.symbol,
1230
- buyFeeBps = token.buyFeeBps,
1231
- sellFeeBps = token.sellFeeBps;
1232
- return new sdkCore.Token(chainId, address, parseInt(decimals.toString()), symbol, /* name */undefined, false, buyFeeBps ? ethers.BigNumber.from(buyFeeBps) : undefined, sellFeeBps ? ethers.BigNumber.from(sellFeeBps) : undefined);
1233
- };
1234
- RouterTradeAdapter.toV3Pool = function toV3Pool(_ref) {
1235
- var fee = _ref.fee,
1236
- sqrtRatioX96 = _ref.sqrtRatioX96,
1237
- liquidity = _ref.liquidity,
1238
- tickCurrent = _ref.tickCurrent,
1239
- tokenIn = _ref.tokenIn,
1240
- tokenOut = _ref.tokenOut;
1241
- return new v3Sdk.Pool(RouterTradeAdapter.toToken(tokenIn), RouterTradeAdapter.toToken(tokenOut), parseInt(fee), sqrtRatioX96, liquidity, parseInt(tickCurrent));
1242
- };
1243
- RouterTradeAdapter.toV4Pool = function toV4Pool(pool) {
1244
- var parsedCurrencyIn = RouterTradeAdapter.toCurrency(isNativeCurrency(pool.tokenIn.address), pool.tokenIn);
1245
- var parsedCurrencyOut = RouterTradeAdapter.toCurrency(isNativeCurrency(pool.tokenOut.address), pool.tokenOut);
1246
- return new v4Sdk.Pool(parsedCurrencyIn, parsedCurrencyOut, parseInt(pool.fee), parseInt(pool.tickSpacing), pool.hooks, pool.sqrtRatioX96, pool.liquidity, parseInt(pool.tickCurrent));
1247
- };
1248
- RouterTradeAdapter.isVersionedRoute = function isVersionedRoute(type, route) {
1249
- return route.every(function (pool) {
1250
- return pool.type === type;
1251
- });
1252
- };
1253
- return RouterTradeAdapter;
1254
- }();
1255
- RouterTradeAdapter.toPoolOrPair = function (pool) {
1256
- switch (pool.type) {
1257
- case exports.PoolType.V4Pool:
1258
- return RouterTradeAdapter.toV4Pool(pool);
1259
- case exports.PoolType.V3Pool:
1260
- return RouterTradeAdapter.toV3Pool(pool);
1261
- case exports.PoolType.V2Pool:
1262
- return RouterTradeAdapter.toPair(pool);
1263
- default:
1264
- throw new Error('Invalid pool type');
1265
- }
1266
- };
1267
- RouterTradeAdapter.toPair = function (_ref2) {
1268
- var reserve0 = _ref2.reserve0,
1269
- reserve1 = _ref2.reserve1;
1270
- return new v2Sdk.Pair(sdkCore.CurrencyAmount.fromRawAmount(RouterTradeAdapter.toToken(reserve0.token), reserve0.quotient), sdkCore.CurrencyAmount.fromRawAmount(RouterTradeAdapter.toToken(reserve1.token), reserve1.quotient));
1271
- };
1272
-
1273
- // Parses UniversalRouter V2 commands
1274
- var CommandParser = /*#__PURE__*/function () {
1275
- function CommandParser() {}
1276
- CommandParser.parseCalldata = function parseCalldata(calldata) {
1277
- var genericParser = new GenericCommandParser(COMMAND_DEFINITION);
1278
- var txDescription = CommandParser.INTERFACE.parseTransaction({
1279
- data: calldata
1280
- });
1281
- var _txDescription$args = txDescription.args,
1282
- commands = _txDescription$args.commands,
1283
- inputs = _txDescription$args.inputs;
1284
- return genericParser.parse(commands, inputs);
1285
- };
1286
- return CommandParser;
1287
- }();
1288
- CommandParser.INTERFACE = /*#__PURE__*/new abi.Interface(UniversalRouter_json.abi);
1289
- // Parses commands based on given command definition
1290
- var GenericCommandParser = /*#__PURE__*/function () {
1291
- function GenericCommandParser(commandDefinition) {
1292
- this.commandDefinition = commandDefinition;
1293
- }
1294
- var _proto = GenericCommandParser.prototype;
1295
- _proto.parse = function parse(commands, inputs) {
1296
- var _this = this;
1297
- var commandTypes = GenericCommandParser.getCommands(commands);
1298
- return {
1299
- commands: commandTypes.map(function (commandType, i) {
1300
- var commandDef = _this.commandDefinition[commandType];
1301
- if (commandDef.parser === exports.Parser.V4Actions) {
1302
- var _V4BaseActionsParser$ = v4Sdk.V4BaseActionsParser.parseCalldata(inputs[i]),
1303
- actions = _V4BaseActionsParser$.actions;
1304
- return {
1305
- commandName: exports.CommandType[commandType],
1306
- commandType: commandType,
1307
- params: v4RouterCallToParams(actions)
1308
- };
1309
- } else if (commandDef.parser === exports.Parser.Abi) {
1310
- var abiDef = commandDef.params;
1311
- var rawParams = ethers.ethers.utils.defaultAbiCoder.decode(abiDef.map(function (command) {
1312
- return command.type;
1313
- }), inputs[i]);
1314
- var params = rawParams.map(function (param, j) {
1315
- switch (abiDef[j].subparser) {
1316
- case exports.Subparser.V3PathExactIn:
1317
- return {
1318
- name: abiDef[j].name,
1319
- value: parseV3PathExactIn(param)
1320
- };
1321
- case exports.Subparser.V3PathExactOut:
1322
- return {
1323
- name: abiDef[j].name,
1324
- value: parseV3PathExactOut(param)
1325
- };
1326
- default:
1327
- return {
1328
- name: abiDef[j].name,
1329
- value: param
1330
- };
1331
- }
1332
- });
1333
- return {
1334
- commandName: exports.CommandType[commandType],
1335
- commandType: commandType,
1336
- params: params
1337
- };
1338
- } else if (commandDef.parser === exports.Parser.V3Actions) {
1339
- // TODO: implement better parsing here
1340
- return {
1341
- commandName: exports.CommandType[commandType],
1342
- commandType: commandType,
1343
- params: inputs.map(function (input) {
1344
- return {
1345
- name: 'command',
1346
- value: input
1347
- };
1348
- })
1349
- };
1350
- } else {
1351
- throw new Error("Unsupported parser: " + commandDef);
1352
- }
1353
- })
1354
- };
1355
- }
1356
- // parse command types from bytes string
1357
- ;
1358
- GenericCommandParser.getCommands = function getCommands(commands) {
1359
- var commandTypes = [];
1360
- for (var i = 2; i < commands.length; i += 2) {
1361
- var _byte = commands.substring(i, i + 2);
1362
- commandTypes.push(parseInt(_byte, 16));
1363
- }
1364
- return commandTypes;
1365
- };
1366
- return GenericCommandParser;
1367
- }();
1368
- function parseV3PathExactIn(path) {
1369
- var strippedPath = path.replace('0x', '');
1370
- var tokenIn = ethers.ethers.utils.getAddress(strippedPath.substring(0, 40));
1371
- var loc = 40;
1372
- var res = [];
1373
- while (loc < strippedPath.length) {
1374
- var feeAndTokenOut = strippedPath.substring(loc, loc + 46);
1375
- var fee = parseInt(feeAndTokenOut.substring(0, 6), 16);
1376
- var tokenOut = ethers.ethers.utils.getAddress(feeAndTokenOut.substring(6, 46));
1377
- res.push({
1378
- tokenIn: tokenIn,
1379
- tokenOut: tokenOut,
1380
- fee: fee
1381
- });
1382
- tokenIn = tokenOut;
1383
- loc += 46;
1384
- }
1385
- return res;
1386
- }
1387
- function parseV3PathExactOut(path) {
1388
- var strippedPath = path.replace('0x', '');
1389
- var tokenIn = ethers.ethers.utils.getAddress(strippedPath.substring(strippedPath.length - 40));
1390
- var loc = strippedPath.length - 86; // 86 = (20 addr + 3 fee + 20 addr) * 2 (for hex characters)
1391
- var res = [];
1392
- while (loc >= 0) {
1393
- var feeAndTokenOut = strippedPath.substring(loc, loc + 46);
1394
- var tokenOut = ethers.ethers.utils.getAddress(feeAndTokenOut.substring(0, 40));
1395
- var fee = parseInt(feeAndTokenOut.substring(40, 46), 16);
1396
- res.push({
1397
- tokenIn: tokenIn,
1398
- tokenOut: tokenOut,
1399
- fee: fee
1400
- });
1401
- tokenIn = tokenOut;
1402
- loc -= 46;
1403
- }
1404
- return res;
1405
- }
1406
- function v4RouterCallToParams(actions) {
1407
- return actions.map(function (action) {
1408
- return {
1409
- name: action.actionName,
1410
- value: action.params.map(function (param) {
1411
- return {
1412
- name: param.name,
1413
- value: param.value
1414
- };
1415
- })
1416
- };
1417
- });
1418
- }
1419
-
1420
- exports.COMMAND_DEFINITION = COMMAND_DEFINITION;
1421
- exports.CommandParser = CommandParser;
1422
- exports.GenericCommandParser = GenericCommandParser;
1423
- exports.ROUTER_AS_RECIPIENT = ROUTER_AS_RECIPIENT;
1424
- exports.RoutePlanner = RoutePlanner;
1425
- exports.RouterTradeAdapter = RouterTradeAdapter;
1426
- exports.SwapRouter = SwapRouter;
1427
- exports.UNIVERSAL_ROUTER_ADDRESS = UNIVERSAL_ROUTER_ADDRESS;
1428
- exports.UNIVERSAL_ROUTER_CREATION_BLOCK = UNIVERSAL_ROUTER_CREATION_BLOCK;
1429
- exports.UniswapTrade = UniswapTrade;
1430
- exports.UnwrapWETH = UnwrapWETH;
1431
- exports.WETH_ADDRESS = WETH_ADDRESS;
1432
- exports.isNativeCurrency = isNativeCurrency;
1433
- //# sourceMappingURL=universal-router-sdk.cjs.development.js.map