@uniswap/router-sdk 1.23.0 → 2.0.0

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 (176) hide show
  1. package/dist/{approveAndCall.d.ts → cjs/src/approveAndCall.d.ts} +33 -33
  2. package/dist/cjs/src/approveAndCall.js +111 -0
  3. package/dist/cjs/src/approveAndCall.js.map +1 -0
  4. package/dist/{constants.d.ts → cjs/src/constants.d.ts} +13 -13
  5. package/dist/cjs/src/constants.js +22 -0
  6. package/dist/cjs/src/constants.js.map +1 -0
  7. package/dist/{entities → cjs/src/entities}/mixedRoute/route.d.ts +29 -29
  8. package/dist/cjs/src/entities/mixedRoute/route.js +119 -0
  9. package/dist/cjs/src/entities/mixedRoute/route.js.map +1 -0
  10. package/dist/cjs/src/entities/mixedRoute/route.test.d.ts +1 -0
  11. package/dist/cjs/src/entities/mixedRoute/route.test.js +469 -0
  12. package/dist/cjs/src/entities/mixedRoute/route.test.js.map +1 -0
  13. package/dist/{entities → cjs/src/entities}/mixedRoute/trade.d.ts +183 -183
  14. package/dist/cjs/src/entities/mixedRoute/trade.js +357 -0
  15. package/dist/cjs/src/entities/mixedRoute/trade.js.map +1 -0
  16. package/dist/cjs/src/entities/mixedRoute/trade.test.d.ts +1 -0
  17. package/dist/cjs/src/entities/mixedRoute/trade.test.js +1010 -0
  18. package/dist/cjs/src/entities/mixedRoute/trade.test.js.map +1 -0
  19. package/dist/{entities → cjs/src/entities}/protocol.d.ts +6 -6
  20. package/dist/cjs/src/entities/protocol.js +11 -0
  21. package/dist/cjs/src/entities/protocol.js.map +1 -0
  22. package/dist/{entities → cjs/src/entities}/route.d.ts +40 -40
  23. package/dist/cjs/src/entities/route.js +63 -0
  24. package/dist/cjs/src/entities/route.js.map +1 -0
  25. package/dist/cjs/src/entities/route.test.d.ts +1 -0
  26. package/dist/cjs/src/entities/route.test.js +192 -0
  27. package/dist/cjs/src/entities/route.test.js.map +1 -0
  28. package/dist/{entities → cjs/src/entities}/trade.d.ts +127 -127
  29. package/dist/cjs/src/entities/trade.js +366 -0
  30. package/dist/cjs/src/entities/trade.js.map +1 -0
  31. package/dist/cjs/src/entities/trade.test.d.ts +1 -0
  32. package/dist/cjs/src/entities/trade.test.js +1267 -0
  33. package/dist/cjs/src/entities/trade.test.js.map +1 -0
  34. package/dist/{index.d.ts → cjs/src/index.d.ts} +14 -14
  35. package/dist/cjs/src/index.js +18 -0
  36. package/dist/cjs/src/index.js.map +1 -0
  37. package/dist/{multicallExtended.d.ts → cjs/src/multicallExtended.d.ts} +11 -11
  38. package/dist/cjs/src/multicallExtended.js +43 -0
  39. package/dist/cjs/src/multicallExtended.js.map +1 -0
  40. package/dist/cjs/src/multicallExtended.test.d.ts +1 -0
  41. package/dist/cjs/src/multicallExtended.test.js +22 -0
  42. package/dist/cjs/src/multicallExtended.test.js.map +1 -0
  43. package/dist/{paymentsExtended.d.ts → cjs/src/paymentsExtended.d.ts} +15 -15
  44. package/dist/cjs/src/paymentsExtended.js +65 -0
  45. package/dist/cjs/src/paymentsExtended.js.map +1 -0
  46. package/dist/cjs/src/paymentsExtended.test.d.ts +1 -0
  47. package/dist/cjs/src/paymentsExtended.test.js +60 -0
  48. package/dist/cjs/src/paymentsExtended.test.js.map +1 -0
  49. package/dist/{swapRouter.d.ts → cjs/src/swapRouter.d.ts} +95 -95
  50. package/dist/cjs/src/swapRouter.js +439 -0
  51. package/dist/cjs/src/swapRouter.js.map +1 -0
  52. package/dist/cjs/src/swapRouter.test.d.ts +1 -0
  53. package/dist/cjs/src/swapRouter.test.js +1161 -0
  54. package/dist/cjs/src/swapRouter.test.js.map +1 -0
  55. package/dist/{utils → cjs/src/utils}/TPool.d.ts +4 -4
  56. package/dist/cjs/src/utils/TPool.js +3 -0
  57. package/dist/cjs/src/utils/TPool.js.map +1 -0
  58. package/dist/{utils → cjs/src/utils}/encodeMixedRouteToPath.d.ts +9 -9
  59. package/dist/cjs/src/utils/encodeMixedRouteToPath.js +90 -0
  60. package/dist/cjs/src/utils/encodeMixedRouteToPath.js.map +1 -0
  61. package/dist/cjs/src/utils/encodeMixedRouteToPath.test.d.ts +1 -0
  62. package/dist/cjs/src/utils/encodeMixedRouteToPath.test.js +136 -0
  63. package/dist/cjs/src/utils/encodeMixedRouteToPath.test.js.map +1 -0
  64. package/dist/{utils → cjs/src/utils}/index.d.ts +16 -16
  65. package/dist/cjs/src/utils/index.js +51 -0
  66. package/dist/cjs/src/utils/index.js.map +1 -0
  67. package/dist/{utils → cjs/src/utils}/pathCurrency.d.ts +4 -4
  68. package/dist/cjs/src/utils/pathCurrency.js +35 -0
  69. package/dist/cjs/src/utils/pathCurrency.js.map +1 -0
  70. package/dist/cjs/src/utils/pathCurrency.test.d.ts +1 -0
  71. package/dist/cjs/src/utils/pathCurrency.test.js +17 -0
  72. package/dist/cjs/src/utils/pathCurrency.test.js.map +1 -0
  73. package/dist/esm/src/approveAndCall.d.ts +33 -0
  74. package/dist/esm/src/approveAndCall.js +105 -0
  75. package/dist/esm/src/approveAndCall.js.map +1 -0
  76. package/dist/esm/src/constants.d.ts +13 -0
  77. package/dist/esm/src/constants.js +18 -0
  78. package/dist/esm/src/constants.js.map +1 -0
  79. package/dist/esm/src/entities/mixedRoute/route.d.ts +29 -0
  80. package/dist/esm/src/entities/mixedRoute/route.js +114 -0
  81. package/dist/esm/src/entities/mixedRoute/route.js.map +1 -0
  82. package/dist/esm/src/entities/mixedRoute/route.test.d.ts +1 -0
  83. package/dist/esm/src/entities/mixedRoute/route.test.js +467 -0
  84. package/dist/esm/src/entities/mixedRoute/route.test.js.map +1 -0
  85. package/dist/esm/src/entities/mixedRoute/trade.d.ts +183 -0
  86. package/dist/esm/src/entities/mixedRoute/trade.js +352 -0
  87. package/dist/esm/src/entities/mixedRoute/trade.js.map +1 -0
  88. package/dist/esm/src/entities/mixedRoute/trade.test.d.ts +1 -0
  89. package/dist/esm/src/entities/mixedRoute/trade.test.js +1008 -0
  90. package/dist/esm/src/entities/mixedRoute/trade.test.js.map +1 -0
  91. package/dist/esm/src/entities/protocol.d.ts +6 -0
  92. package/dist/esm/src/entities/protocol.js +8 -0
  93. package/dist/esm/src/entities/protocol.js.map +1 -0
  94. package/dist/esm/src/entities/route.d.ts +40 -0
  95. package/dist/esm/src/entities/route.js +55 -0
  96. package/dist/esm/src/entities/route.js.map +1 -0
  97. package/dist/esm/src/entities/route.test.d.ts +1 -0
  98. package/dist/esm/src/entities/route.test.js +190 -0
  99. package/dist/esm/src/entities/route.test.js.map +1 -0
  100. package/dist/esm/src/entities/trade.d.ts +127 -0
  101. package/dist/esm/src/entities/trade.js +362 -0
  102. package/dist/esm/src/entities/trade.js.map +1 -0
  103. package/dist/esm/src/entities/trade.test.d.ts +1 -0
  104. package/dist/esm/src/entities/trade.test.js +1265 -0
  105. package/dist/esm/src/entities/trade.test.js.map +1 -0
  106. package/dist/esm/src/index.d.ts +14 -0
  107. package/dist/esm/src/index.js +15 -0
  108. package/dist/esm/src/index.js.map +1 -0
  109. package/dist/esm/src/multicallExtended.d.ts +11 -0
  110. package/dist/esm/src/multicallExtended.js +39 -0
  111. package/dist/esm/src/multicallExtended.js.map +1 -0
  112. package/dist/esm/src/multicallExtended.test.d.ts +1 -0
  113. package/dist/esm/src/multicallExtended.test.js +20 -0
  114. package/dist/esm/src/multicallExtended.test.js.map +1 -0
  115. package/dist/esm/src/paymentsExtended.d.ts +15 -0
  116. package/dist/esm/src/paymentsExtended.js +61 -0
  117. package/dist/esm/src/paymentsExtended.js.map +1 -0
  118. package/dist/esm/src/paymentsExtended.test.d.ts +1 -0
  119. package/dist/esm/src/paymentsExtended.test.js +57 -0
  120. package/dist/esm/src/paymentsExtended.test.js.map +1 -0
  121. package/dist/esm/src/swapRouter.d.ts +95 -0
  122. package/dist/esm/src/swapRouter.js +434 -0
  123. package/dist/esm/src/swapRouter.js.map +1 -0
  124. package/dist/esm/src/swapRouter.test.d.ts +1 -0
  125. package/dist/esm/src/swapRouter.test.js +1159 -0
  126. package/dist/esm/src/swapRouter.test.js.map +1 -0
  127. package/dist/esm/src/utils/TPool.d.ts +4 -0
  128. package/dist/esm/src/utils/TPool.js +2 -0
  129. package/dist/esm/src/utils/TPool.js.map +1 -0
  130. package/dist/esm/src/utils/encodeMixedRouteToPath.d.ts +9 -0
  131. package/dist/esm/src/utils/encodeMixedRouteToPath.js +86 -0
  132. package/dist/esm/src/utils/encodeMixedRouteToPath.js.map +1 -0
  133. package/dist/esm/src/utils/encodeMixedRouteToPath.test.d.ts +1 -0
  134. package/dist/esm/src/utils/encodeMixedRouteToPath.test.js +134 -0
  135. package/dist/esm/src/utils/encodeMixedRouteToPath.test.js.map +1 -0
  136. package/dist/esm/src/utils/index.d.ts +16 -0
  137. package/dist/esm/src/utils/index.js +46 -0
  138. package/dist/esm/src/utils/index.js.map +1 -0
  139. package/dist/esm/src/utils/pathCurrency.d.ts +4 -0
  140. package/dist/esm/src/utils/pathCurrency.js +30 -0
  141. package/dist/esm/src/utils/pathCurrency.js.map +1 -0
  142. package/dist/esm/src/utils/pathCurrency.test.d.ts +1 -0
  143. package/dist/esm/src/utils/pathCurrency.test.js +15 -0
  144. package/dist/esm/src/utils/pathCurrency.test.js.map +1 -0
  145. package/dist/types/src/approveAndCall.d.ts +33 -0
  146. package/dist/types/src/constants.d.ts +13 -0
  147. package/dist/types/src/entities/mixedRoute/route.d.ts +29 -0
  148. package/dist/types/src/entities/mixedRoute/route.test.d.ts +1 -0
  149. package/dist/types/src/entities/mixedRoute/trade.d.ts +183 -0
  150. package/dist/types/src/entities/mixedRoute/trade.test.d.ts +1 -0
  151. package/dist/types/src/entities/protocol.d.ts +6 -0
  152. package/dist/types/src/entities/route.d.ts +40 -0
  153. package/dist/types/src/entities/route.test.d.ts +1 -0
  154. package/dist/types/src/entities/trade.d.ts +127 -0
  155. package/dist/types/src/entities/trade.test.d.ts +1 -0
  156. package/dist/types/src/index.d.ts +14 -0
  157. package/dist/types/src/multicallExtended.d.ts +11 -0
  158. package/dist/types/src/multicallExtended.test.d.ts +1 -0
  159. package/dist/types/src/paymentsExtended.d.ts +15 -0
  160. package/dist/types/src/paymentsExtended.test.d.ts +1 -0
  161. package/dist/types/src/swapRouter.d.ts +95 -0
  162. package/dist/types/src/swapRouter.test.d.ts +1 -0
  163. package/dist/types/src/utils/TPool.d.ts +4 -0
  164. package/dist/types/src/utils/encodeMixedRouteToPath.d.ts +9 -0
  165. package/dist/types/src/utils/encodeMixedRouteToPath.test.d.ts +1 -0
  166. package/dist/types/src/utils/index.d.ts +16 -0
  167. package/dist/types/src/utils/pathCurrency.d.ts +4 -0
  168. package/dist/types/src/utils/pathCurrency.test.d.ts +1 -0
  169. package/package.json +29 -14
  170. package/dist/index.js +0 -8
  171. package/dist/router-sdk.cjs.development.js +0 -2485
  172. package/dist/router-sdk.cjs.development.js.map +0 -1
  173. package/dist/router-sdk.cjs.production.min.js +0 -2
  174. package/dist/router-sdk.cjs.production.min.js.map +0 -1
  175. package/dist/router-sdk.esm.js +0 -2452
  176. package/dist/router-sdk.esm.js.map +0 -1
