@paraswap/dex-lib 4.6.23 → 4.6.25

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 (148) hide show
  1. package/build/abi/PendleRouterStatic.json +19 -0
  2. package/build/abi/apex-defi/ApexDefiFactory.abi.json +1749 -0
  3. package/build/abi/apex-defi/ApexDefiRouter.abi.json +1120 -0
  4. package/build/abi/apex-defi/ApexDefiToken.abi.json +229 -0
  5. package/build/abi/apex-defi/ApexDefiWrapper.abi.json +92 -0
  6. package/build/abi/apex-defi/ApexDefiWrapperFactory.abi.json +1107 -0
  7. package/build/abi/cap/CapToken.json +2111 -0
  8. package/build/abi/cap/PriceOracle.json +762 -0
  9. package/build/abi/pangolin-v3/PangolinV3StateMulticall.abi.json +796 -0
  10. package/build/abi/pendle/pendle-deployer.abi.json +520 -0
  11. package/build/abi/pendle/pendle-oracle.abi.json +413 -0
  12. package/build/abi/ring-v2/few-wrapped-token.json +587 -0
  13. package/build/abi/ring-v2/ring-v2-factory.json +125 -0
  14. package/build/abi/ring-v2/ring-v2-pool.json +461 -0
  15. package/build/abi/ring-v2/ring-v2-router.json +332 -0
  16. package/build/abi/stabull/stabull-curve.json +738 -0
  17. package/build/abi/stabull/stabull-router.json +76 -0
  18. package/build/abi/uniswap-v4/hooks/cabalcoin-hook.abi.json +682 -0
  19. package/build/abi/uniswap-v4/hooks/fee-hook.abi.json +1335 -0
  20. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.d.ts +29 -0
  21. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js +153 -0
  22. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js.map +1 -0
  23. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.d.ts +40 -0
  24. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js +323 -0
  25. package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js.map +1 -0
  26. package/build/dex/aave-pt-to-underlying/config.d.ts +3 -0
  27. package/build/dex/aave-pt-to-underlying/config.js +24 -0
  28. package/build/dex/aave-pt-to-underlying/config.js.map +1 -0
  29. package/build/dex/aave-pt-to-underlying/constants.d.ts +2 -0
  30. package/build/dex/aave-pt-to-underlying/constants.js +6 -0
  31. package/build/dex/aave-pt-to-underlying/constants.js.map +1 -0
  32. package/build/dex/aave-pt-to-underlying/types.d.ts +24 -0
  33. package/build/dex/aave-pt-to-underlying/types.js +3 -0
  34. package/build/dex/aave-pt-to-underlying/types.js.map +1 -0
  35. package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.d.ts +39 -0
  36. package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js +244 -0
  37. package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js.map +1 -0
  38. package/build/dex/aave-pt-to-usdc/config.d.ts +3 -0
  39. package/build/dex/aave-pt-to-usdc/config.js +47 -0
  40. package/build/dex/aave-pt-to-usdc/config.js.map +1 -0
  41. package/build/dex/aave-pt-to-usdc/constants.d.ts +2 -0
  42. package/build/dex/aave-pt-to-usdc/constants.js +6 -0
  43. package/build/dex/aave-pt-to-usdc/constants.js.map +1 -0
  44. package/build/dex/aave-pt-to-usdc/types.d.ts +22 -0
  45. package/build/dex/aave-pt-to-usdc/types.js +3 -0
  46. package/build/dex/aave-pt-to-usdc/types.js.map +1 -0
  47. package/build/dex/apex-defi/apex-defi-factory.d.ts +26 -0
  48. package/build/dex/apex-defi/apex-defi-factory.js +53 -0
  49. package/build/dex/apex-defi/apex-defi-factory.js.map +1 -0
  50. package/build/dex/apex-defi/apex-defi-pool.d.ts +55 -0
  51. package/build/dex/apex-defi/apex-defi-pool.js +247 -0
  52. package/build/dex/apex-defi/apex-defi-pool.js.map +1 -0
  53. package/build/dex/apex-defi/apex-defi-wrapper-factory.d.ts +57 -0
  54. package/build/dex/apex-defi/apex-defi-wrapper-factory.js +250 -0
  55. package/build/dex/apex-defi/apex-defi-wrapper-factory.js.map +1 -0
  56. package/build/dex/apex-defi/apex-defi.d.ts +97 -0
  57. package/build/dex/apex-defi/apex-defi.js +1021 -0
  58. package/build/dex/apex-defi/apex-defi.js.map +1 -0
  59. package/build/dex/apex-defi/config.d.ts +4 -0
  60. package/build/dex/apex-defi/config.js +138 -0
  61. package/build/dex/apex-defi/config.js.map +1 -0
  62. package/build/dex/apex-defi/types.d.ts +32 -0
  63. package/build/dex/apex-defi/types.js +3 -0
  64. package/build/dex/apex-defi/types.js.map +1 -0
  65. package/build/dex/apex-defi/utils.d.ts +46 -0
  66. package/build/dex/apex-defi/utils.js +133 -0
  67. package/build/dex/apex-defi/utils.js.map +1 -0
  68. package/build/dex/cap/cap-pools.d.ts +44 -0
  69. package/build/dex/cap/cap-pools.js +199 -0
  70. package/build/dex/cap/cap-pools.js.map +1 -0
  71. package/build/dex/cap/cap.d.ts +48 -0
  72. package/build/dex/cap/cap.js +335 -0
  73. package/build/dex/cap/cap.js.map +1 -0
  74. package/build/dex/cap/config.d.ts +3 -0
  75. package/build/dex/cap/config.js +25 -0
  76. package/build/dex/cap/config.js.map +1 -0
  77. package/build/dex/cap/types.d.ts +35 -0
  78. package/build/dex/cap/types.js +8 -0
  79. package/build/dex/cap/types.js.map +1 -0
  80. package/build/dex/erc4626/config.js +21 -0
  81. package/build/dex/erc4626/config.js.map +1 -1
  82. package/build/dex/erc4626/erc-4626-pool.d.ts +0 -1
  83. package/build/dex/erc4626/erc-4626-pool.js +0 -6
  84. package/build/dex/erc4626/erc-4626-pool.js.map +1 -1
  85. package/build/dex/erc4626/erc4626.d.ts +5 -1
  86. package/build/dex/erc4626/erc4626.js +28 -6
  87. package/build/dex/erc4626/erc4626.js.map +1 -1
  88. package/build/dex/erc4626/types.d.ts +2 -0
  89. package/build/dex/idle-dao/idle-dao.d.ts +0 -1
  90. package/build/dex/idle-dao/idle-dao.js +11 -23
  91. package/build/dex/idle-dao/idle-dao.js.map +1 -1
  92. package/build/dex/index.js +2 -0
  93. package/build/dex/index.js.map +1 -1
  94. package/build/dex/maker-psm/maker-psm.d.ts +41 -4
  95. package/build/dex/maker-psm/maker-psm.js +143 -40
  96. package/build/dex/maker-psm/maker-psm.js.map +1 -1
  97. package/build/dex/miro-migrator/miro-migrator-state.d.ts +27 -0
  98. package/build/dex/miro-migrator/miro-migrator-state.js +89 -0
  99. package/build/dex/miro-migrator/miro-migrator-state.js.map +1 -0
  100. package/build/dex/stabull/config.d.ts +3 -0
  101. package/build/dex/stabull/config.js +177 -0
  102. package/build/dex/stabull/config.js.map +1 -0
  103. package/build/dex/stabull/stabull-pool.d.ts +46 -0
  104. package/build/dex/stabull/stabull-pool.js +113 -0
  105. package/build/dex/stabull/stabull-pool.js.map +1 -0
  106. package/build/dex/stabull/stabull.d.ts +55 -0
  107. package/build/dex/stabull/stabull.js +286 -0
  108. package/build/dex/stabull/stabull.js.map +1 -0
  109. package/build/dex/stabull/types.d.ts +21 -0
  110. package/build/dex/stabull/types.js +3 -0
  111. package/build/dex/stabull/types.js.map +1 -0
  112. package/build/dex/uniswap-v3/forks/pangolin-v3/utils.d.ts +4 -0
  113. package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js +56 -0
  114. package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js.map +1 -0
  115. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.d.ts +7 -0
  116. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js +28 -0
  117. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js.map +1 -0
  118. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.d.ts +0 -0
  119. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js +2 -0
  120. package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js.map +1 -0
  121. package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.d.ts +7 -0
  122. package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js +28 -0
  123. package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js.map +1 -0
  124. package/build/dex/uniswap-v4/hooks/fee-hook/types.d.ts +0 -0
  125. package/build/dex/uniswap-v4/hooks/fee-hook/types.js +2 -0
  126. package/build/dex/uniswap-v4/hooks/fee-hook/types.js.map +1 -0
  127. package/build/dex/uniswap-v4/hooks/index.d.ts +2 -0
  128. package/build/dex/uniswap-v4/hooks/index.js +8 -0
  129. package/build/dex/uniswap-v4/hooks/index.js.map +1 -0
  130. package/build/dex/usdc-transmuter/usdc-transmuter-pool.d.ts +26 -0
  131. package/build/dex/usdc-transmuter/usdc-transmuter-pool.js +75 -0
  132. package/build/dex/usdc-transmuter/usdc-transmuter-pool.js.map +1 -0
  133. package/build/dex/usual/usual-usdc-usdc.d.ts +17 -0
  134. package/build/dex/usual/usual-usdc-usdc.js +59 -0
  135. package/build/dex/usual/usual-usdc-usdc.js.map +1 -0
  136. package/build/dex/yo/config.d.ts +3 -0
  137. package/build/dex/yo/config.js +21 -0
  138. package/build/dex/yo/config.js.map +1 -0
  139. package/build/dex/yo/types.d.ts +13 -0
  140. package/build/dex/yo/types.js +3 -0
  141. package/build/dex/yo/types.js.map +1 -0
  142. package/build/dex/yo/yo-pool.d.ts +13 -0
  143. package/build/dex/yo/yo-pool.js +26 -0
  144. package/build/dex/yo/yo-pool.js.map +1 -0
  145. package/build/dex/yo/yo.d.ts +39 -0
  146. package/build/dex/yo/yo.js +248 -0
  147. package/build/dex/yo/yo.js.map +1 -0
  148. package/package.json +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cabalcoin-hook-pool.js","sourceRoot":"","sources":["../../../../../src/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.ts"],"names":[],"mappings":";;;;;;AAAA,4CAA+C;AAC/C,2DAAsD;AAEtD,mFAA6E;AAE7E,uHAAwF;AAExF,MAAa,iBAAkB,SAAQ,+BAAa;IAC1C,aAAa,GAAG,IAAI,eAAS,CAAC,iCAAgB,CAAC,CAAC;IAExD,YAAY,GAAG,IAAiD;QAC9D,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;QAEf,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAEtE,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC;YAC/B,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,KAAK,CAAC,2BAA2B,CAAC,KAAU,EAAE,SAAoB;QAChE,MAAM,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC;QACvC,wCAAiB,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAElD,SAAS,CAAC,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAE7C,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AArBD,8CAqBC"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/dex/uniswap-v4/hooks/cabalcoin-hook/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ import { UniswapV4Pool } from '../../uniswap-v4-pool';
