@defisaver/automation-sdk 3.0.9-dev → 3.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +3 -3
- package/.editorconfig +9 -9
- package/.env.dev +4 -4
- package/.eslintignore +6 -7
- package/.eslintrc.js +39 -41
- package/.mocharc.json +5 -0
- package/.nvmrc +1 -0
- package/README.md +47 -41
- package/cjs/abis/Erc20.json +223 -0
- package/cjs/abis/SubStorage.json +21 -0
- package/cjs/abis/UniMulticall.json +17 -0
- package/cjs/abis/index.d.ts +9 -0
- package/cjs/abis/index.js +30 -0
- package/cjs/abis/legacy_AaveV2Subscriptions.json +8 -0
- package/cjs/abis/legacy_AuthCheck.json +8 -0
- package/cjs/abis/legacy_CompoundV2Subscriptions.json +9 -0
- package/cjs/abis/legacy_MakerSubscriptions.json +9 -0
- package/cjs/automation/private/Automation.d.ts +12 -0
- package/cjs/automation/private/Automation.js +42 -0
- package/cjs/automation/private/LegacyAutomation.d.ts +25 -0
- package/cjs/automation/private/LegacyAutomation.js +118 -0
- package/cjs/automation/private/LegacyProtocol.d.ts +22 -0
- package/cjs/automation/private/LegacyProtocol.js +41 -0
- package/cjs/automation/private/LegacyProtocol.test.d.ts +1 -0
- package/cjs/automation/private/LegacyProtocol.test.js +25 -0
- package/cjs/automation/private/Protocol.d.ts +22 -0
- package/cjs/automation/private/Protocol.js +41 -0
- package/cjs/automation/private/Protocol.test.d.ts +1 -0
- package/cjs/automation/private/Protocol.test.js +25 -0
- package/cjs/automation/private/StrategiesAutomation.d.ts +33 -0
- package/cjs/automation/private/StrategiesAutomation.js +181 -0
- package/cjs/automation/private/StrategiesAutomation.test.d.ts +1 -0
- package/cjs/automation/private/StrategiesAutomation.test.js +671 -0
- package/cjs/automation/public/ArbitrumStrategies.d.ts +5 -0
- package/cjs/automation/public/ArbitrumStrategies.js +13 -0
- package/cjs/automation/public/BaseStrategies.d.ts +5 -0
- package/cjs/automation/public/BaseStrategies.js +13 -0
- package/cjs/automation/public/EthereumStrategies.d.ts +5 -0
- package/cjs/automation/public/EthereumStrategies.js +13 -0
- package/cjs/automation/public/OptimismStrategies.d.ts +5 -0
- package/cjs/automation/public/OptimismStrategies.js +13 -0
- package/cjs/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -0
- package/cjs/automation/public/legacy/LegacyAaveAutomation.js +20 -0
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -0
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.js +20 -0
- package/cjs/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -0
- package/cjs/automation/public/legacy/LegacyMakerAutomation.js +20 -0
- package/cjs/configuration.d.ts +1 -0
- package/cjs/configuration.js +12 -0
- package/cjs/constants/index.d.ts +28 -0
- package/cjs/constants/index.js +474 -0
- package/cjs/index.d.ts +23 -0
- package/cjs/index.js +65 -0
- package/cjs/services/contractService.d.ts +12 -0
- package/cjs/services/contractService.js +54 -0
- package/cjs/services/ethereumService.d.ts +7 -0
- package/cjs/services/ethereumService.js +49 -0
- package/cjs/services/ethereumService.test.d.ts +1 -0
- package/cjs/services/ethereumService.test.js +242 -0
- package/cjs/services/strategiesService.d.ts +2 -0
- package/cjs/services/strategiesService.js +723 -0
- package/cjs/services/strategiesService.test.d.ts +1 -0
- package/cjs/services/strategiesService.test.js +110 -0
- package/cjs/services/strategySubService.d.ts +100 -0
- package/cjs/services/strategySubService.js +264 -0
- package/cjs/services/strategySubService.test.d.ts +1 -0
- package/cjs/services/strategySubService.test.js +934 -0
- package/cjs/services/subDataService.d.ts +192 -0
- package/cjs/services/subDataService.js +475 -0
- package/cjs/services/subDataService.test.d.ts +1 -0
- package/cjs/services/subDataService.test.js +1282 -0
- package/cjs/services/triggerService.d.ts +191 -0
- package/cjs/services/triggerService.js +367 -0
- package/cjs/services/triggerService.test.d.ts +1 -0
- package/cjs/services/triggerService.test.js +926 -0
- package/cjs/services/utils.d.ts +25 -0
- package/cjs/services/utils.js +131 -0
- package/cjs/services/utils.test.d.ts +1 -0
- package/cjs/services/utils.test.js +376 -0
- package/cjs/types/contracts/generated/Erc20.d.ts +53 -0
- package/cjs/types/contracts/generated/Erc20.js +5 -0
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -0
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.js +5 -0
- package/cjs/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -0
- package/cjs/types/contracts/generated/Legacy_AuthCheck.js +5 -0
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -0
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +5 -0
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -0
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.js +5 -0
- package/cjs/types/contracts/generated/SubStorage.d.ts +114 -0
- package/cjs/types/contracts/generated/SubStorage.js +5 -0
- package/cjs/types/contracts/generated/UniMulticall.d.ts +55 -0
- package/cjs/types/contracts/generated/UniMulticall.js +5 -0
- package/cjs/types/contracts/generated/index.d.ts +7 -0
- package/cjs/types/contracts/generated/index.js +2 -0
- package/cjs/types/contracts/generated/types.d.ts +54 -0
- package/cjs/types/contracts/generated/types.js +2 -0
- package/cjs/types/enums.d.ts +181 -0
- package/cjs/types/enums.js +203 -0
- package/cjs/types/index.d.ts +224 -0
- package/cjs/types/index.js +2 -0
- 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 -30
- 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 -42
- package/esm/automation/private/LegacyAutomation.d.ts +25 -25
- package/esm/automation/private/LegacyAutomation.js +112 -118
- package/esm/automation/private/LegacyProtocol.d.ts +22 -22
- package/esm/automation/private/LegacyProtocol.js +38 -41
- package/esm/automation/private/LegacyProtocol.test.d.ts +1 -1
- package/esm/automation/private/LegacyProtocol.test.js +20 -25
- package/esm/automation/private/Protocol.d.ts +22 -22
- package/esm/automation/private/Protocol.js +38 -41
- package/esm/automation/private/Protocol.test.d.ts +1 -1
- package/esm/automation/private/Protocol.test.js +20 -25
- package/esm/automation/private/StrategiesAutomation.d.ts +33 -33
- package/esm/automation/private/StrategiesAutomation.js +175 -181
- package/esm/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/esm/automation/private/StrategiesAutomation.test.js +666 -671
- package/esm/automation/public/ArbitrumStrategies.d.ts +5 -5
- package/esm/automation/public/ArbitrumStrategies.js +7 -13
- package/esm/automation/public/BaseStrategies.d.ts +5 -5
- package/esm/automation/public/BaseStrategies.js +7 -13
- package/esm/automation/public/EthereumStrategies.d.ts +5 -5
- package/esm/automation/public/EthereumStrategies.js +7 -13
- package/esm/automation/public/OptimismStrategies.d.ts +5 -5
- package/esm/automation/public/OptimismStrategies.js +7 -13
- package/esm/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyAaveAutomation.js +14 -20
- package/esm/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyCompoundAutomation.js +14 -20
- package/esm/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyMakerAutomation.js +14 -20
- package/esm/configuration.d.ts +1 -1
- package/esm/configuration.js +7 -12
- package/esm/constants/index.d.ts +28 -28
- package/esm/constants/index.js +468 -474
- package/esm/index.d.ts +23 -23
- package/esm/index.js +23 -65
- package/esm/services/contractService.d.ts +12 -12
- package/esm/services/contractService.js +45 -54
- package/esm/services/ethereumService.d.ts +7 -7
- package/esm/services/ethereumService.js +41 -49
- package/esm/services/ethereumService.test.d.ts +1 -1
- package/esm/services/ethereumService.test.js +237 -242
- package/esm/services/strategiesService.d.ts +2 -2
- package/esm/services/strategiesService.js +696 -723
- package/esm/services/strategiesService.test.d.ts +1 -1
- package/esm/services/strategiesService.test.js +108 -110
- package/esm/services/strategySubService.d.ts +100 -100
- package/esm/services/strategySubService.js +235 -264
- package/esm/services/strategySubService.test.d.ts +1 -1
- package/esm/services/strategySubService.test.js +906 -934
- package/esm/services/subDataService.d.ts +192 -192
- package/esm/services/subDataService.js +469 -475
- package/esm/services/subDataService.test.d.ts +1 -1
- package/esm/services/subDataService.test.js +1254 -1282
- package/esm/services/triggerService.d.ts +191 -191
- package/esm/services/triggerService.js +338 -367
- package/esm/services/triggerService.test.d.ts +1 -1
- package/esm/services/triggerService.test.js +901 -926
- package/esm/services/utils.d.ts +25 -25
- package/esm/services/utils.js +82 -131
- package/esm/services/utils.test.d.ts +1 -1
- package/esm/services/utils.test.js +348 -376
- package/esm/types/contracts/generated/Erc20.d.ts +53 -53
- package/esm/types/contracts/generated/Erc20.js +4 -5
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -129
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.js +4 -5
- package/esm/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -20
- package/esm/types/contracts/generated/Legacy_AuthCheck.js +4 -5
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -128
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +4 -5
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -246
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.js +4 -5
- package/esm/types/contracts/generated/SubStorage.d.ts +114 -114
- package/esm/types/contracts/generated/SubStorage.js +4 -5
- package/esm/types/contracts/generated/UniMulticall.d.ts +55 -55
- package/esm/types/contracts/generated/UniMulticall.js +4 -5
- package/esm/types/contracts/generated/index.d.ts +7 -7
- package/esm/types/contracts/generated/index.js +1 -2
- package/esm/types/contracts/generated/types.d.ts +54 -54
- package/esm/types/contracts/generated/types.js +1 -2
- package/esm/types/enums.d.ts +181 -181
- package/esm/types/enums.js +200 -203
- package/esm/types/index.d.ts +224 -224
- package/esm/types/index.js +1 -2
- package/package.json +61 -71
- 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 +242 -242
- 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/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 +492 -492
- 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 +934 -934
- package/src/services/strategySubService.test.ts +1119 -1119
- package/src/services/strategySubService.ts +518 -518
- package/src/services/subDataService.test.ts +1387 -1387
- package/src/services/subDataService.ts +644 -644
- package/src/services/triggerService.test.ts +1004 -1004
- package/src/services/triggerService.ts +449 -449
- package/src/services/utils.test.ts +430 -430
- package/src/services/utils.ts +103 -103
- package/src/types/enums.ts +197 -197
- package/src/types/index.ts +279 -279
- package/tsconfig.esm.json +8 -0
- package/tsconfig.json +22 -79
- package/umd/index.js +40 -253
- package/.tests.sh +0 -3
- package/all_comits.txt +0 -2134
- package/webpack.umd.js +0 -52
|
@@ -1,41 +1,38 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
if (
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
exports.default = Protocol;
|
|
41
|
-
_Protocol_versionSeparator = new WeakMap();
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
3
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
|
+
};
|
|
6
|
+
var _Protocol_versionSeparator;
|
|
7
|
+
export default class Protocol {
|
|
8
|
+
constructor(args) {
|
|
9
|
+
_Protocol_versionSeparator.set(this, '__');
|
|
10
|
+
this.id = args.id;
|
|
11
|
+
this.name = this.getName();
|
|
12
|
+
this.slug = this.getSlug();
|
|
13
|
+
this.version = this.getVersion();
|
|
14
|
+
this.fullName = this.getFullName();
|
|
15
|
+
}
|
|
16
|
+
hasVersion() {
|
|
17
|
+
return this.id.indexOf(__classPrivateFieldGet(this, _Protocol_versionSeparator, "f")) !== -1;
|
|
18
|
+
}
|
|
19
|
+
splitId() {
|
|
20
|
+
return this.id.split(__classPrivateFieldGet(this, _Protocol_versionSeparator, "f"));
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* @dev See naming convention at ProtocolIdentifiers declaration
|
|
24
|
+
*/
|
|
25
|
+
getVersion() {
|
|
26
|
+
return this.hasVersion() ? this.splitId().reverse()[0] : '';
|
|
27
|
+
}
|
|
28
|
+
getName() {
|
|
29
|
+
return this.hasVersion() ? this.splitId()[0] : this.id;
|
|
30
|
+
}
|
|
31
|
+
getSlug() {
|
|
32
|
+
return this.name.split(' ').join('-').toLowerCase();
|
|
33
|
+
}
|
|
34
|
+
getFullName() {
|
|
35
|
+
return this.hasVersion() ? `${this.name} ${this.version}` : this.name;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
_Protocol_versionSeparator = new WeakMap();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
@@ -1,25 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
(0, chai_1.expect)(actual).to.equal(expected);
|
|
22
|
-
});
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
});
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { ProtocolIdentifiers } from '../../types/enums';
|
|
3
|
+
import Protocol from './Protocol';
|
|
4
|
+
describe('Feature: Protocol.ts', () => {
|
|
5
|
+
describe('When testing class Protocol', () => {
|
|
6
|
+
const exampleProtocol = new Protocol({ id: ProtocolIdentifiers.StrategiesAutomation.AaveV3 });
|
|
7
|
+
const examples = [
|
|
8
|
+
[exampleProtocol.id, 'Aave__V3'],
|
|
9
|
+
[exampleProtocol.name, 'Aave'],
|
|
10
|
+
[exampleProtocol.slug, 'aave'],
|
|
11
|
+
[exampleProtocol.version, 'V3'],
|
|
12
|
+
[exampleProtocol.fullName, 'Aave V3'],
|
|
13
|
+
];
|
|
14
|
+
examples.forEach(([expected, actual]) => {
|
|
15
|
+
it(`Given ${actual} should return expected value: ${expected}`, () => {
|
|
16
|
+
expect(actual).to.equal(expected);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
});
|
|
@@ -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, SubStorage } 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<any[]>;
|
|
21
|
-
protected getUpdateDataEventsFromSubStorage(options?: PastEventOptions): Promise<any[]>;
|
|
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, SubStorage } 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<any[]>;
|
|
21
|
+
protected getUpdateDataEventsFromSubStorage(options?: PastEventOptions): Promise<any[]>;
|
|
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,181 +1,175 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
function
|
|
6
|
-
function
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
this.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
this
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
return
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
return
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
&& s.
|
|
99
|
-
|
|
100
|
-
&& s.
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
subscriptions.push(Object.assign(Object.assign(
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
return
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
172
|
-
return this._getSubscriptions(
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
177
|
-
return this._getSubscriptions(addresses, options);
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
exports.default = StrategiesAutomation;
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import Dec from 'decimal.js';
|
|
11
|
+
import { Strategies, ProtocolIdentifiers } from '../../types/enums';
|
|
12
|
+
import { addToObjectIf, isDefined, isUndefined } from '../../services/utils';
|
|
13
|
+
import { getAbiItem, makeSubStorageContract } from '../../services/contractService';
|
|
14
|
+
import { getEventsFromContract, multicall } from '../../services/ethereumService';
|
|
15
|
+
import { parseStrategiesAutomatedPosition } from '../../services/strategiesService';
|
|
16
|
+
import Automation from './Automation';
|
|
17
|
+
export default class StrategiesAutomation extends Automation {
|
|
18
|
+
constructor(args) {
|
|
19
|
+
super();
|
|
20
|
+
this.web3 = args.provider;
|
|
21
|
+
this.web3Fork = args.providerFork;
|
|
22
|
+
this.chainId = args.chainId;
|
|
23
|
+
this.subStorageContract = makeSubStorageContract(this.web3, this.chainId);
|
|
24
|
+
this.subStorageContractFork = this.web3Fork ? makeSubStorageContract(this.web3Fork, this.chainId) : null;
|
|
25
|
+
this.assert();
|
|
26
|
+
}
|
|
27
|
+
getEventFromSubStorage(event, options) {
|
|
28
|
+
var _a;
|
|
29
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
30
|
+
// only used for backfilling, so in case options?.fromBlock in undefined
|
|
31
|
+
// (just like we omit fromBlock when we call from app when not on fork), we still want to fetch events
|
|
32
|
+
if (new Dec(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())) {
|
|
33
|
+
return [];
|
|
34
|
+
}
|
|
35
|
+
return getEventsFromContract(this.subStorageContract, this.subStorageContractFork, event, options);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
getStrategiesSubs(subIds, fromBlock = 'latest') {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
let options;
|
|
41
|
+
let web3;
|
|
42
|
+
if (this.web3Fork && this.subStorageContractFork) {
|
|
43
|
+
options = {
|
|
44
|
+
target: this.subStorageContractFork.address,
|
|
45
|
+
abiItem: getAbiItem(this.subStorageContractFork.abi, 'strategiesSubs'),
|
|
46
|
+
};
|
|
47
|
+
web3 = this.web3Fork;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
options = {
|
|
51
|
+
target: this.subStorageContract.address,
|
|
52
|
+
abiItem: getAbiItem(this.subStorageContract.abi, 'strategiesSubs'),
|
|
53
|
+
};
|
|
54
|
+
web3 = this.web3;
|
|
55
|
+
}
|
|
56
|
+
const multicallCalls = subIds.map((subId) => (Object.assign(Object.assign({}, options), { params: [subId] })));
|
|
57
|
+
return multicall(web3, this.chainId, multicallCalls, fromBlock);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
getSubscriptionEventsFromSubStorage(options) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
return this.getEventFromSubStorage('Subscribe', options);
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
getUpdateDataEventsFromSubStorage(options) {
|
|
66
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
+
const events = yield this.getEventFromSubStorage('UpdateData', options);
|
|
68
|
+
/** @dev - Some RPCs sort events differently */
|
|
69
|
+
return events.sort((a, b) => a.blockNumber - b.blockNumber);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
getParsedSubscriptions(parseData) {
|
|
73
|
+
return parseStrategiesAutomatedPosition(parseData);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* @description Removes expired Limit Order subscriptions
|
|
77
|
+
*/
|
|
78
|
+
removeExpiredSubscriptions(subscriptions) {
|
|
79
|
+
return subscriptions.filter((subscription) => {
|
|
80
|
+
if (!subscription) {
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
const { protocol, strategy, strategyData } = subscription;
|
|
84
|
+
if (protocol.id === ProtocolIdentifiers.StrategiesAutomation.Exchange
|
|
85
|
+
&& strategy.strategyId === Strategies.Identifiers.LimitOrder) {
|
|
86
|
+
return new Dec(strategyData.decoded.triggerData.goodUntil).gt(new Dec(Date.now()).div(1000));
|
|
87
|
+
}
|
|
88
|
+
return true;
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
_mergeCheck(s, current) {
|
|
92
|
+
return s.owner === current.owner
|
|
93
|
+
&& s.strategy.strategyId === current.strategy.strategyId
|
|
94
|
+
&& s.protocol.id === current.protocol.id
|
|
95
|
+
&& s.specific.mergeId === current.specific.mergeWithId
|
|
96
|
+
&& (s.protocol.id !== ProtocolIdentifiers.StrategiesAutomation.MakerDAO // reflexer needs to get added if we have it
|
|
97
|
+
|| s.strategyData.decoded.subData.vaultId === current.strategyData.decoded.triggerData.vaultId)
|
|
98
|
+
&& (s.protocol.id !== ProtocolIdentifiers.StrategiesAutomation.CrvUSD // merge only crvUSD leverage management for the same market
|
|
99
|
+
|| s.strategyData.decoded.subData.controller.toLowerCase() === current.strategyData.decoded.triggerData.controller.toLowerCase())
|
|
100
|
+
&& (s.protocol.id !== ProtocolIdentifiers.StrategiesAutomation.MorphoBlue // merge morpho blue with the same marketId
|
|
101
|
+
|| s.strategyData.decoded.triggerData.marketId.toLowerCase() === current.strategyData.decoded.triggerData.marketId.toLowerCase());
|
|
102
|
+
}
|
|
103
|
+
mergeSubs(_subscriptions) {
|
|
104
|
+
const mergeBase = _subscriptions.filter(s => isDefined(s) && isDefined(s.specific.mergeWithId));
|
|
105
|
+
const mergeExtension = _subscriptions.filter(s => isDefined(s) && isDefined(s.specific.mergeId));
|
|
106
|
+
let subscriptions = _subscriptions.filter(s => isDefined(s) && isUndefined(s.specific.mergeWithId) && isUndefined(s.specific.mergeId)).map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })));
|
|
107
|
+
mergeBase.forEach((current) => {
|
|
108
|
+
const mergePairIndexSubEnabled = mergeExtension.findIndex(s => this._mergeCheck(s, current) && s.isEnabled === current.isEnabled);
|
|
109
|
+
const mergePairIndexSubDisabled = mergeExtension.findIndex(s => this._mergeCheck(s, current));
|
|
110
|
+
const mergePairIndex = mergePairIndexSubEnabled !== -1 ? mergePairIndexSubEnabled : mergePairIndexSubDisabled;
|
|
111
|
+
if (mergePairIndex !== -1) {
|
|
112
|
+
const mergePair = mergeExtension[mergePairIndex];
|
|
113
|
+
mergeExtension.splice(mergePairIndex, 1);
|
|
114
|
+
subscriptions.push(Object.assign(Object.assign(Object.assign({}, mergePair), current), {
|
|
115
|
+
// @ts-ignore
|
|
116
|
+
blockNumber: Dec.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) }));
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
subscriptions.push(Object.assign(Object.assign({}, current), { subIds: [current.subId] }));
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
if (mergeExtension.length > 0) {
|
|
123
|
+
console.error('Not all merge-able extensions were used', mergeExtension);
|
|
124
|
+
subscriptions = [...subscriptions, ...mergeExtension.map((s) => (Object.assign(Object.assign({}, s), { subIds: [s.subId] })))];
|
|
125
|
+
}
|
|
126
|
+
return subscriptions;
|
|
127
|
+
}
|
|
128
|
+
_getSubscriptions(addresses, options) {
|
|
129
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
130
|
+
const _options = Object.assign(Object.assign({}, addToObjectIf(isDefined(options), options)), addToObjectIf(isDefined(addresses), { filter: { proxy: addresses } }));
|
|
131
|
+
let subscriptionEvents = (yield this.getSubscriptionEventsFromSubStorage(_options)); // TODO PlaceholderType
|
|
132
|
+
let subscriptions = [];
|
|
133
|
+
if (subscriptionEvents) {
|
|
134
|
+
let strategiesSubs = yield this.getStrategiesSubs(subscriptionEvents.map((e) => e.returnValues.subId), _options.toBlock);
|
|
135
|
+
if (_options.enabledOnly) {
|
|
136
|
+
const filteredSubscriptionEvents = [];
|
|
137
|
+
strategiesSubs = strategiesSubs.filter((sub, index) => {
|
|
138
|
+
if (sub === null || sub === void 0 ? void 0 : sub.isEnabled)
|
|
139
|
+
filteredSubscriptionEvents.push(subscriptionEvents[index]);
|
|
140
|
+
return sub === null || sub === void 0 ? void 0 : sub.isEnabled;
|
|
141
|
+
});
|
|
142
|
+
subscriptionEvents = filteredSubscriptionEvents;
|
|
143
|
+
}
|
|
144
|
+
subscriptions = yield Promise.all(strategiesSubs.map((sub, index) => __awaiter(this, void 0, void 0, function* () {
|
|
145
|
+
var _a;
|
|
146
|
+
let latestUpdate = subscriptionEvents[index].returnValues;
|
|
147
|
+
if (latestUpdate.subHash !== (sub === null || sub === void 0 ? void 0 : sub.strategySubHash)) {
|
|
148
|
+
const updates = yield this.getUpdateDataEventsFromSubStorage(Object.assign(Object.assign({}, addToObjectIf(!!_options, _options)), { filter: { subId: latestUpdate.subId } }));
|
|
149
|
+
latestUpdate = 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);
|
|
150
|
+
}
|
|
151
|
+
return this.getParsedSubscriptions({
|
|
152
|
+
chainId: this.chainId,
|
|
153
|
+
blockNumber: subscriptionEvents[index].blockNumber,
|
|
154
|
+
subscriptionEventData: latestUpdate,
|
|
155
|
+
strategiesSubsData: sub,
|
|
156
|
+
});
|
|
157
|
+
})));
|
|
158
|
+
if (options === null || options === void 0 ? void 0 : options.mergeSubs) {
|
|
159
|
+
subscriptions = this.mergeSubs(subscriptions);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
return _options.unexpiredOnly ? this.removeExpiredSubscriptions(subscriptions) : subscriptions;
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
getSubscriptions(options) {
|
|
166
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
167
|
+
return this._getSubscriptions(undefined, options);
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
getSubscriptionsFor(addresses, options) {
|
|
171
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
172
|
+
return this._getSubscriptions(addresses, options);
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import '../../configuration';
|
|
1
|
+
import '../../configuration';
|