@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.
- package/build/abi/PendleRouterStatic.json +19 -0
- package/build/abi/apex-defi/ApexDefiFactory.abi.json +1749 -0
- package/build/abi/apex-defi/ApexDefiRouter.abi.json +1120 -0
- package/build/abi/apex-defi/ApexDefiToken.abi.json +229 -0
- package/build/abi/apex-defi/ApexDefiWrapper.abi.json +92 -0
- package/build/abi/apex-defi/ApexDefiWrapperFactory.abi.json +1107 -0
- package/build/abi/cap/CapToken.json +2111 -0
- package/build/abi/cap/PriceOracle.json +762 -0
- package/build/abi/pangolin-v3/PangolinV3StateMulticall.abi.json +796 -0
- package/build/abi/pendle/pendle-deployer.abi.json +520 -0
- package/build/abi/pendle/pendle-oracle.abi.json +413 -0
- package/build/abi/ring-v2/few-wrapped-token.json +587 -0
- package/build/abi/ring-v2/ring-v2-factory.json +125 -0
- package/build/abi/ring-v2/ring-v2-pool.json +461 -0
- package/build/abi/ring-v2/ring-v2-router.json +332 -0
- package/build/abi/stabull/stabull-curve.json +738 -0
- package/build/abi/stabull/stabull-router.json +76 -0
- package/build/abi/uniswap-v4/hooks/cabalcoin-hook.abi.json +682 -0
- package/build/abi/uniswap-v4/hooks/fee-hook.abi.json +1335 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.d.ts +29 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js +153 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.d.ts +40 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js +323 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/config.d.ts +3 -0
- package/build/dex/aave-pt-to-underlying/config.js +24 -0
- package/build/dex/aave-pt-to-underlying/config.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/constants.d.ts +2 -0
- package/build/dex/aave-pt-to-underlying/constants.js +6 -0
- package/build/dex/aave-pt-to-underlying/constants.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/types.d.ts +24 -0
- package/build/dex/aave-pt-to-underlying/types.js +3 -0
- package/build/dex/aave-pt-to-underlying/types.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.d.ts +39 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js +244 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/config.d.ts +3 -0
- package/build/dex/aave-pt-to-usdc/config.js +47 -0
- package/build/dex/aave-pt-to-usdc/config.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/constants.d.ts +2 -0
- package/build/dex/aave-pt-to-usdc/constants.js +6 -0
- package/build/dex/aave-pt-to-usdc/constants.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/types.d.ts +22 -0
- package/build/dex/aave-pt-to-usdc/types.js +3 -0
- package/build/dex/aave-pt-to-usdc/types.js.map +1 -0
- package/build/dex/apex-defi/apex-defi-factory.d.ts +26 -0
- package/build/dex/apex-defi/apex-defi-factory.js +53 -0
- package/build/dex/apex-defi/apex-defi-factory.js.map +1 -0
- package/build/dex/apex-defi/apex-defi-pool.d.ts +55 -0
- package/build/dex/apex-defi/apex-defi-pool.js +247 -0
- package/build/dex/apex-defi/apex-defi-pool.js.map +1 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.d.ts +57 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.js +250 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.js.map +1 -0
- package/build/dex/apex-defi/apex-defi.d.ts +97 -0
- package/build/dex/apex-defi/apex-defi.js +1021 -0
- package/build/dex/apex-defi/apex-defi.js.map +1 -0
- package/build/dex/apex-defi/config.d.ts +4 -0
- package/build/dex/apex-defi/config.js +138 -0
- package/build/dex/apex-defi/config.js.map +1 -0
- package/build/dex/apex-defi/types.d.ts +32 -0
- package/build/dex/apex-defi/types.js +3 -0
- package/build/dex/apex-defi/types.js.map +1 -0
- package/build/dex/apex-defi/utils.d.ts +46 -0
- package/build/dex/apex-defi/utils.js +133 -0
- package/build/dex/apex-defi/utils.js.map +1 -0
- package/build/dex/cap/cap-pools.d.ts +44 -0
- package/build/dex/cap/cap-pools.js +199 -0
- package/build/dex/cap/cap-pools.js.map +1 -0
- package/build/dex/cap/cap.d.ts +48 -0
- package/build/dex/cap/cap.js +335 -0
- package/build/dex/cap/cap.js.map +1 -0
- package/build/dex/cap/config.d.ts +3 -0
- package/build/dex/cap/config.js +25 -0
- package/build/dex/cap/config.js.map +1 -0
- package/build/dex/cap/types.d.ts +35 -0
- package/build/dex/cap/types.js +8 -0
- package/build/dex/cap/types.js.map +1 -0
- package/build/dex/erc4626/config.js +21 -0
- package/build/dex/erc4626/config.js.map +1 -1
- package/build/dex/erc4626/erc-4626-pool.d.ts +0 -1
- package/build/dex/erc4626/erc-4626-pool.js +0 -6
- package/build/dex/erc4626/erc-4626-pool.js.map +1 -1
- package/build/dex/erc4626/erc4626.d.ts +5 -1
- package/build/dex/erc4626/erc4626.js +28 -6
- package/build/dex/erc4626/erc4626.js.map +1 -1
- package/build/dex/erc4626/types.d.ts +2 -0
- package/build/dex/idle-dao/idle-dao.d.ts +0 -1
- package/build/dex/idle-dao/idle-dao.js +11 -23
- package/build/dex/idle-dao/idle-dao.js.map +1 -1
- package/build/dex/index.js +2 -0
- package/build/dex/index.js.map +1 -1
- package/build/dex/maker-psm/maker-psm.d.ts +41 -4
- package/build/dex/maker-psm/maker-psm.js +143 -40
- package/build/dex/maker-psm/maker-psm.js.map +1 -1
- package/build/dex/miro-migrator/miro-migrator-state.d.ts +27 -0
- package/build/dex/miro-migrator/miro-migrator-state.js +89 -0
- package/build/dex/miro-migrator/miro-migrator-state.js.map +1 -0
- package/build/dex/stabull/config.d.ts +3 -0
- package/build/dex/stabull/config.js +177 -0
- package/build/dex/stabull/config.js.map +1 -0
- package/build/dex/stabull/stabull-pool.d.ts +46 -0
- package/build/dex/stabull/stabull-pool.js +113 -0
- package/build/dex/stabull/stabull-pool.js.map +1 -0
- package/build/dex/stabull/stabull.d.ts +55 -0
- package/build/dex/stabull/stabull.js +286 -0
- package/build/dex/stabull/stabull.js.map +1 -0
- package/build/dex/stabull/types.d.ts +21 -0
- package/build/dex/stabull/types.js +3 -0
- package/build/dex/stabull/types.js.map +1 -0
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.d.ts +4 -0
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js +56 -0
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.d.ts +7 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js +28 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.d.ts +0 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js +2 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.d.ts +7 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js +28 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.d.ts +0 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.js +2 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/index.d.ts +2 -0
- package/build/dex/uniswap-v4/hooks/index.js +8 -0
- package/build/dex/uniswap-v4/hooks/index.js.map +1 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.d.ts +26 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.js +75 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.js.map +1 -0
- package/build/dex/usual/usual-usdc-usdc.d.ts +17 -0
- package/build/dex/usual/usual-usdc-usdc.js +59 -0
- package/build/dex/usual/usual-usdc-usdc.js.map +1 -0
- package/build/dex/yo/config.d.ts +3 -0
- package/build/dex/yo/config.js +21 -0
- package/build/dex/yo/config.js.map +1 -0
- package/build/dex/yo/types.d.ts +13 -0
- package/build/dex/yo/types.js +3 -0
- package/build/dex/yo/types.js.map +1 -0
- package/build/dex/yo/yo-pool.d.ts +13 -0
- package/build/dex/yo/yo-pool.js +26 -0
- package/build/dex/yo/yo-pool.js.map +1 -0
- package/build/dex/yo/yo.d.ts +39 -0
- package/build/dex/yo/yo.js +248 -0
- package/build/dex/yo/yo.js.map +1 -0
- 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"}
|
|
File without changes
|
|
@@ -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 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/dex/uniswap-v4/hooks/fee-hook/types.ts"],"names":[],"mappings":""}
|
|
@@ -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,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 @@
|
|
|
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
|
+
}
|