@@ -0,0 +1,183 @@
1
+ import { Currency, Percent, Price, CurrencyAmount, TradeType } from '@uniswap/sdk-core';
2
+ import { BestTradeOptions } from '@uniswap/v3-sdk';
3
+ import { MixedRouteSDK } from './route';
4
+ import { TPool } from '../../utils/TPool';
5
+ /**
6
+ * Trades comparator, an extension of the input output comparator that also considers other dimensions of the trade in ranking them
7
+ * @template TInput The input token, either Ether or an ERC-20
8
+ * @template TOutput The output token, either Ether or an ERC-20
9
+ * @template TTradeType The trade type, either exact input or exact output
10
+ * @param a The first trade to compare
11
+ * @param b The second trade to compare
12
+ * @returns A sorted ordering for two neighboring elements in a trade array
13
+ */
14
+ export declare function tradeComparator<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType>(a: MixedRouteTrade<TInput, TOutput, TTradeType>, b: MixedRouteTrade<TInput, TOutput, TTradeType>): number;
15
+ /**
16
+ * Represents a trade executed against a set of routes where some percentage of the input is
17
+ * split across each route.
18
+ *
19
+ * Each route has its own set of pools. Pools can not be re-used across routes.
20
+ *
21
+ * Does not account for slippage, i.e., changes in price environment that can occur between
22
+ * the time the trade is submitted and when it is executed.
23
+ * @notice This class is functionally the same as the `Trade` class in the `@uniswap/v3-sdk` package, aside from typing and some input validation.
24
+ * @template TInput The input token, either Ether or an ERC-20
25
+ * @template TOutput The output token, either Ether or an ERC-20
26
+ * @template TTradeType The trade type, either exact input or exact output
27
+ */
28
+ export declare class MixedRouteTrade<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType> {
29
+ /**
30
+ * @deprecated Deprecated in favor of 'swaps' property. If the trade consists of multiple routes
31
+ * this will return an error.
32
+ *
33
+ * When the trade consists of just a single route, this returns the route of the trade,
34
+ * i.e. which pools the trade goes through.
35
+ */
36
+ get route(): MixedRouteSDK<TInput, TOutput>;
37
+ /**
38
+ * The swaps of the trade, i.e. which routes and how much is swapped in each that
39
+ * make up the trade.
40
+ */
41
+ readonly swaps: {
42
+ route: MixedRouteSDK<TInput, TOutput>;
43
+ inputAmount: CurrencyAmount<TInput>;
44
+ outputAmount: CurrencyAmount<TOutput>;
45
+ }[];
46
+ /**
47
+ * The type of the trade, either exact in or exact out.
48
+ */
49
+ readonly tradeType: TTradeType;
50
+ /**
51
+ * The cached result of the input amount computation
52
+ * @private
53
+ */
54
+ private _inputAmount;
55
+ /**
56
+ * The input amount for the trade assuming no slippage.
57
+ */
58
+ get inputAmount(): CurrencyAmount<TInput>;
59
+ /**
60
+ * The cached result of the output amount computation
61
+ * @private
62
+ */
63
+ private _outputAmount;
64
+ /**
65
+ * The output amount for the trade assuming no slippage.
66
+ */
67
+ get outputAmount(): CurrencyAmount<TOutput>;
68
+ /**
69
+ * The cached result of the computed execution price
70
+ * @private
71
+ */
72
+ private _executionPrice;
73
+ /**
74
+ * The price expressed in terms of output amount/input amount.
75
+ */
76
+ get executionPrice(): Price<TInput, TOutput>;
77
+ /**
78
+ * The cached result of the price impact computation
79
+ * @private
80
+ */
81
+ private _priceImpact;
82
+ /**
83
+ * Returns the percent difference between the route's mid price and the price impact
84
+ */
85
+ get priceImpact(): Percent;
86
+ /**
87
+ * Constructs a trade by simulating swaps through the given route
88
+ * @template TInput The input token, either Ether or an ERC-20.
89
+ * @template TOutput The output token, either Ether or an ERC-20.
90
+ * @template TTradeType The type of the trade, either exact in or exact out.
91
+ * @param route route to swap through
92
+ * @param amount the amount specified, either input or output, depending on tradeType
93
+ * @param tradeType whether the trade is an exact input or exact output swap
94
+ * @returns The route
95
+ */
96
+ static fromRoute<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType>(route: MixedRouteSDK<TInput, TOutput>, amount: TTradeType extends TradeType.EXACT_INPUT ? CurrencyAmount<TInput> : CurrencyAmount<TOutput>, tradeType: TTradeType): Promise<MixedRouteTrade<TInput, TOutput, TTradeType>>;
97
+ /**
98
+ * Constructs a trade from routes by simulating swaps
99
+ *
100
+ * @template TInput The input token, either Ether or an ERC-20.
101
+ * @template TOutput The output token, either Ether or an ERC-20.
102
+ * @template TTradeType The type of the trade, either exact in or exact out.
103
+ * @param routes the routes to swap through and how much of the amount should be routed through each
104
+ * @param tradeType whether the trade is an exact input or exact output swap
105
+ * @returns The trade
106
+ */
107
+ static fromRoutes<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType>(routes: {
108
+ amount: TTradeType extends TradeType.EXACT_INPUT ? CurrencyAmount<TInput> : CurrencyAmount<TOutput>;
109
+ route: MixedRouteSDK<TInput, TOutput>;
110
+ }[], tradeType: TTradeType): Promise<MixedRouteTrade<TInput, TOutput, TTradeType>>;
111
+ /**
112
+ * Creates a trade without computing the result of swapping through the route. Useful when you have simulated the trade
113
+ * elsewhere and do not have any tick data
114
+ * @template TInput The input token, either Ether or an ERC-20
115
+ * @template TOutput The output token, either Ether or an ERC-20
116
+ * @template TTradeType The type of the trade, either exact in or exact out
117
+ * @param constructorArguments The arguments passed to the trade constructor
118
+ * @returns The unchecked trade
119
+ */
120
+ static createUncheckedTrade<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType>(constructorArguments: {
121
+ route: MixedRouteSDK<TInput, TOutput>;
122
+ inputAmount: CurrencyAmount<TInput>;
123
+ outputAmount: CurrencyAmount<TOutput>;
124
+ tradeType: TTradeType;
125
+ }): MixedRouteTrade<TInput, TOutput, TTradeType>;
126
+ /**
127
+ * Creates a trade without computing the result of swapping through the routes. Useful when you have simulated the trade
128
+ * elsewhere and do not have any tick data
129
+ * @template TInput The input token, either Ether or an ERC-20
130
+ * @template TOutput The output token, either Ether or an ERC-20
131
+ * @template TTradeType The type of the trade, either exact in or exact out
132
+ * @param constructorArguments The arguments passed to the trade constructor
133
+ * @returns The unchecked trade
134
+ */
135
+ static createUncheckedTradeWithMultipleRoutes<TInput extends Currency, TOutput extends Currency, TTradeType extends TradeType>(constructorArguments: {
136
+ routes: {
137
+ route: MixedRouteSDK<TInput, TOutput>;
138
+ inputAmount: CurrencyAmount<TInput>;
139
+ outputAmount: CurrencyAmount<TOutput>;
140
+ }[];
141
+ tradeType: TTradeType;
142
+ }): MixedRouteTrade<TInput, TOutput, TTradeType>;
143
+ /**
144
+ * Construct a trade by passing in the pre-computed property values
145
+ * @param routes The routes through which the trade occurs
146
+ * @param tradeType The type of trade, exact input or exact output
147
+ */
148
+ private constructor();
149
+ /**
150
+ * Get the minimum amount that must be received from this trade for the given slippage tolerance
151
+ * @param slippageTolerance The tolerance of unfavorable slippage from the execution price of this trade
152
+ * @returns The amount out
153
+ */
154
+ minimumAmountOut(slippageTolerance: Percent, amountOut?: CurrencyAmount<TOutput>): CurrencyAmount<TOutput>;
155
+ /**
156
+ * Get the maximum amount in that can be spent via this trade for the given slippage tolerance
157
+ * @param slippageTolerance The tolerance of unfavorable slippage from the execution price of this trade
158
+ * @returns The amount in
159
+ */
160
+ maximumAmountIn(slippageTolerance: Percent, amountIn?: CurrencyAmount<TInput>): CurrencyAmount<TInput>;
161
+ /**
162
+ * Return the execution price after accounting for slippage tolerance
163
+ * @param slippageTolerance the allowed tolerated slippage
164
+ * @returns The execution price
165
+ */
166
+ worstExecutionPrice(slippageTolerance: Percent): Price<TInput, TOutput>;
167
+ /**
168
+ * Given a list of pools, and a fixed amount in, returns the top `maxNumResults` trades that go from an input token
169
+ * amount to an output token, making at most `maxHops` hops.
170
+ * Note this does not consider aggregation, as routes are linear. It's possible a better route exists by splitting
171
+ * the amount in among multiple routes.
172
+ * @param pools the pools to consider in finding the best trade
173
+ * @param nextAmountIn exact amount of input currency to spend
174
+ * @param currencyOut the desired currency out
175
+ * @param maxNumResults maximum number of results to return
176
+ * @param maxHops maximum number of hops a returned trade can make, e.g. 1 hop goes through a single pool
177
+ * @param currentPools used in recursion; the current list of pools
178
+ * @param currencyAmountIn used in recursion; the original value of the currencyAmountIn parameter
179
+ * @param bestTrades used in recursion; the current list of best trades
180
+ * @returns The exact in trade
181
+ */
182
+ static bestTradeExactIn<TInput extends Currency, TOutput extends Currency>(pools: TPool[], currencyAmountIn: CurrencyAmount<TInput>, currencyOut: TOutput, { maxNumResults, maxHops }?: BestTradeOptions, currentPools?: TPool[], nextAmountIn?: CurrencyAmount<Currency>, bestTrades?: MixedRouteTrade<TInput, TOutput, TradeType.EXACT_INPUT>[]): Promise<MixedRouteTrade<TInput, TOutput, TradeType.EXACT_INPUT>[]>;
183
+ }
@@ -0,0 +1,352 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Fraction, Percent, Price, sortedInsert, CurrencyAmount, TradeType } from '@uniswap/sdk-core';
3
+ import { Pair } from '@uniswap/v2-sdk';
4
+ import { Pool as V3Pool } from '@uniswap/v3-sdk';
5
+ import { Pool as V4Pool } from '@uniswap/v4-sdk';
6
+ import invariant from 'tiny-invariant';
7
+ import { ONE, ZERO } from '../../constants';
8
+ import { MixedRouteSDK } from './route';
9
+ import { amountWithPathCurrency } from '../../utils/pathCurrency';
10
+ /**
11
+ * Trades comparator, an extension of the input output comparator that also considers other dimensions of the trade in ranking them
12
+ * @template TInput The input token, either Ether or an ERC-20
13
+ * @template TOutput The output token, either Ether or an ERC-20
14
+ * @template TTradeType The trade type, either exact input or exact output
15
+ * @param a The first trade to compare
16
+ * @param b The second trade to compare
17
+ * @returns A sorted ordering for two neighboring elements in a trade array
18
+ */
19
+ export function tradeComparator(a, b) {
20
+ // must have same input and output token for comparison
21
+ invariant(a.inputAmount.currency.equals(b.inputAmount.currency), 'INPUT_CURRENCY');
22
+ invariant(a.outputAmount.currency.equals(b.outputAmount.currency), 'OUTPUT_CURRENCY');
23
+ if (a.outputAmount.equalTo(b.outputAmount)) {
24
+ if (a.inputAmount.equalTo(b.inputAmount)) {
25
+ // consider the number of hops since each hop costs gas
26
+ const aHops = a.swaps.reduce((total, cur) => total + cur.route.path.length, 0);
27
+ const bHops = b.swaps.reduce((total, cur) => total + cur.route.path.length, 0);
28
+ return aHops - bHops;
29
+ }
30
+ // trade A requires less input than trade B, so A should come first
31
+ if (a.inputAmount.lessThan(b.inputAmount)) {
32
+ return -1;
33
+ }
34
+ else {
35
+ return 1;
36
+ }
37
+ }
38
+ else {
39
+ // tradeA has less output than trade B, so should come second
40
+ if (a.outputAmount.lessThan(b.outputAmount)) {
41
+ return 1;
42
+ }
43
+ else {
44
+ return -1;
45
+ }
46
+ }
47
+ }
48
+ /**
49
+ * Represents a trade executed against a set of routes where some percentage of the input is
50
+ * split across each route.
51
+ *
52
+ * Each route has its own set of pools. Pools can not be re-used across routes.
53
+ *
54
+ * Does not account for slippage, i.e., changes in price environment that can occur between
55
+ * the time the trade is submitted and when it is executed.
56
+ * @notice This class is functionally the same as the `Trade` class in the `@uniswap/v3-sdk` package, aside from typing and some input validation.
57
+ * @template TInput The input token, either Ether or an ERC-20
58
+ * @template TOutput The output token, either Ether or an ERC-20
59
+ * @template TTradeType The trade type, either exact input or exact output
60
+ */
61
+ export class MixedRouteTrade {
62
+ /**
63
+ * @deprecated Deprecated in favor of 'swaps' property. If the trade consists of multiple routes
64
+ * this will return an error.
65
+ *
66
+ * When the trade consists of just a single route, this returns the route of the trade,
67
+ * i.e. which pools the trade goes through.
68
+ */
69
+ get route() {
70
+ invariant(this.swaps.length === 1, 'MULTIPLE_ROUTES');
71
+ return this.swaps[0].route;
72
+ }
73
+ /**
74
+ * The input amount for the trade assuming no slippage.
75
+ */
76
+ get inputAmount() {
77
+ if (this._inputAmount) {
78
+ return this._inputAmount;
79
+ }
80
+ const inputCurrency = this.swaps[0].inputAmount.currency;
81
+ const totalInputFromRoutes = this.swaps
82
+ .map(({ inputAmount }) => inputAmount)
83
+ .reduce((total, cur) => total.add(cur), CurrencyAmount.fromRawAmount(inputCurrency, 0));
84
+ this._inputAmount = totalInputFromRoutes;
85
+ return this._inputAmount;
86
+ }
87
+ /**
88
+ * The output amount for the trade assuming no slippage.
89
+ */
90
+ get outputAmount() {
91
+ if (this._outputAmount) {
92
+ return this._outputAmount;
93
+ }
94
+ const outputCurrency = this.swaps[0].outputAmount.currency;
95
+ const totalOutputFromRoutes = this.swaps
96
+ .map(({ outputAmount }) => outputAmount)
97
+ .reduce((total, cur) => total.add(cur), CurrencyAmount.fromRawAmount(outputCurrency, 0));
98
+ this._outputAmount = totalOutputFromRoutes;
99
+ return this._outputAmount;
100
+ }
101
+ /**
102
+ * The price expressed in terms of output amount/input amount.
103
+ */
104
+ get executionPrice() {
105
+ var _a;
106
+ return ((_a = this._executionPrice) !== null && _a !== void 0 ? _a : (this._executionPrice = new Price(this.inputAmount.currency, this.outputAmount.currency, this.inputAmount.quotient, this.outputAmount.quotient)));
107
+ }
108
+ /**
109
+ * Returns the percent difference between the route's mid price and the price impact
110
+ */
111
+ get priceImpact() {
112
+ if (this._priceImpact) {
113
+ return this._priceImpact;
114
+ }
115
+ let spotOutputAmount = CurrencyAmount.fromRawAmount(this.outputAmount.currency, 0);
116
+ for (const { route, inputAmount } of this.swaps) {
117
+ const midPrice = route.midPrice;
118
+ spotOutputAmount = spotOutputAmount.add(midPrice.quote(inputAmount));
119
+ }
120
+ const priceImpact = spotOutputAmount.subtract(this.outputAmount).divide(spotOutputAmount);
121
+ this._priceImpact = new Percent(priceImpact.numerator, priceImpact.denominator);
122
+ return this._priceImpact;
123
+ }
124
+ /**
125
+ * Constructs a trade by simulating swaps through the given route
126
+ * @template TInput The input token, either Ether or an ERC-20.
127
+ * @template TOutput The output token, either Ether or an ERC-20.
128
+ * @template TTradeType The type of the trade, either exact in or exact out.
129
+ * @param route route to swap through
130
+ * @param amount the amount specified, either input or output, depending on tradeType
131
+ * @param tradeType whether the trade is an exact input or exact output swap
132
+ * @returns The route
133
+ */
134
+ static fromRoute(route, amount, tradeType) {
135
+ return __awaiter(this, void 0, void 0, function* () {
136
+ const amounts = new Array(route.path.length);
137
+ let inputAmount;
138
+ let outputAmount;
139
+ invariant(tradeType === TradeType.EXACT_INPUT, 'TRADE_TYPE');
140
+ invariant(amount.currency.equals(route.input), 'INPUT');
141
+ amounts[0] = amountWithPathCurrency(amount, route.pools[0]);
142
+ for (let i = 0; i < route.path.length - 1; i++) {
143
+ const pool = route.pools[i];
144
+ const [outputAmount] = yield pool.getOutputAmount(amountWithPathCurrency(amounts[i], pool));
145
+ amounts[i + 1] = outputAmount;
146
+ }
147
+ inputAmount = CurrencyAmount.fromFractionalAmount(route.input, amount.numerator, amount.denominator);
148
+ outputAmount = CurrencyAmount.fromFractionalAmount(route.output, amounts[amounts.length - 1].numerator, amounts[amounts.length - 1].denominator);
149
+ return new MixedRouteTrade({
150
+ routes: [{ inputAmount, outputAmount, route }],
151
+ tradeType,
152
+ });
153
+ });
154
+ }
155
+ /**
156
+ * Constructs a trade from routes by simulating swaps
157
+ *
158
+ * @template TInput The input token, either Ether or an ERC-20.
159
+ * @template TOutput The output token, either Ether or an ERC-20.
160
+ * @template TTradeType The type of the trade, either exact in or exact out.
161
+ * @param routes the routes to swap through and how much of the amount should be routed through each
162
+ * @param tradeType whether the trade is an exact input or exact output swap
163
+ * @returns The trade
164
+ */
165
+ static fromRoutes(routes, tradeType) {
166
+ return __awaiter(this, void 0, void 0, function* () {
167
+ const populatedRoutes = [];
168
+ invariant(tradeType === TradeType.EXACT_INPUT, 'TRADE_TYPE');
169
+ for (const { route, amount } of routes) {
170
+ const amounts = new Array(route.path.length);
171
+ let inputAmount;
172
+ let outputAmount;
173
+ invariant(amount.currency.equals(route.input), 'INPUT');
174
+ inputAmount = CurrencyAmount.fromFractionalAmount(route.input, amount.numerator, amount.denominator);
175
+ amounts[0] = CurrencyAmount.fromFractionalAmount(route.pathInput, amount.numerator, amount.denominator);
176
+ for (let i = 0; i < route.path.length - 1; i++) {
177
+ const pool = route.pools[i];
178
+ const [outputAmount] = yield pool.getOutputAmount(amountWithPathCurrency(amounts[i], pool));
179
+ amounts[i + 1] = outputAmount;
180
+ }
181
+ outputAmount = CurrencyAmount.fromFractionalAmount(route.output, amounts[amounts.length - 1].numerator, amounts[amounts.length - 1].denominator);
182
+ populatedRoutes.push({ route, inputAmount, outputAmount });
183
+ }
184
+ return new MixedRouteTrade({
185
+ routes: populatedRoutes,
186
+ tradeType,
187
+ });
188
+ });
189
+ }
190
+ /**
191
+ * Creates a trade without computing the result of swapping through the route. Useful when you have simulated the trade
192
+ * elsewhere and do not have any tick data
193
+ * @template TInput The input token, either Ether or an ERC-20
194
+ * @template TOutput The output token, either Ether or an ERC-20
195
+ * @template TTradeType The type of the trade, either exact in or exact out
196
+ * @param constructorArguments The arguments passed to the trade constructor
197
+ * @returns The unchecked trade
198
+ */
199
+ static createUncheckedTrade(constructorArguments) {
200
+ return new MixedRouteTrade(Object.assign(Object.assign({}, constructorArguments), { routes: [
201
+ {
202
+ inputAmount: constructorArguments.inputAmount,
203
+ outputAmount: constructorArguments.outputAmount,
204
+ route: constructorArguments.route,
205
+ },
206
+ ] }));
207
+ }
208
+ /**
209
+ * Creates a trade without computing the result of swapping through the routes. Useful when you have simulated the trade
210
+ * elsewhere and do not have any tick data
211
+ * @template TInput The input token, either Ether or an ERC-20
212
+ * @template TOutput The output token, either Ether or an ERC-20
213
+ * @template TTradeType The type of the trade, either exact in or exact out
214
+ * @param constructorArguments The arguments passed to the trade constructor
215
+ * @returns The unchecked trade
216
+ */
217
+ static createUncheckedTradeWithMultipleRoutes(constructorArguments) {
218
+ return new MixedRouteTrade(constructorArguments);
219
+ }
220
+ /**
221
+ * Construct a trade by passing in the pre-computed property values
222
+ * @param routes The routes through which the trade occurs
223
+ * @param tradeType The type of trade, exact input or exact output
224
+ */
225
+ constructor({ routes, tradeType, }) {
226
+ const inputCurrency = routes[0].inputAmount.currency;
227
+ const outputCurrency = routes[0].outputAmount.currency;
228
+ invariant(routes.every(({ route }) => inputCurrency.wrapped.equals(route.input.wrapped)), 'INPUT_CURRENCY_MATCH');
229
+ invariant(routes.every(({ route }) => outputCurrency.wrapped.equals(route.output.wrapped)), 'OUTPUT_CURRENCY_MATCH');
230
+ const numPools = routes.map(({ route }) => route.pools.length).reduce((total, cur) => total + cur, 0);
231
+ const poolIdentifierSet = new Set();
232
+ for (const { route } of routes) {
233
+ for (const pool of route.pools) {
234
+ if (pool instanceof V4Pool) {
235
+ poolIdentifierSet.add(pool.poolId);
236
+ }
237
+ else if (pool instanceof V3Pool) {
238
+ poolIdentifierSet.add(V3Pool.getAddress(pool.token0, pool.token1, pool.fee));
239
+ }
240
+ else if (pool instanceof Pair) {
241
+ const pair = pool;
242
+ poolIdentifierSet.add(Pair.getAddress(pair.token0, pair.token1));
243
+ }
244
+ else {
245
+ throw new Error('Unexpected pool type in route when constructing trade object');
246
+ }
247
+ }
248
+ }
249
+ invariant(numPools === poolIdentifierSet.size, 'POOLS_DUPLICATED');
250
+ invariant(tradeType === TradeType.EXACT_INPUT, 'TRADE_TYPE');
251
+ this.swaps = routes;
252
+ this.tradeType = tradeType;
253
+ }
254
+ /**
255
+ * Get the minimum amount that must be received from this trade for the given slippage tolerance
256
+ * @param slippageTolerance The tolerance of unfavorable slippage from the execution price of this trade
257
+ * @returns The amount out
258
+ */
259
+ minimumAmountOut(slippageTolerance, amountOut = this.outputAmount) {
260
+ invariant(!slippageTolerance.lessThan(ZERO), 'SLIPPAGE_TOLERANCE');
261
+ /// does not support exactOutput, as enforced in the constructor
262
+ const slippageAdjustedAmountOut = new Fraction(ONE)
263
+ .add(slippageTolerance)
264
+ .invert()
265
+ .multiply(amountOut.quotient).quotient;
266
+ return CurrencyAmount.fromRawAmount(amountOut.currency, slippageAdjustedAmountOut);
267
+ }
268
+ /**
269
+ * Get the maximum amount in that can be spent via this trade for the given slippage tolerance
270
+ * @param slippageTolerance The tolerance of unfavorable slippage from the execution price of this trade
271
+ * @returns The amount in
272
+ */
273
+ maximumAmountIn(slippageTolerance, amountIn = this.inputAmount) {
274
+ invariant(!slippageTolerance.lessThan(ZERO), 'SLIPPAGE_TOLERANCE');
275
+ return amountIn;
276
+ /// does not support exactOutput
277
+ }
278
+ /**
279
+ * Return the execution price after accounting for slippage tolerance
280
+ * @param slippageTolerance the allowed tolerated slippage
281
+ * @returns The execution price
282
+ */
283
+ worstExecutionPrice(slippageTolerance) {
284
+ return new Price(this.inputAmount.currency, this.outputAmount.currency, this.maximumAmountIn(slippageTolerance).quotient, this.minimumAmountOut(slippageTolerance).quotient);
285
+ }
286
+ /**
287
+ * Given a list of pools, and a fixed amount in, returns the top `maxNumResults` trades that go from an input token
288
+ * amount to an output token, making at most `maxHops` hops.
289
+ * Note this does not consider aggregation, as routes are linear. It's possible a better route exists by splitting
290
+ * the amount in among multiple routes.
291
+ * @param pools the pools to consider in finding the best trade
292
+ * @param nextAmountIn exact amount of input currency to spend
293
+ * @param currencyOut the desired currency out
294
+ * @param maxNumResults maximum number of results to return
295
+ * @param maxHops maximum number of hops a returned trade can make, e.g. 1 hop goes through a single pool
296
+ * @param currentPools used in recursion; the current list of pools
297
+ * @param currencyAmountIn used in recursion; the original value of the currencyAmountIn parameter
298
+ * @param bestTrades used in recursion; the current list of best trades
299
+ * @returns The exact in trade
300
+ */
301
+ static bestTradeExactIn(pools, currencyAmountIn, currencyOut, { maxNumResults = 3, maxHops = 3 } = {},
302
+ // used in recursion.
303
+ currentPools = [], nextAmountIn = currencyAmountIn, bestTrades = []) {
304
+ return __awaiter(this, void 0, void 0, function* () {
305
+ invariant(pools.length > 0, 'POOLS');
306
+ invariant(maxHops > 0, 'MAX_HOPS');
307
+ invariant(currencyAmountIn === nextAmountIn || currentPools.length > 0, 'INVALID_RECURSION');
308
+ const amountIn = nextAmountIn;
309
+ for (let i = 0; i < pools.length; i++) {
310
+ const pool = pools[i];
311
+ const amountInAdjusted = pool instanceof V4Pool ? amountIn : amountIn.wrapped;
312
+ // pool irrelevant
313
+ if (!pool.token0.equals(amountInAdjusted.currency) && !pool.token1.equals(amountInAdjusted.currency))
314
+ continue;
315
+ if (pool instanceof Pair) {
316
+ if (pool.reserve0.equalTo(ZERO) || pool.reserve1.equalTo(ZERO))
317
+ continue;
318
+ }
319
+ let amountOut;
320
+ try {
321
+ ;
322
+ [amountOut] =
323
+ pool instanceof V4Pool
324
+ ? yield pool.getOutputAmount(amountInAdjusted)
325
+ : yield pool.getOutputAmount(amountInAdjusted.wrapped);
326
+ }
327
+ catch (error) {
328
+ // input too low
329
+ // @ts-ignore[2571] error is unknown
330
+ if (error.isInsufficientInputAmountError) {
331
+ continue;
332
+ }
333
+ throw error;
334
+ }
335
+ // we have arrived at the output token, so this is the final trade of one of the paths
336
+ if (amountOut.currency.wrapped.equals(currencyOut.wrapped)) {
337
+ sortedInsert(bestTrades, yield MixedRouteTrade.fromRoute(new MixedRouteSDK([...currentPools, pool], currencyAmountIn.currency, currencyOut), currencyAmountIn, TradeType.EXACT_INPUT), maxNumResults, tradeComparator);
338
+ }
339
+ else if (maxHops > 1 && pools.length > 1) {
340
+ const poolsExcludingThisPool = pools.slice(0, i).concat(pools.slice(i + 1, pools.length));
341
+ // otherwise, consider all the other paths that lead from this token as long as we have not exceeded maxHops
342
+ yield MixedRouteTrade.bestTradeExactIn(poolsExcludingThisPool, currencyAmountIn, currencyOut, {
343
+ maxNumResults,
344
+ maxHops: maxHops - 1,
345
+ }, [...currentPools, pool], amountOut, bestTrades);
346
+ }
347
+ }
348
+ return bestTrades;
349
+ });
350
+ }
351
+ }
352
+ //# sourceMappingURL=trade.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trade.js","sourceRoot":"","sources":["../../../../../src/entities/mixedRoute/trade.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};