2
+ import { PoolState } from '../../types';
3
+ export declare class FeeHookPool extends UniswapV4Pool {
4
+ private hookInterface;
5
+ constructor(...args: ConstructorParameters<typeof UniswapV4Pool>);
6
+ handleCustomFeeChangedEvent(event: any, poolState: PoolState): Promise<PoolState>;
7
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.FeeHookPool = void 0;
7
+ const abi_1 = require("@ethersproject/abi");
8
+ const uniswap_v4_pool_1 = require("../../uniswap-v4-pool");
9
+ const uniswap_v4_pool_math_1 = require("../../contract-math/uniswap-v4-pool-math");
10
+ const fee_hook_abi_json_1 = __importDefault(require("../../../../abi/uniswap-v4/hooks/fee-hook.abi.json"));
11
+ class FeeHookPool extends uniswap_v4_pool_1.UniswapV4Pool {
12
+ hookInterface = new abi_1.Interface(fee_hook_abi_json_1.default);
13
+ constructor(...args) {
14
+ super(...args);
15
+ this.addressesSubscribed.push(this.hooks);
16
+ this.logDecoders.push((log) => this.hookInterface.parseLog(log));
17
+ this.handlers['CustomFeeChanged'] =
18
+ this.handleCustomFeeChangedEvent.bind(this);
19
+ }
20
+ async handleCustomFeeChangedEvent(event, poolState) {
21
+ const id = event.args.id.toLowerCase();
22
+ uniswap_v4_pool_math_1.uniswapV4PoolMath.checkPoolInitialized(poolState);
23
+ poolState.fee = event.args.newFee.toString();
24
+ return poolState;
25
+ }
26
+ }
27
+ exports.FeeHookPool = FeeHookPool;
28
+ //# sourceMappingURL=fee-hook-pool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fee-hook-pool.js","sourceRoot":"","sources":["../../../../../src/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.ts"],"names":[],"mappings":";;;;;;AAAA,4CAA+C;AAC/C,2DAAsD;AAEtD,mFAA6E;AAE7E,2GAA4E;AAE5E,MAAa,WAAY,SAAQ,+BAAa;IACpC,aAAa,GAAG,IAAI,eAAS,CAAC,2BAAU,CAAC,CAAC;IAElD,YAAY,GAAG,IAAiD;QAC9D,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;QAEf,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAEtE,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC;YAC/B,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,KAAK,CAAC,2BAA2B,CAAC,KAAU,EAAE,SAAoB;QAChE,MAAM,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC;QACvC,wCAAiB,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAElD,SAAS,CAAC,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAE7C,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AArBD,kCAqBC"}
File without changes
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/dex/uniswap-v4/hooks/fee-hook/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export { FeeHookPool } from './fee-hook/fee-hook-pool';
2
+ export { CabalcoinHookPool } from './cabalcoin-hook/cabalcoin-hook-pool';
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CabalcoinHookPool = exports.FeeHookPool = void 0;
4
+ var fee_hook_pool_1 = require("./fee-hook/fee-hook-pool");
5
+ Object.defineProperty(exports, "FeeHookPool", { enumerable: true, get: function () { return fee_hook_pool_1.FeeHookPool; } });
6
+ var cabalcoin_hook_pool_1 = require("./cabalcoin-hook/cabalcoin-hook-pool");
7
+ Object.defineProperty(exports, "CabalcoinHookPool", { enumerable: true, get: function () { return cabalcoin_hook_pool_1.CabalcoinHookPool; } });
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/dex/uniswap-v4/hooks/index.ts"],"names":[],"mappings":";;;AAAA,0DAAuD;AAA9C,4GAAA,WAAW,OAAA;AACpB,4EAAyE;AAAhE,wHAAA,iBAAiB,OAAA"}
@@ -0,0 +1,26 @@
1
+ import { Interface } from '@ethersproject/abi';
2
+ import { DeepReadonly } from 'ts-essentials';
3
+ import { Log, Logger } from '../../types';
4
+ import { StatefulEventSubscriber } from '../../stateful-event-subscriber';
5
+ import { IDexHelper } from '../../dex-helper/idex-helper';
6
+ import { PoolState } from './types';
7
+ import { Contract } from 'ethers';
8
+ export declare class UsdcTransmuterEventPool extends StatefulEventSubscriber<PoolState> {
9
+ readonly parentName: string;
10
+ protected network: number;
11
+ protected dexHelper: IDexHelper;
12
+ protected usdcTransmuterAddress: string;
13
+ protected usdcAddress: string;
14
+ protected usdcTransmuterIface: Interface;
15
+ protected usdcContract: Contract;
16
+ handlers: {
17
+ [event: string]: (event: any, state: DeepReadonly<PoolState>, log: Readonly<Log>) => DeepReadonly<PoolState> | null;
18
+ };
19
+ logDecoder: (log: Log) => any;
20
+ constructor(parentName: string, network: number, dexHelper: IDexHelper, logger: Logger, usdcTransmuterAddress: string, usdcAddress: string, usdcTransmuterIface?: Interface, usdcContract?: Contract);
21
+ protected processLog(state: DeepReadonly<PoolState>, log: Readonly<Log>): DeepReadonly<PoolState> | null;
22
+ generateState(blockNumber?: number | 'latest'): Promise<DeepReadonly<PoolState>>;
23
+ getOrGenerateState(blockNumber: number): Promise<PoolState>;
24
+ handleDeposit(event: any, state: DeepReadonly<PoolState>, log: Readonly<Log>): DeepReadonly<PoolState> | null;
25
+ handleWithdrawal(event: any, state: DeepReadonly<PoolState>, log: Readonly<Log>): DeepReadonly<PoolState> | null;
26
+ }
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.UsdcTransmuterEventPool = void 0;
7
+ const abi_1 = require("@ethersproject/abi");
8
+ const utils_1 = require("../../utils");
9
+ const stateful_event_subscriber_1 = require("../../stateful-event-subscriber");
10
+ const usdc_transmuter_abi_json_1 = __importDefault(require("../../abi/usdc-transmuter/usdc-transmuter.abi.json"));
11
+ const utils_2 = require("../../lib/tokens/utils");
12
+ const ethers_1 = require("ethers");
13
+ class UsdcTransmuterEventPool extends stateful_event_subscriber_1.StatefulEventSubscriber {
14
+ parentName;
15
+ network;
16
+ dexHelper;
17
+ usdcTransmuterAddress;
18
+ usdcAddress;
19
+ usdcTransmuterIface;
20
+ usdcContract;
21
+ handlers = {};
22
+ logDecoder;
23
+ constructor(parentName, network, dexHelper, logger, usdcTransmuterAddress, usdcAddress, usdcTransmuterIface = new abi_1.Interface(usdc_transmuter_abi_json_1.default), usdcContract = new ethers_1.Contract(usdcAddress, utils_2.erc20Iface, dexHelper.provider)) {
24
+ super(parentName, 'usdc', dexHelper, logger);
25
+ this.parentName = parentName;
26
+ this.network = network;
27
+ this.dexHelper = dexHelper;
28
+ this.usdcTransmuterAddress = usdcTransmuterAddress;
29
+ this.usdcAddress = usdcAddress;
30
+ this.usdcTransmuterIface = usdcTransmuterIface;
31
+ this.usdcContract = usdcContract;
32
+ this.logDecoder = (log) => this.usdcTransmuterIface.parseLog(log);
33
+ this.addressesSubscribed = [usdcTransmuterAddress];
34
+ this.handlers['Deposit'] = this.handleDeposit.bind(this);
35
+ this.handlers['Withdraw'] = this.handleWithdrawal.bind(this);
36
+ }
37
+ processLog(state, log) {
38
+ try {
39
+ const event = this.logDecoder(log);
40
+ if (event.name in this.handlers) {
41
+ return this.handlers[event.name](event, state, log);
42
+ }
43
+ }
44
+ catch (e) {
45
+ (0, utils_1.catchParseLogError)(e, this.logger);
46
+ }
47
+ return null;
48
+ }
49
+ async generateState(blockNumber = 'latest') {
50
+ const balance = await this.usdcContract.balanceOf(this.usdcTransmuterAddress, { blockTag: blockNumber });
51
+ return {
52
+ balance: balance.toBigInt(),
53
+ };
54
+ }
55
+ async getOrGenerateState(blockNumber) {
56
+ let state = this.getState(blockNumber);
57
+ if (!state) {
58
+ state = await this.generateState(blockNumber);
59
+ this.setState(state, blockNumber);
60
+ }
61
+ return state;
62
+ }
63
+ handleDeposit(event, state, log) {
64
+ return {
65
+ balance: state.balance + event.args.amount.toBigInt(),
66
+ };
67
+ }
68
+ handleWithdrawal(event, state, log) {
69
+ return {
70
+ balance: state.balance - event.args.amount.toBigInt(),
71
+ };
72
+ }
73
+ }
74
+ exports.UsdcTransmuterEventPool = UsdcTransmuterEventPool;
75
+ //# sourceMappingURL=usdc-transmuter-pool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usdc-transmuter-pool.js","sourceRoot":"","sources":["../../../src/dex/usdc-transmuter/usdc-transmuter-pool.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { Address, DexExchangeParam, NumberAsString } from '../../types';
2
+ import { Network, SwapSide } from '../../constants';
3
+ import { IDexHelper } from '../../dex-helper/idex-helper';
4
+ import { Interface } from '@ethersproject/abi';
5
+ import { Usual } from './usual';
6
+ export declare class UsualUSDCUsdc extends Usual {
7
+ readonly network: Network;
8
+ readonly dexKey: string;
9
+ readonly dexHelper: IDexHelper;
10
+ static dexKeysWithNetwork: {
11
+ key: string;
12
+ networks: Network[];
13
+ }[];
14
+ usualUsdcIface: Interface;
15
+ constructor(network: Network, dexKey: string, dexHelper: IDexHelper);
16
+ getDexParam(srcToken: Address, destToken: Address, srcAmount: NumberAsString, destAmount: NumberAsString, recipient: Address, data: {}, side: SwapSide): Promise<DexExchangeParam>;
17
+ }
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.UsualUSDCUsdc = void 0;
7
+ const constants_1 = require("../../constants");
8
+ const abi_1 = require("@ethersproject/abi");
9
+ const usual_1 = require("./usual");
10
+ const utils_1 = require("../../utils");
11
+ const utils_2 = require("../../executor/utils");
12
+ const abi_json_1 = __importDefault(require("../../abi/usual-usual-usdc/abi.json"));
13
+ const Config = {
14
+ UsualUSDCUsdc: {
15
+ [constants_1.Network.MAINNET]: {
16
+ fromToken: {
17
+ address: '0xb672B3976bAa3952bFb2eCE8eeFB784f8daB1424', // Usual USDC
18
+ decimals: 6,
19
+ },
20
+ toToken: {
21
+ address: '0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48', // USDC
22
+ decimals: 6,
23
+ },
24
+ },
25
+ },
26
+ };
27
+ class UsualUSDCUsdc extends usual_1.Usual {
28
+ network;
29
+ dexKey;
30
+ dexHelper;
31
+ static dexKeysWithNetwork = (0, utils_1.getDexKeysWithNetwork)(Config);
32
+ usualUsdcIface;
33
+ constructor(network, dexKey, dexHelper) {
34
+ super(network, dexKey, dexHelper, Config[dexKey][network]);
35
+ this.network = network;
36
+ this.dexKey = dexKey;
37
+ this.dexHelper = dexHelper;
38
+ this.usualUsdcIface = new abi_1.Interface(abi_json_1.default);
39
+ }
40
+ async getDexParam(srcToken, destToken, srcAmount, destAmount, recipient, data, side) {
41
+ if (this.isFromToken(srcToken) && this.isToToken(destToken)) {
42
+ const UNWRAP_FUNCTION = 'unwrap(address,uint256)';
43
+ const amount = side === constants_1.SwapSide.SELL ? srcAmount : destAmount;
44
+ const exchangeData = this.usualUsdcIface.encodeFunctionData(UNWRAP_FUNCTION, [recipient, amount]);
45
+ return {
46
+ needWrapNative: false,
47
+ dexFuncHasRecipient: true,
48
+ exchangeData,
49
+ targetExchange: this.config.fromToken.address,
50
+ returnAmountPos: side === constants_1.SwapSide.SELL
51
+ ? (0, utils_2.extractReturnAmountPosition)(this.usualUsdcIface, UNWRAP_FUNCTION)
52
+ : undefined,
53
+ };
54
+ }
55
+ throw new Error('LOGIC ERROR');
56
+ }
57
+ }
58
+ exports.UsualUSDCUsdc = UsualUSDCUsdc;
59
+ //# sourceMappingURL=usual-usdc-usdc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usual-usdc-usdc.js","sourceRoot":"","sources":["../../../src/dex/usual/usual-usdc-usdc.ts"],"names":[],"mappings":";;;;;;AAMA,+CAAoD;AAGpD,4CAA6D;AAC7D,mCAAgC;AAChC,uCAAoD;AACpD,gDAAmE;AACnE,mFAAiE;AAEjE,MAAM,MAAM,GAA4B;IACtC,aAAa,EAAE;QACb,CAAC,mBAAO,CAAC,OAAO,CAAC,EAAE;YACjB,SAAS,EAAE;gBACT,OAAO,EAAE,4CAA4C,EAAE,aAAa;gBACpE,QAAQ,EAAE,CAAC;aACZ;YACD,OAAO,EAAE;gBACP,OAAO,EAAE,4CAA4C,EAAE,OAAO;gBAC9D,QAAQ,EAAE,CAAC;aACZ;SACF;KACF;CACF,CAAC;AAEF,MAAa,aAAc,SAAQ,aAAK;IAO3B;IACA;IACA;IARJ,MAAM,CAAC,kBAAkB,GAC9B,IAAA,6BAAqB,EAAC,MAAM,CAAC,CAAC;IAEhC,cAAc,CAAY;IAE1B,YACW,OAAgB,EAChB,MAAc,EACd,SAAqB;QAE9B,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QAJlD,YAAO,GAAP,OAAO,CAAS;QAChB,WAAM,GAAN,MAAM,CAAQ;QACd,cAAS,GAAT,SAAS,CAAY;QAG9B,IAAI,CAAC,cAAc,GAAG,IAAI,eAAS,CAAC,kBAAgC,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,WAAW,CACf,QAAiB,EACjB,SAAkB,EAClB,SAAyB,EACzB,UAA0B,EAC1B,SAAkB,EAClB,IAAQ,EACR,IAAc;QAEd,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5D,MAAM,eAAe,GAAG,yBAAyB,CAAC;YAClD,MAAM,MAAM,GAAG,IAAI,KAAK,oBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC;YAE/D,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,kBAAkB,CACzD,eAAe,EACf,CAAC,SAAS,EAAE,MAAM,CAAC,CACpB,CAAC;YAEF,OAAO;gBACL,cAAc,EAAE,KAAK;gBACrB,mBAAmB,EAAE,IAAI;gBACzB,YAAY;gBACZ,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO;gBAC7C,eAAe,EACb,IAAI,KAAK,oBAAQ,CAAC,IAAI;oBACpB,CAAC,CAAC,IAAA,mCAA2B,EAAC,IAAI,CAAC,cAAc,EAAE,eAAe,CAAC;oBACnE,CAAC,CAAC,SAAS;aAChB,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,aAAa,CAAC,CAAC;IACjC,CAAC;;AA9CH,sCA+CC"}
@@ -0,0 +1,3 @@
1
+ import { DexParams } from './types';
2
+ import { DexConfigMap } from '../../types';
3
+ export declare const YoConfig: DexConfigMap<DexParams>;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.YoConfig = void 0;
4
+ const constants_1 = require("../../constants");
5
+ exports.YoConfig = {
6
+ yoETH: {
7
+ [constants_1.Network.BASE]: {
8
+ vault: '0x3a43aec53490cb9fa922847385d82fe25d0e9de7',
9
+ asset: '0x4200000000000000000000000000000000000006',
10
+ decimals: 18,
11
+ },
12
+ },
13
+ yoUSD: {
14
+ [constants_1.Network.BASE]: {
15
+ vault: '0x0000000f2eb9f69274678c76222b35eec7588a65',
16
+ asset: '0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913',
17
+ decimals: 6,
18
+ },
19
+ },
20
+ };
21
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/dex/yo/config.ts"],"names":[],"mappings":";;;AAEA,+CAA0C;AAE7B,QAAA,QAAQ,GAA4B;IAC/C,KAAK,EAAE;QACL,CAAC,mBAAO,CAAC,IAAI,CAAC,EAAE;YACd,KAAK,EAAE,4CAA4C;YACnD,KAAK,EAAE,4CAA4C;YACnD,QAAQ,EAAE,EAAE;SACb;KACF;IACD,KAAK,EAAE;QACL,CAAC,mBAAO,CAAC,IAAI,CAAC,EAAE;YACd,KAAK,EAAE,4CAA4C;YACnD,KAAK,EAAE,4CAA4C;YACnD,QAAQ,EAAE,CAAC;SACZ;KACF;CACF,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { Address } from '../../types';
2
+ export type YoData = {
3
+ exchange: Address;
4
+ state: {
5
+ totalShares: string;
6
+ totalAssets: string;
7
+ };
8
+ };
9
+ export type DexParams = {
10
+ vault: string;
11
+ asset: string;
12
+ decimals: number;
13
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/dex/yo/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,13 @@
1
+ import { Interface } from '@ethersproject/abi';
2
+ import { Logger, Address } from '../../types';
3
+ import { IDexHelper } from '../../dex-helper/idex-helper';
4
+ import { ERC4626EventPool } from '../erc4626/erc-4626-pool';
5
+ import { Network } from '../../constants';
6
+ import { ERC4626PoolState } from '../erc4626/types';
7
+ export declare class YoEventPool extends ERC4626EventPool {
8
+ readonly parentName: string;
9
+ protected network: Network;
10
+ protected dexHelper: IDexHelper;
11
+ constructor(parentName: string, network: Network, dexHelper: IDexHelper, logger: Logger, vault: Address, asset: Address, cooldownEnabled?: boolean, yoIface?: Interface);
12
+ withdrawRedeemAllowed(state: ERC4626PoolState): boolean;
13
+ }
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.YoEventPool = void 0;
7
+ const abi_1 = require("@ethersproject/abi");
8
+ const erc_4626_pool_1 = require("../erc4626/erc-4626-pool");
9
+ const ERC4626_json_1 = __importDefault(require("../../abi/ERC4626.json"));
10
+ const constants_1 = require("../erc4626/constants");
11
+ class YoEventPool extends erc_4626_pool_1.ERC4626EventPool {
12
+ parentName;
13
+ network;
14
+ dexHelper;
15
+ constructor(parentName, network, dexHelper, logger, vault, asset, cooldownEnabled = false, yoIface = new abi_1.Interface(ERC4626_json_1.default)) {
16
+ super(parentName, network, `${vault}_${asset}`, dexHelper, vault, asset, yoIface, logger, constants_1.DEPOSIT_TOPIC, constants_1.WITHDRAW_TOPIC, constants_1.TRANSFER_TOPIC, cooldownEnabled);
17
+ this.parentName = parentName;
18
+ this.network = network;
19
+ this.dexHelper = dexHelper;
20
+ }
21
+ withdrawRedeemAllowed(state) {
22
+ return true;
23
+ }
24
+ }
25
+ exports.YoEventPool = YoEventPool;
26
+ //# sourceMappingURL=yo-pool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"yo-pool.js","sourceRoot":"","sources":["../../../src/dex/yo/yo-pool.ts"],"names":[],"mappings":";;;;;;AAAA,4CAA+C;AAG/C,4DAA4D;AAE5D,0EAAiD;AACjD,oDAI8B;AAG9B,MAAa,WAAY,SAAQ,gCAAgB;IAEpC;IACC;IACA;IAHZ,YACW,UAAkB,EACjB,OAAgB,EAChB,SAAqB,EAC/B,MAAc,EACd,KAAc,EACd,KAAc,EACd,kBAA2B,KAAK,EAChC,OAAO,GAAG,IAAI,eAAS,CAAC,sBAAW,CAAC;QAEpC,KAAK,CACH,UAAU,EACV,OAAO,EACP,GAAG,KAAK,IAAI,KAAK,EAAE,EACnB,SAAS,EACT,KAAK,EACL,KAAK,EACL,OAAO,EACP,MAAM,EACN,yBAAa,EACb,0BAAc,EACd,0BAAc,EACd,eAAe,CAChB,CAAC;QAtBO,eAAU,GAAV,UAAU,CAAQ;QACjB,YAAO,GAAP,OAAO,CAAS;QAChB,cAAS,GAAT,SAAS,CAAY;IAqBjC,CAAC;IAED,qBAAqB,CAAC,KAAuB;QAC3C,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AA9BD,kCA8BC"}
@@ -0,0 +1,39 @@
1
+ import { Token, Address, ExchangePrices, PoolPrices, AdapterExchangeParam, SimpleExchangeParam, PoolLiquidity, Logger, NumberAsString, DexExchangeParam } from '../../types';
2
+ import { SwapSide, Network } from '../../constants';
3
+ import { IDex, Context } from '../idex';
4
+ import { IDexHelper } from '../../dex-helper/idex-helper';
5
+ import { YoData } from './types';
6
+ import { YoEventPool } from './yo-pool';
7
+ import { ERC4626 } from '../erc4626/erc4626';
8
+ import { Interface } from '@ethersproject/abi';
9
+ export declare enum ERC4626Functions {
10
+ deposit = "deposit",
11
+ redeem = "redeem",
12
+ withdraw = "withdraw",
13
+ mint = "mint"
14
+ }
15
+ export declare class Yo extends ERC4626 implements IDex<YoData> {
16
+ readonly network: Network;
17
+ readonly dexKey: string;
18
+ readonly dexHelper: IDexHelper;
19
+ readonly vault: string;
20
+ readonly asset: string;
21
+ readonly decimals: number;
22
+ readonly erc4626Interface: Interface;
23
+ readonly needWrapNative = true;
24
+ readonly isFeeOnTransferSupported = false;
25
+ static dexKeysWithNetwork: {
26
+ key: string;
27
+ networks: Network[];
28
+ }[];
29
+ logger: Logger;
30
+ readonly eventPool: YoEventPool;
31
+ constructor(network: Network, dexKey: string, dexHelper: IDexHelper, vault?: string, asset?: string, decimals?: number, erc4626Interface?: Interface);
32
+ getPricesVolume(srcToken: Token, destToken: Token, amounts: bigint[], side: SwapSide, blockNumber: number): Promise<null | ExchangePrices<YoData>>;
33
+ getSimpleParam(srcToken: string, destToken: string, srcAmount: string, destAmount: string, data: YoData, side: SwapSide): Promise<SimpleExchangeParam>;
34
+ getDexParam(srcToken: Address, destToken: Address, srcAmount: NumberAsString, destAmount: NumberAsString, recipient: Address, data: YoData, side: SwapSide, _: Context, executorAddress: Address): Promise<DexExchangeParam>;
35
+ getAdapterParam(srcToken: string, destToken: string, srcAmount: string, destAmount: string, data: YoData, side: SwapSide): AdapterExchangeParam;
36
+ getCalldataGasCost(_poolPrices: PoolPrices<YoData>): number | number[];
37
+ updatePoolState(): Promise<void>;
38
+ getTopPoolsForToken(tokenAddress: Address, _limit: number): Promise<PoolLiquidity[]>;
39
+ }