@defisaver/automation-sdk 3.2.5 → 3.3.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.
- package/.babelrc +3 -3
- package/.editorconfig +9 -9
- package/.env.dev +4 -4
- package/.eslintignore +6 -6
- package/.eslintrc.js +39 -39
- package/.mocharc.json +4 -4
- package/.nvmrc +1 -1
- package/README.md +46 -46
- package/cjs/abis/Erc20.json +223 -223
- package/cjs/abis/SubStorage.json +21 -21
- package/cjs/abis/UniMulticall.json +17 -17
- package/cjs/abis/index.d.ts +9 -9
- package/cjs/abis/index.js +30 -30
- package/cjs/abis/legacy_AaveV2Subscriptions.json +8 -8
- package/cjs/abis/legacy_AuthCheck.json +8 -8
- package/cjs/abis/legacy_CompoundV2Subscriptions.json +9 -9
- package/cjs/abis/legacy_MakerSubscriptions.json +9 -9
- package/cjs/automation/private/Automation.d.ts +12 -12
- package/cjs/automation/private/Automation.js +42 -42
- package/cjs/automation/private/LegacyAutomation.d.ts +25 -25
- package/cjs/automation/private/LegacyAutomation.js +118 -118
- package/cjs/automation/private/LegacyProtocol.d.ts +22 -22
- package/cjs/automation/private/LegacyProtocol.js +41 -41
- package/cjs/automation/private/LegacyProtocol.test.d.ts +1 -1
- package/cjs/automation/private/LegacyProtocol.test.js +25 -25
- package/cjs/automation/private/Protocol.d.ts +22 -22
- package/cjs/automation/private/Protocol.js +41 -41
- package/cjs/automation/private/Protocol.test.d.ts +1 -1
- package/cjs/automation/private/Protocol.test.js +25 -25
- package/cjs/automation/private/StrategiesAutomation.d.ts +33 -33
- package/cjs/automation/private/StrategiesAutomation.js +189 -189
- package/cjs/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/cjs/automation/private/StrategiesAutomation.test.js +671 -671
- package/cjs/automation/public/ArbitrumStrategies.d.ts +5 -5
- package/cjs/automation/public/ArbitrumStrategies.js +13 -13
- package/cjs/automation/public/BaseStrategies.d.ts +5 -5
- package/cjs/automation/public/BaseStrategies.js +13 -13
- package/cjs/automation/public/EthereumStrategies.d.ts +5 -5
- package/cjs/automation/public/EthereumStrategies.js +13 -13
- package/cjs/automation/public/OptimismStrategies.d.ts +5 -5
- package/cjs/automation/public/OptimismStrategies.js +13 -13
- package/cjs/automation/public/Strategies.test.d.ts +1 -1
- package/cjs/automation/public/Strategies.test.js +61 -61
- package/cjs/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyAaveAutomation.js +20 -20
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.js +20 -20
- package/cjs/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyMakerAutomation.js +20 -20
- package/cjs/configuration.d.ts +1 -1
- package/cjs/configuration.js +12 -12
- package/cjs/constants/index.d.ts +28 -28
- package/cjs/constants/index.js +674 -564
- package/cjs/index.d.ts +23 -23
- package/cjs/index.js +65 -65
- package/cjs/services/contractService.d.ts +12 -12
- package/cjs/services/contractService.js +54 -54
- package/cjs/services/ethereumService.d.ts +7 -7
- package/cjs/services/ethereumService.js +49 -49
- package/cjs/services/ethereumService.test.d.ts +1 -1
- package/cjs/services/ethereumService.test.js +242 -242
- package/cjs/services/strategiesService.d.ts +2 -2
- package/cjs/services/strategiesService.js +946 -898
- package/cjs/services/strategiesService.test.d.ts +1 -1
- package/cjs/services/strategiesService.test.js +110 -110
- package/cjs/services/strategySubService.d.ts +113 -111
- package/cjs/services/strategySubService.js +328 -314
- package/cjs/services/strategySubService.test.d.ts +1 -1
- package/cjs/services/strategySubService.test.js +1058 -936
- package/cjs/services/subDataService.d.ts +282 -261
- package/cjs/services/subDataService.js +740 -683
- package/cjs/services/subDataService.test.d.ts +1 -1
- package/cjs/services/subDataService.test.js +1458 -1282
- package/cjs/services/triggerService.d.ts +268 -249
- package/cjs/services/triggerService.js +509 -473
- package/cjs/services/triggerService.test.d.ts +1 -1
- package/cjs/services/triggerService.test.js +1139 -1045
- package/cjs/services/utils.d.ts +30 -30
- package/cjs/services/utils.js +182 -182
- package/cjs/services/utils.test.d.ts +1 -1
- package/cjs/services/utils.test.js +376 -376
- package/cjs/types/contracts/generated/Erc20.d.ts +53 -53
- package/cjs/types/contracts/generated/Erc20.js +5 -5
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -129
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.js +5 -5
- package/cjs/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -20
- package/cjs/types/contracts/generated/Legacy_AuthCheck.js +5 -5
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -128
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +5 -5
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -246
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.js +5 -5
- package/cjs/types/contracts/generated/SubStorage.d.ts +114 -114
- package/cjs/types/contracts/generated/SubStorage.js +5 -5
- package/cjs/types/contracts/generated/UniMulticall.d.ts +55 -55
- package/cjs/types/contracts/generated/UniMulticall.js +5 -5
- package/cjs/types/contracts/generated/index.d.ts +7 -7
- package/cjs/types/contracts/generated/index.js +2 -2
- package/cjs/types/contracts/generated/types.d.ts +54 -54
- package/cjs/types/contracts/generated/types.js +2 -2
- package/cjs/types/enums.d.ts +253 -226
- package/cjs/types/enums.js +279 -252
- package/cjs/types/index.d.ts +264 -248
- package/cjs/types/index.js +2 -2
- package/esm/abis/Erc20.json +223 -223
- package/esm/abis/SubStorage.json +21 -21
- package/esm/abis/UniMulticall.json +17 -17
- package/esm/abis/index.d.ts +9 -9
- package/esm/abis/index.js +18 -18
- package/esm/abis/legacy_AaveV2Subscriptions.json +8 -8
- package/esm/abis/legacy_AuthCheck.json +8 -8
- package/esm/abis/legacy_CompoundV2Subscriptions.json +9 -9
- package/esm/abis/legacy_MakerSubscriptions.json +9 -9
- package/esm/automation/private/Automation.d.ts +12 -12
- package/esm/automation/private/Automation.js +39 -39
- package/esm/automation/private/LegacyAutomation.d.ts +25 -25
- package/esm/automation/private/LegacyAutomation.js +112 -112
- package/esm/automation/private/LegacyProtocol.d.ts +22 -22
- package/esm/automation/private/LegacyProtocol.js +38 -38
- package/esm/automation/private/LegacyProtocol.test.d.ts +1 -1
- package/esm/automation/private/LegacyProtocol.test.js +20 -20
- package/esm/automation/private/Protocol.d.ts +22 -22
- package/esm/automation/private/Protocol.js +38 -38
- package/esm/automation/private/Protocol.test.d.ts +1 -1
- package/esm/automation/private/Protocol.test.js +20 -20
- package/esm/automation/private/StrategiesAutomation.d.ts +33 -33
- package/esm/automation/private/StrategiesAutomation.js +183 -183
- package/esm/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/esm/automation/private/StrategiesAutomation.test.js +666 -666
- package/esm/automation/public/ArbitrumStrategies.d.ts +5 -5
- package/esm/automation/public/ArbitrumStrategies.js +7 -7
- package/esm/automation/public/BaseStrategies.d.ts +5 -5
- package/esm/automation/public/BaseStrategies.js +7 -7
- package/esm/automation/public/EthereumStrategies.d.ts +5 -5
- package/esm/automation/public/EthereumStrategies.js +7 -7
- package/esm/automation/public/OptimismStrategies.d.ts +5 -5
- package/esm/automation/public/OptimismStrategies.js +7 -7
- package/esm/automation/public/Strategies.test.d.ts +1 -1
- package/esm/automation/public/Strategies.test.js +56 -56
- package/esm/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyAaveAutomation.js +14 -14
- package/esm/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyCompoundAutomation.js +14 -14
- package/esm/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyMakerAutomation.js +14 -14
- package/esm/configuration.d.ts +1 -1
- package/esm/configuration.js +7 -7
- package/esm/constants/index.d.ts +28 -28
- package/esm/constants/index.js +668 -558
- package/esm/index.d.ts +23 -23
- package/esm/index.js +23 -23
- package/esm/services/contractService.d.ts +12 -12
- package/esm/services/contractService.js +45 -45
- package/esm/services/ethereumService.d.ts +7 -7
- package/esm/services/ethereumService.js +41 -41
- package/esm/services/ethereumService.test.d.ts +1 -1
- package/esm/services/ethereumService.test.js +237 -237
- package/esm/services/strategiesService.d.ts +2 -2
- package/esm/services/strategiesService.js +916 -868
- package/esm/services/strategiesService.test.d.ts +1 -1
- package/esm/services/strategiesService.test.js +108 -108
- package/esm/services/strategySubService.d.ts +113 -111
- package/esm/services/strategySubService.js +299 -285
- package/esm/services/strategySubService.test.d.ts +1 -1
- package/esm/services/strategySubService.test.js +1030 -908
- package/esm/services/subDataService.d.ts +282 -261
- package/esm/services/subDataService.js +734 -677
- package/esm/services/subDataService.test.d.ts +1 -1
- package/esm/services/subDataService.test.js +1430 -1254
- package/esm/services/triggerService.d.ts +268 -249
- package/esm/services/triggerService.js +480 -444
- package/esm/services/triggerService.test.d.ts +1 -1
- package/esm/services/triggerService.test.js +1114 -1020
- package/esm/services/utils.d.ts +30 -30
- package/esm/services/utils.js +131 -131
- package/esm/services/utils.test.d.ts +1 -1
- package/esm/services/utils.test.js +348 -348
- package/esm/types/contracts/generated/Erc20.d.ts +53 -53
- package/esm/types/contracts/generated/Erc20.js +4 -4
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -129
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.js +4 -4
- package/esm/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -20
- package/esm/types/contracts/generated/Legacy_AuthCheck.js +4 -4
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -128
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +4 -4
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -246
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.js +4 -4
- package/esm/types/contracts/generated/SubStorage.d.ts +114 -114
- package/esm/types/contracts/generated/SubStorage.js +4 -4
- package/esm/types/contracts/generated/UniMulticall.d.ts +55 -55
- package/esm/types/contracts/generated/UniMulticall.js +4 -4
- package/esm/types/contracts/generated/index.d.ts +7 -7
- package/esm/types/contracts/generated/index.js +1 -1
- package/esm/types/contracts/generated/types.d.ts +54 -54
- package/esm/types/contracts/generated/types.js +1 -1
- package/esm/types/enums.d.ts +253 -226
- package/esm/types/enums.js +276 -249
- package/esm/types/index.d.ts +264 -248
- package/esm/types/index.js +1 -1
- package/package.json +60 -60
- package/scripts/generateContractTypes.js +39 -39
- package/src/abis/Erc20.json +222 -222
- package/src/abis/SubStorage.json +21 -21
- package/src/abis/UniMulticall.json +17 -17
- package/src/abis/index.ts +28 -28
- package/src/abis/legacy_AaveV2Subscriptions.json +7 -7
- package/src/abis/legacy_AuthCheck.json +7 -7
- package/src/abis/legacy_CompoundV2Subscriptions.json +8 -8
- package/src/abis/legacy_MakerSubscriptions.json +8 -8
- package/src/automation/private/Automation.ts +44 -44
- package/src/automation/private/LegacyAutomation.ts +135 -135
- package/src/automation/private/LegacyProtocol.test.ts +23 -23
- package/src/automation/private/LegacyProtocol.ts +51 -51
- package/src/automation/private/Protocol.test.ts +23 -23
- package/src/automation/private/Protocol.ts +51 -51
- package/src/automation/private/StrategiesAutomation.test.ts +663 -663
- package/src/automation/private/StrategiesAutomation.ts +254 -254
- package/src/automation/public/ArbitrumStrategies.ts +10 -10
- package/src/automation/public/BaseStrategies.ts +10 -10
- package/src/automation/public/EthereumStrategies.ts +10 -10
- package/src/automation/public/OptimismStrategies.ts +10 -10
- package/src/automation/public/Strategies.test.ts +49 -49
- package/src/automation/public/legacy/LegacyAaveAutomation.ts +20 -20
- package/src/automation/public/legacy/LegacyCompoundAutomation.ts +20 -20
- package/src/automation/public/legacy/LegacyMakerAutomation.ts +20 -20
- package/src/configuration.ts +8 -8
- package/src/constants/index.ts +702 -593
- package/src/index.ts +39 -39
- package/src/services/contractService.ts +77 -77
- package/src/services/ethereumService.test.ts +257 -257
- package/src/services/ethereumService.ts +69 -69
- package/src/services/strategiesService.test.ts +105 -105
- package/src/services/strategiesService.ts +1219 -1158
- package/src/services/strategySubService.test.ts +1250 -1122
- package/src/services/strategySubService.ts +685 -648
- package/src/services/subDataService.test.ts +1546 -1387
- package/src/services/subDataService.ts +1024 -934
- package/src/services/triggerService.test.ts +1234 -1130
- package/src/services/triggerService.ts +659 -602
- package/src/services/utils.test.ts +430 -430
- package/src/services/utils.ts +162 -162
- package/src/types/enums.ts +273 -246
- package/src/types/index.ts +333 -312
- package/tsconfig.esm.json +8 -8
- package/tsconfig.json +22 -22
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import type Web3 from 'web3';
|
|
2
|
-
import type { PastEventOptions } from 'web3-eth-contract';
|
|
3
|
-
import type { Position, Interfaces, EthereumAddress, SubscriptionOptions, Contract, ParseData, BlockNumber } from '../../types';
|
|
4
|
-
import type { StrategyModel, Subscribe, SubStorage, UpdateData } from '../../types/contracts/generated/SubStorage';
|
|
5
|
-
import type { ChainId } from '../../types/enums';
|
|
6
|
-
import Automation from './Automation';
|
|
7
|
-
interface IStrategiesAutomation extends Interfaces.Automation {
|
|
8
|
-
chainId: ChainId;
|
|
9
|
-
providerFork?: Web3;
|
|
10
|
-
}
|
|
11
|
-
export default class StrategiesAutomation extends Automation {
|
|
12
|
-
protected chainId: ChainId;
|
|
13
|
-
protected web3: Web3;
|
|
14
|
-
protected web3Fork?: Web3;
|
|
15
|
-
protected subStorageContract: Contract.WithMeta<SubStorage>;
|
|
16
|
-
protected subStorageContractFork: Contract.WithMeta<SubStorage> | null;
|
|
17
|
-
constructor(args: IStrategiesAutomation);
|
|
18
|
-
protected getEventFromSubStorage(event: string, options?: PastEventOptions): Promise<any[]>;
|
|
19
|
-
protected getStrategiesSubs(subIds: number[], fromBlock?: BlockNumber): Promise<StrategyModel.StoredSubDataStructOutputStruct[]>;
|
|
20
|
-
protected getSubscriptionEventsFromSubStorage(options?: PastEventOptions): Promise<Subscribe[]>;
|
|
21
|
-
protected getUpdateDataEventsFromSubStorage(options?: PastEventOptions): Promise<UpdateData[]>;
|
|
22
|
-
protected getParsedSubscriptions(parseData: ParseData): Position.Automated | null;
|
|
23
|
-
/**
|
|
24
|
-
* @description Removes expired Limit Order subscriptions
|
|
25
|
-
*/
|
|
26
|
-
protected removeExpiredSubscriptions(subscriptions: (Position.Automated | null)[]): (Position.Automated | null)[];
|
|
27
|
-
private _mergeCheck;
|
|
28
|
-
protected mergeSubs(_subscriptions: (Position.Automated | null)[]): Position.Automated[];
|
|
29
|
-
protected _getSubscriptions(addresses?: EthereumAddress[], options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
30
|
-
getSubscriptions(options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
31
|
-
getSubscriptionsFor(addresses: EthereumAddress[], options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
32
|
-
}
|
|
33
|
-
export {};
|
|
1
|
+
import type Web3 from 'web3';
|
|
2
|
+
import type { PastEventOptions } from 'web3-eth-contract';
|
|
3
|
+
import type { Position, Interfaces, EthereumAddress, SubscriptionOptions, Contract, ParseData, BlockNumber } from '../../types';
|
|
4
|
+
import type { StrategyModel, Subscribe, SubStorage, UpdateData } from '../../types/contracts/generated/SubStorage';
|
|
5
|
+
import type { ChainId } from '../../types/enums';
|
|
6
|
+
import Automation from './Automation';
|
|
7
|
+
interface IStrategiesAutomation extends Interfaces.Automation {
|
|
8
|
+
chainId: ChainId;
|
|
9
|
+
providerFork?: Web3;
|
|
10
|
+
}
|
|
11
|
+
export default class StrategiesAutomation extends Automation {
|
|
12
|
+
protected chainId: ChainId;
|
|
13
|
+
protected web3: Web3;
|
|
14
|
+
protected web3Fork?: Web3;
|
|
15
|
+
protected subStorageContract: Contract.WithMeta<SubStorage>;
|
|
16
|
+
protected subStorageContractFork: Contract.WithMeta<SubStorage> | null;
|
|
17
|
+
constructor(args: IStrategiesAutomation);
|
|
18
|
+
protected getEventFromSubStorage(event: string, options?: PastEventOptions): Promise<any[]>;
|
|
19
|
+
protected getStrategiesSubs(subIds: number[], fromBlock?: BlockNumber): Promise<StrategyModel.StoredSubDataStructOutputStruct[]>;
|
|
20
|
+
protected getSubscriptionEventsFromSubStorage(options?: PastEventOptions): Promise<Subscribe[]>;
|
|
21
|
+
protected getUpdateDataEventsFromSubStorage(options?: PastEventOptions): Promise<UpdateData[]>;
|
|
22
|
+
protected getParsedSubscriptions(parseData: ParseData): Position.Automated | null;
|
|
23
|
+
/**
|
|
24
|
+
* @description Removes expired Limit Order subscriptions
|
|
25
|
+
*/
|
|
26
|
+
protected removeExpiredSubscriptions(subscriptions: (Position.Automated | null)[]): (Position.Automated | null)[];
|
|
27
|
+
private _mergeCheck;
|
|
28
|
+
protected mergeSubs(_subscriptions: (Position.Automated | null)[]): Position.Automated[];
|
|
29
|
+
protected _getSubscriptions(addresses?: EthereumAddress[], options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
30
|
+
getSubscriptions(options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
31
|
+
getSubscriptionsFor(addresses: EthereumAddress[], options?: SubscriptionOptions): Promise<(Position.Automated | null)[]>;
|
|
32
|
+
}
|
|
33
|
+
export {};
|
|
@@ -1,189 +1,189 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
16
|
-
const es6_promise_pool_1 = __importDefault(require("es6-promise-pool"));
|
|
17
|
-
const enums_1 = require("../../types/enums");
|
|
18
|
-
const utils_1 = require("../../services/utils");
|
|
19
|
-
const contractService_1 = require("../../services/contractService");
|
|
20
|
-
const ethereumService_1 = require("../../services/ethereumService");
|
|
21
|
-
const strategiesService_1 = require("../../services/strategiesService");
|
|
22
|
-
const Automation_1 = __importDefault(require("./Automation"));
|
|
23
|
-
class StrategiesAutomation extends Automation_1.default {
|
|
24
|
-
constructor(args) {
|
|
25
|
-
super();
|
|
26
|
-
this.web3 = args.provider;
|
|
27
|
-
this.web3Fork = args.providerFork;
|
|
28
|
-
this.chainId = args.chainId;
|
|
29
|
-
this.subStorageContract = (0, contractService_1.makeSubStorageContract)(this.web3, this.chainId);
|
|
30
|
-
this.subStorageContractFork = this.web3Fork ? (0, contractService_1.makeSubStorageContract)(this.web3Fork, this.chainId) : null;
|
|
31
|
-
this.assert();
|
|
32
|
-
}
|
|
33
|
-
getEventFromSubStorage(event, options) {
|
|
34
|
-
var _a;
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
// only used for backfilling, so in case options?.fromBlock in undefined
|
|
37
|
-
// (just like we omit fromBlock when we call from app when not on fork), we still want to fetch events
|
|
38
|
-
if (new decimal_js_1.default(this.subStorageContract.createdBlock.toString()).gt(((_a = options === null || options === void 0 ? void 0 : options.fromBlock) === null || _a === void 0 ? void 0 : _a.toString()) || this.subStorageContract.createdBlock.toString())) {
|
|
39
|
-
return [];
|
|
40
|
-
}
|
|
41
|
-
return (0, ethereumService_1.getEventsFromContract)(this.subStorageContract, this.subStorageContractFork, event, options);
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
getStrategiesSubs(subIds, fromBlock = 'latest') {
|
|
45
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
-
let options;
|
|
47
|
-
let web3;
|
|
48
|
-
if (this.web3Fork && this.subStorageContractFork) {
|
|
49
|
-
options = {
|
|
50
|
-
target: this.subStorageContractFork.address,
|
|
51
|
-
abiItem: (0, contractService_1.getAbiItem)(this.subStorageContractFork.abi, 'strategiesSubs'),
|
|
52
|
-
};
|
|
53
|
-
web3 = this.web3Fork;
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
options = {
|
|
57
|
-
target: this.subStorageContract.address,
|
|
58
|
-
abiItem: (0, contractService_1.getAbiItem)(this.subStorageContract.abi, 'strategiesSubs'),
|
|
59
|
-
};
|
|
60
|
-
web3 = this.web3;
|
|
61
|
-
}
|
|
62
|
-
const multicallCalls = subIds.map((subId) => (Object.assign(Object.assign({}, options), { params: [subId] })));
|
|
63
|
-
return (0, ethereumService_1.multicall)(web3, this.chainId, multicallCalls, fromBlock);
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
getSubscriptionEventsFromSubStorage(options) {
|
|
67
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
68
|
-
return this.getEventFromSubStorage('Subscribe', options);
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
getUpdateDataEventsFromSubStorage(options) {
|
|
72
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
-
const events = yield this.getEventFromSubStorage('UpdateData', options);
|
|
74
|
-
/** @dev - Some RPCs sort events differently */
|
|
75
|
-
return events.sort((a, b) => a.blockNumber - b.blockNumber);
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
getParsedSubscriptions(parseData) {
|
|
79
|
-
return (0, strategiesService_1.parseStrategiesAutomatedPosition)(parseData);
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* @description Removes expired Limit Order subscriptions
|
|
83
|
-
*/
|
|
84
|
-
removeExpiredSubscriptions(subscriptions) {
|
|
85
|
-
return subscriptions.filter((subscription) => {
|
|
86
|
-
if (!subscription) {
|
|
87
|
-
return true;
|
|
88
|
-
}
|
|
89
|
-
const { protocol, strategy, strategyData } = subscription;
|
|
90
|
-
if (protocol.id === enums_1.ProtocolIdentifiers.StrategiesAutomation.Exchange
|
|
91
|
-
&& strategy.strategyId === enums_1.Strategies.Identifiers.LimitOrder) {
|
|
92
|
-
return new decimal_js_1.default(strategyData.decoded.triggerData.goodUntil).gt(new decimal_js_1.default(Date.now()).div(1000));
|
|
93
|
-
}
|
|
94
|
-
return true;
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
_mergeCheck(s, current) {
|
|
98
|
-
return s.owner === current.owner
|
|
99
|
-
&& s.strategy.strategyId === current.strategy.strategyId
|
|
100
|
-
&& s.protocol.id === current.protocol.id
|
|
101
|
-
&& s.specific.mergeId === current.specific.mergeWithId
|
|
102
|
-
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.MakerDAO // reflexer needs to get added if we have it
|
|
103
|
-
|| s.strategyData.decoded.subData.vaultId === current.strategyData.decoded.triggerData.vaultId)
|
|
104
|
-
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.CrvUSD // merge only crvUSD leverage management for the same market
|
|
105
|
-
|| s.strategyData.decoded.subData.controller.toLowerCase() === current.strategyData.decoded.triggerData.controller.toLowerCase())
|
|
106
|
-
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.MorphoBlue // merge morpho blue with the same marketId
|
|
107
|
-
|| s.strategyData.decoded.triggerData.marketId.toLowerCase() === current.strategyData.decoded.triggerData.marketId.toLowerCase());
|
|
108
|
-
}
|
|
109
|
-
mergeSubs(_subscriptions) {
|
|
110
|
-
const mergeBase = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isDefined)(s.specific.mergeWithId));
|
|
111
|
-
const mergeExtension = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isDefined)(s.specific.mergeId));
|
|
112
|
-
let subscriptions = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isUndefined)(s.specific.mergeWithId) && (0, utils_1.isUndefined)(s.specific.mergeId)).map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })));
|
|
113
|
-
mergeBase.forEach((current) => {
|
|
114
|
-
const mergePairIndexSubEnabled = mergeExtension.findIndex(s => this._mergeCheck(s, current) && s.isEnabled === current.isEnabled);
|
|
115
|
-
const mergePairIndexSubDisabled = mergeExtension.findIndex(s => this._mergeCheck(s, current));
|
|
116
|
-
const mergePairIndex = mergePairIndexSubEnabled !== -1 ? mergePairIndexSubEnabled : mergePairIndexSubDisabled;
|
|
117
|
-
if (mergePairIndex !== -1) {
|
|
118
|
-
const mergePair = mergeExtension[mergePairIndex];
|
|
119
|
-
mergeExtension.splice(mergePairIndex, 1);
|
|
120
|
-
subscriptions.push(Object.assign(Object.assign(Object.assign({}, mergePair), current), {
|
|
121
|
-
// @ts-ignore
|
|
122
|
-
blockNumber: decimal_js_1.default.max(mergePair.blockNumber, current.blockNumber).toNumber(), subIds: [current.subId, mergePair.subId], isEnabled: mergePair.isEnabled || current.isEnabled, specific: Object.assign(Object.assign({}, mergePair.specific), current.specific) }));
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
subscriptions.push(Object.assign(Object.assign({}, current), { subIds: [current.subId] }));
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
if (mergeExtension.length > 0) {
|
|
129
|
-
subscriptions = [...subscriptions, ...mergeExtension.map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })))];
|
|
130
|
-
}
|
|
131
|
-
return subscriptions;
|
|
132
|
-
}
|
|
133
|
-
_getSubscriptions(addresses, options) {
|
|
134
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
135
|
-
const _options = Object.assign(Object.assign({}, (0, utils_1.addToObjectIf)((0, utils_1.isDefined)(options), options)), (0, utils_1.addToObjectIf)((0, utils_1.isDefined)(addresses), { filter: { proxy: addresses } }));
|
|
136
|
-
let subscriptionEvents = yield this.getSubscriptionEventsFromSubStorage(_options);
|
|
137
|
-
let subscriptions = [];
|
|
138
|
-
if (subscriptionEvents) {
|
|
139
|
-
let strategiesSubs = yield this.getStrategiesSubs(subscriptionEvents.map((e) => +e.returnValues.subId), _options.toBlock);
|
|
140
|
-
if (_options.enabledOnly) {
|
|
141
|
-
const filteredSubscriptionEvents = [];
|
|
142
|
-
strategiesSubs = strategiesSubs.filter((sub, index) => {
|
|
143
|
-
if (sub === null || sub === void 0 ? void 0 : sub.isEnabled)
|
|
144
|
-
filteredSubscriptionEvents.push(subscriptionEvents[index]);
|
|
145
|
-
return sub === null || sub === void 0 ? void 0 : sub.isEnabled;
|
|
146
|
-
});
|
|
147
|
-
subscriptionEvents = filteredSubscriptionEvents;
|
|
148
|
-
}
|
|
149
|
-
const replaceSubWithUpdate = (index) => __awaiter(this, void 0, void 0, function* () {
|
|
150
|
-
var _a;
|
|
151
|
-
const sub = strategiesSubs[index];
|
|
152
|
-
let latestUpdate = Object.assign({}, subscriptionEvents[index].returnValues);
|
|
153
|
-
if (latestUpdate.subHash !== (sub === null || sub === void 0 ? void 0 : sub.strategySubHash)) {
|
|
154
|
-
const updates = yield this.getUpdateDataEventsFromSubStorage(Object.assign(Object.assign({}, (0, utils_1.addToObjectIf)(!!_options, _options)), { filter: { subId: latestUpdate.subId } }));
|
|
155
|
-
latestUpdate = Object.assign(Object.assign(Object.assign({}, latestUpdate), (_a = updates === null || updates === void 0 ? void 0 : updates[updates.length - 1]) === null || _a === void 0 ? void 0 : _a.returnValues), { 2: latestUpdate[2] });
|
|
156
|
-
}
|
|
157
|
-
subscriptions.push(this.getParsedSubscriptions({
|
|
158
|
-
chainId: this.chainId,
|
|
159
|
-
blockNumber: subscriptionEvents[index].blockNumber,
|
|
160
|
-
subscriptionEventData: latestUpdate,
|
|
161
|
-
strategiesSubsData: sub,
|
|
162
|
-
}));
|
|
163
|
-
});
|
|
164
|
-
// eslint-disable-next-line func-names
|
|
165
|
-
const pool = new es6_promise_pool_1.default(function* () {
|
|
166
|
-
for (let index = 0; index < strategiesSubs.length; index++) {
|
|
167
|
-
yield replaceSubWithUpdate(index);
|
|
168
|
-
}
|
|
169
|
-
}, 50);
|
|
170
|
-
yield pool.start();
|
|
171
|
-
if (options === null || options === void 0 ? void 0 : options.mergeSubs) {
|
|
172
|
-
subscriptions = this.mergeSubs(subscriptions);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
return _options.unexpiredOnly ? this.removeExpiredSubscriptions(subscriptions) : subscriptions;
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
getSubscriptions(options) {
|
|
179
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
180
|
-
return this._getSubscriptions(undefined, options);
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
getSubscriptionsFor(addresses, options) {
|
|
184
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
185
|
-
return this._getSubscriptions(addresses, options);
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
exports.default = StrategiesAutomation;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
16
|
+
const es6_promise_pool_1 = __importDefault(require("es6-promise-pool"));
|
|
17
|
+
const enums_1 = require("../../types/enums");
|
|
18
|
+
const utils_1 = require("../../services/utils");
|
|
19
|
+
const contractService_1 = require("../../services/contractService");
|
|
20
|
+
const ethereumService_1 = require("../../services/ethereumService");
|
|
21
|
+
const strategiesService_1 = require("../../services/strategiesService");
|
|
22
|
+
const Automation_1 = __importDefault(require("./Automation"));
|
|
23
|
+
class StrategiesAutomation extends Automation_1.default {
|
|
24
|
+
constructor(args) {
|
|
25
|
+
super();
|
|
26
|
+
this.web3 = args.provider;
|
|
27
|
+
this.web3Fork = args.providerFork;
|
|
28
|
+
this.chainId = args.chainId;
|
|
29
|
+
this.subStorageContract = (0, contractService_1.makeSubStorageContract)(this.web3, this.chainId);
|
|
30
|
+
this.subStorageContractFork = this.web3Fork ? (0, contractService_1.makeSubStorageContract)(this.web3Fork, this.chainId) : null;
|
|
31
|
+
this.assert();
|
|
32
|
+
}
|
|
33
|
+
getEventFromSubStorage(event, options) {
|
|
34
|
+
var _a;
|
|
35
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
+
// only used for backfilling, so in case options?.fromBlock in undefined
|
|
37
|
+
// (just like we omit fromBlock when we call from app when not on fork), we still want to fetch events
|
|
38
|
+
if (new decimal_js_1.default(this.subStorageContract.createdBlock.toString()).gt(((_a = options === null || options === void 0 ? void 0 : options.fromBlock) === null || _a === void 0 ? void 0 : _a.toString()) || this.subStorageContract.createdBlock.toString())) {
|
|
39
|
+
return [];
|
|
40
|
+
}
|
|
41
|
+
return (0, ethereumService_1.getEventsFromContract)(this.subStorageContract, this.subStorageContractFork, event, options);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
getStrategiesSubs(subIds, fromBlock = 'latest') {
|
|
45
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
+
let options;
|
|
47
|
+
let web3;
|
|
48
|
+
if (this.web3Fork && this.subStorageContractFork) {
|
|
49
|
+
options = {
|
|
50
|
+
target: this.subStorageContractFork.address,
|
|
51
|
+
abiItem: (0, contractService_1.getAbiItem)(this.subStorageContractFork.abi, 'strategiesSubs'),
|
|
52
|
+
};
|
|
53
|
+
web3 = this.web3Fork;
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
options = {
|
|
57
|
+
target: this.subStorageContract.address,
|
|
58
|
+
abiItem: (0, contractService_1.getAbiItem)(this.subStorageContract.abi, 'strategiesSubs'),
|
|
59
|
+
};
|
|
60
|
+
web3 = this.web3;
|
|
61
|
+
}
|
|
62
|
+
const multicallCalls = subIds.map((subId) => (Object.assign(Object.assign({}, options), { params: [subId] })));
|
|
63
|
+
return (0, ethereumService_1.multicall)(web3, this.chainId, multicallCalls, fromBlock);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
getSubscriptionEventsFromSubStorage(options) {
|
|
67
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
68
|
+
return this.getEventFromSubStorage('Subscribe', options);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
getUpdateDataEventsFromSubStorage(options) {
|
|
72
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
+
const events = yield this.getEventFromSubStorage('UpdateData', options);
|
|
74
|
+
/** @dev - Some RPCs sort events differently */
|
|
75
|
+
return events.sort((a, b) => a.blockNumber - b.blockNumber);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
getParsedSubscriptions(parseData) {
|
|
79
|
+
return (0, strategiesService_1.parseStrategiesAutomatedPosition)(parseData);
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* @description Removes expired Limit Order subscriptions
|
|
83
|
+
*/
|
|
84
|
+
removeExpiredSubscriptions(subscriptions) {
|
|
85
|
+
return subscriptions.filter((subscription) => {
|
|
86
|
+
if (!subscription) {
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
const { protocol, strategy, strategyData } = subscription;
|
|
90
|
+
if (protocol.id === enums_1.ProtocolIdentifiers.StrategiesAutomation.Exchange
|
|
91
|
+
&& strategy.strategyId === enums_1.Strategies.Identifiers.LimitOrder) {
|
|
92
|
+
return new decimal_js_1.default(strategyData.decoded.triggerData.goodUntil).gt(new decimal_js_1.default(Date.now()).div(1000));
|
|
93
|
+
}
|
|
94
|
+
return true;
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
_mergeCheck(s, current) {
|
|
98
|
+
return s.owner === current.owner
|
|
99
|
+
&& s.strategy.strategyId === current.strategy.strategyId
|
|
100
|
+
&& s.protocol.id === current.protocol.id
|
|
101
|
+
&& s.specific.mergeId === current.specific.mergeWithId
|
|
102
|
+
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.MakerDAO // reflexer needs to get added if we have it
|
|
103
|
+
|| s.strategyData.decoded.subData.vaultId === current.strategyData.decoded.triggerData.vaultId)
|
|
104
|
+
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.CrvUSD // merge only crvUSD leverage management for the same market
|
|
105
|
+
|| s.strategyData.decoded.subData.controller.toLowerCase() === current.strategyData.decoded.triggerData.controller.toLowerCase())
|
|
106
|
+
&& (s.protocol.id !== enums_1.ProtocolIdentifiers.StrategiesAutomation.MorphoBlue // merge morpho blue with the same marketId
|
|
107
|
+
|| s.strategyData.decoded.triggerData.marketId.toLowerCase() === current.strategyData.decoded.triggerData.marketId.toLowerCase());
|
|
108
|
+
}
|
|
109
|
+
mergeSubs(_subscriptions) {
|
|
110
|
+
const mergeBase = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isDefined)(s.specific.mergeWithId));
|
|
111
|
+
const mergeExtension = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isDefined)(s.specific.mergeId));
|
|
112
|
+
let subscriptions = _subscriptions.filter(s => (0, utils_1.isDefined)(s) && (0, utils_1.isUndefined)(s.specific.mergeWithId) && (0, utils_1.isUndefined)(s.specific.mergeId)).map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })));
|
|
113
|
+
mergeBase.forEach((current) => {
|
|
114
|
+
const mergePairIndexSubEnabled = mergeExtension.findIndex(s => this._mergeCheck(s, current) && s.isEnabled === current.isEnabled);
|
|
115
|
+
const mergePairIndexSubDisabled = mergeExtension.findIndex(s => this._mergeCheck(s, current));
|
|
116
|
+
const mergePairIndex = mergePairIndexSubEnabled !== -1 ? mergePairIndexSubEnabled : mergePairIndexSubDisabled;
|
|
117
|
+
if (mergePairIndex !== -1) {
|
|
118
|
+
const mergePair = mergeExtension[mergePairIndex];
|
|
119
|
+
mergeExtension.splice(mergePairIndex, 1);
|
|
120
|
+
subscriptions.push(Object.assign(Object.assign(Object.assign({}, mergePair), current), {
|
|
121
|
+
// @ts-ignore
|
|
122
|
+
blockNumber: decimal_js_1.default.max(mergePair.blockNumber, current.blockNumber).toNumber(), subIds: [current.subId, mergePair.subId], isEnabled: mergePair.isEnabled || current.isEnabled, specific: Object.assign(Object.assign({}, mergePair.specific), current.specific) }));
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
subscriptions.push(Object.assign(Object.assign({}, current), { subIds: [current.subId] }));
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
if (mergeExtension.length > 0) {
|
|
129
|
+
subscriptions = [...subscriptions, ...mergeExtension.map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })))];
|
|
130
|
+
}
|
|
131
|
+
return subscriptions;
|
|
132
|
+
}
|
|
133
|
+
_getSubscriptions(addresses, options) {
|
|
134
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
135
|
+
const _options = Object.assign(Object.assign({}, (0, utils_1.addToObjectIf)((0, utils_1.isDefined)(options), options)), (0, utils_1.addToObjectIf)((0, utils_1.isDefined)(addresses), { filter: { proxy: addresses } }));
|
|
136
|
+
let subscriptionEvents = yield this.getSubscriptionEventsFromSubStorage(_options);
|
|
137
|
+
let subscriptions = [];
|
|
138
|
+
if (subscriptionEvents) {
|
|
139
|
+
let strategiesSubs = yield this.getStrategiesSubs(subscriptionEvents.map((e) => +e.returnValues.subId), _options.toBlock);
|
|
140
|
+
if (_options.enabledOnly) {
|
|
141
|
+
const filteredSubscriptionEvents = [];
|
|
142
|
+
strategiesSubs = strategiesSubs.filter((sub, index) => {
|
|
143
|
+
if (sub === null || sub === void 0 ? void 0 : sub.isEnabled)
|
|
144
|
+
filteredSubscriptionEvents.push(subscriptionEvents[index]);
|
|
145
|
+
return sub === null || sub === void 0 ? void 0 : sub.isEnabled;
|
|
146
|
+
});
|
|
147
|
+
subscriptionEvents = filteredSubscriptionEvents;
|
|
148
|
+
}
|
|
149
|
+
const replaceSubWithUpdate = (index) => __awaiter(this, void 0, void 0, function* () {
|
|
150
|
+
var _a;
|
|
151
|
+
const sub = strategiesSubs[index];
|
|
152
|
+
let latestUpdate = Object.assign({}, subscriptionEvents[index].returnValues);
|
|
153
|
+
if (latestUpdate.subHash !== (sub === null || sub === void 0 ? void 0 : sub.strategySubHash)) {
|
|
154
|
+
const updates = yield this.getUpdateDataEventsFromSubStorage(Object.assign(Object.assign({}, (0, utils_1.addToObjectIf)(!!_options, _options)), { filter: { subId: latestUpdate.subId } }));
|
|
155
|
+
latestUpdate = Object.assign(Object.assign(Object.assign({}, latestUpdate), (_a = updates === null || updates === void 0 ? void 0 : updates[updates.length - 1]) === null || _a === void 0 ? void 0 : _a.returnValues), { 2: latestUpdate[2] });
|
|
156
|
+
}
|
|
157
|
+
subscriptions.push(this.getParsedSubscriptions({
|
|
158
|
+
chainId: this.chainId,
|
|
159
|
+
blockNumber: subscriptionEvents[index].blockNumber,
|
|
160
|
+
subscriptionEventData: latestUpdate,
|
|
161
|
+
strategiesSubsData: sub,
|
|
162
|
+
}));
|
|
163
|
+
});
|
|
164
|
+
// eslint-disable-next-line func-names
|
|
165
|
+
const pool = new es6_promise_pool_1.default(function* () {
|
|
166
|
+
for (let index = 0; index < strategiesSubs.length; index++) {
|
|
167
|
+
yield replaceSubWithUpdate(index);
|
|
168
|
+
}
|
|
169
|
+
}, 50);
|
|
170
|
+
yield pool.start();
|
|
171
|
+
if (options === null || options === void 0 ? void 0 : options.mergeSubs) {
|
|
172
|
+
subscriptions = this.mergeSubs(subscriptions);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return _options.unexpiredOnly ? this.removeExpiredSubscriptions(subscriptions) : subscriptions;
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
getSubscriptions(options) {
|
|
179
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
180
|
+
return this._getSubscriptions(undefined, options);
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
getSubscriptionsFor(addresses, options) {
|
|
184
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
185
|
+
return this._getSubscriptions(addresses, options);
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
exports.default = StrategiesAutomation;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import '../../configuration';
|
|
1
|
+
import '../../configuration';
|