@defisaver/automation-sdk 2.0.6 → 2.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/.env.dev +5 -0
  2. package/.tests.sh +3 -0
  3. package/README.md +3 -1
  4. package/esm/automation/private/LegacyProtocol.test.d.ts +1 -0
  5. package/esm/automation/private/LegacyProtocol.test.js +25 -0
  6. package/esm/automation/private/Protocol.test.d.ts +1 -0
  7. package/esm/automation/private/Protocol.test.js +25 -0
  8. package/esm/constants/index.js +5 -0
  9. package/esm/services/contractService.d.ts +3 -2
  10. package/esm/services/contractService.js +7 -1
  11. package/esm/services/ethereumService.test.d.ts +1 -0
  12. package/esm/services/ethereumService.test.js +241 -0
  13. package/esm/services/strategiesService.js +14 -0
  14. package/esm/services/strategiesService.test.d.ts +1 -0
  15. package/esm/services/strategiesService.test.js +108 -0
  16. package/esm/services/strategySubService.d.ts +5 -3
  17. package/esm/services/strategySubService.js +10 -6
  18. package/esm/services/strategySubService.test.d.ts +1 -0
  19. package/esm/services/strategySubService.test.js +692 -0
  20. package/esm/services/subDataService.d.ts +8 -1
  21. package/esm/services/subDataService.js +23 -14
  22. package/esm/services/subDataService.test.d.ts +1 -0
  23. package/esm/services/subDataService.test.js +993 -0
  24. package/esm/services/triggerService.d.ts +7 -0
  25. package/esm/services/triggerService.js +14 -1
  26. package/esm/services/triggerService.test.js +119 -17
  27. package/esm/types/enums.d.ts +4 -2
  28. package/esm/types/enums.js +2 -0
  29. package/esm/types/index.d.ts +8 -2
  30. package/package.json +3 -3
  31. package/src/automation/private/LegacyProtocol.test.ts +24 -0
  32. package/src/automation/private/Protocol.test.ts +24 -0
  33. package/src/constants/index.ts +5 -0
  34. package/src/services/contractService.ts +17 -4
  35. package/src/services/ethereumService.test.ts +256 -0
  36. package/src/services/ethereumService.ts +2 -1
  37. package/src/services/strategiesService.test.ts +103 -0
  38. package/src/services/strategiesService.ts +27 -3
  39. package/src/services/strategySubService.test.ts +835 -0
  40. package/src/services/strategySubService.ts +28 -15
  41. package/src/services/subDataService.test.ts +1063 -0
  42. package/src/services/subDataService.ts +29 -14
  43. package/src/services/triggerService.test.ts +131 -19
  44. package/src/services/triggerService.ts +14 -0
  45. package/src/services/utils.test.ts +1 -1
  46. package/src/types/enums.ts +2 -0
  47. package/src/types/index.ts +14 -3
  48. package/umd/index.js +148 -74
package/.env.dev ADDED
@@ -0,0 +1,5 @@
1
+ # Used for testing
2
+ RPC_1=
3
+ RPC_10=
4
+ RPC_8453=
5
+ RPC_42161=
package/.tests.sh ADDED
@@ -0,0 +1,3 @@
1
+ if [ -z "$1" ]; then mocha "./src/**/*.test.ts" --require ts-node/register --extension ts;
2
+ else mocha "./src/**/${1}.test.ts" --require ts-node/register --extension ts;
3
+ fi
package/README.md CHANGED
@@ -33,4 +33,6 @@ const subscriptions = await ethereumStrategies.getSubscriptionsFor(
33
33
  - `./src/services/subDataService.ts`
34
34
  - `./src/services/triggerService.ts`
35
35
  - Write parsing for the strategy in `./src/services/strategeiesService.ts` and add assign it to `const parsingMethodsMapping`
36
- - Test it out!
36
+ - Write tests for each method
37
+ - Run tests with `yarn test` or `yarn test fileName` for a specific file (e.g. `yarn test utils`)
38
+ - Congrats! 🥳
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,25 @@
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
+ const chai_1 = require("chai");
7
+ const enums_1 = require("../../types/enums");
8
+ const LegacyProtocol_1 = __importDefault(require("./LegacyProtocol"));
9
+ describe('Feature: LegacyProtocol.ts', () => {
10
+ describe('When testing class LegacyProtocol', () => {
11
+ const exampleProtocol = new LegacyProtocol_1.default({ id: enums_1.ProtocolIdentifiers.LegacyAutomation.MakerDAO });
12
+ const examples = [
13
+ [exampleProtocol.id, 'MakerDAO'],
14
+ [exampleProtocol.name, 'MakerDAO'],
15
+ [exampleProtocol.slug, 'makerdao'],
16
+ [exampleProtocol.version, ''],
17
+ [exampleProtocol.fullName, 'MakerDAO'],
18
+ ];
19
+ examples.forEach(([expected, actual]) => {
20
+ it(`Given ${actual} should return expected value: ${expected}`, () => {
21
+ (0, chai_1.expect)(actual).to.equal(expected);
22
+ });
23
+ });
24
+ });
25
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,25 @@
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
+ const chai_1 = require("chai");
7
+ const enums_1 = require("../../types/enums");
8
+ const Protocol_1 = __importDefault(require("./Protocol"));
9
+ describe('Feature: Protocol.ts', () => {
10
+ describe('When testing class Protocol', () => {
11
+ const exampleProtocol = new Protocol_1.default({ id: enums_1.ProtocolIdentifiers.StrategiesAutomation.AaveV3 });
12
+ const examples = [
13
+ [exampleProtocol.id, 'Aave__V3'],
14
+ [exampleProtocol.name, 'Aave'],
15
+ [exampleProtocol.slug, 'aave'],
16
+ [exampleProtocol.version, 'V3'],
17
+ [exampleProtocol.fullName, 'Aave V3'],
18
+ ];
19
+ examples.forEach(([expected, actual]) => {
20
+ it(`Given ${actual} should return expected value: ${expected}`, () => {
21
+ (0, chai_1.expect)(actual).to.equal(expected);
22
+ });
23
+ });
24
+ });
25
+ });
@@ -85,6 +85,11 @@ exports.MAINNET_STRATEGIES_INFO = {
85
85
  strategyId: enums_1.Strategies.Identifiers.SavingsDsrSupply,
86
86
  protocol: exports.PROTOCOLS.Liquity,
87
87
  },
88
+ [enums_1.Strategies.MainnetIds.LIQUITY_DEBT_IN_FRONT_REPAY]: {
89
+ strategyOrBundleId: enums_1.Strategies.MainnetIds.LIQUITY_DEBT_IN_FRONT_REPAY,
90
+ strategyId: enums_1.Strategies.Identifiers.DebtInFrontRepay,
91
+ protocol: exports.PROTOCOLS.Liquity,
92
+ },
88
93
  };
89
94
  exports.OPTIMISM_STRATEGIES_INFO = {
90
95
  [enums_1.Strategies.OptimismIds.EXCHANGE_DCA]: {
@@ -1,11 +1,12 @@
1
1
  import type Web3 from 'web3';
2
2
  import type { AbiItem } from 'web3-utils';
3
- import type { Contract } from '../types';
3
+ import type { Contract, EthereumAddress } from '../types';
4
4
  import type { BaseContract } from '../types/contracts/generated/types';
5
- import type { Legacy_AuthCheck, SubStorage, UniMulticall } from '../types/contracts/generated';
5
+ import type { Legacy_AuthCheck, SubStorage, UniMulticall, Erc20 } from '../types/contracts/generated';
6
6
  import { ChainId } from '../types/enums';
7
7
  export declare function getAbiItem(abi: AbiItem[], itemName: string): AbiItem;
8
8
  export declare function makeUniMulticallContract(web3: Web3, chainId: ChainId): Contract.WithMeta<UniMulticall>;
9
9
  export declare function makeSubStorageContract(web3: Web3, chainId: ChainId): Contract.WithMeta<SubStorage>;
10
10
  export declare function makeAuthCheckerContract(web3: Web3, chainId: ChainId): Contract.WithMeta<Legacy_AuthCheck>;
11
11
  export declare function makeLegacySubscriptionContract<T extends BaseContract>(web3: Web3, contractJson: Contract.Json): Contract.WithMeta<T>;
12
+ export declare function makeErc20Contract(web3: Web3, tokenAddress: EthereumAddress, chainId: ChainId): Contract.WithMeta<Erc20>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.makeLegacySubscriptionContract = exports.makeAuthCheckerContract = exports.makeSubStorageContract = exports.makeUniMulticallContract = exports.getAbiItem = void 0;
3
+ exports.makeErc20Contract = exports.makeLegacySubscriptionContract = exports.makeAuthCheckerContract = exports.makeSubStorageContract = exports.makeUniMulticallContract = exports.getAbiItem = void 0;
4
4
  const abis_1 = require("../abis");
5
5
  const utils_1 = require("./utils");
6
6
  const enums_1 = require("../types/enums");
@@ -46,3 +46,9 @@ function makeLegacySubscriptionContract(web3, contractJson) {
46
46
  return makeContract(web3, contractJson, enums_1.ChainId.Ethereum);
47
47
  }
48
48
  exports.makeLegacySubscriptionContract = makeLegacySubscriptionContract;
49
+ function makeErc20Contract(web3, tokenAddress, chainId) {
50
+ return makeContract(web3, Object.assign(Object.assign({}, abis_1.Erc20Json), { networks: {
51
+ [chainId]: { address: tokenAddress },
52
+ } }), chainId);
53
+ }
54
+ exports.makeErc20Contract = makeErc20Contract;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,241 @@
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 web3_1 = __importDefault(require("web3"));
16
+ const chai_1 = require("chai");
17
+ const tokens_1 = require("@defisaver/tokens");
18
+ const enums_1 = require("../types/enums");
19
+ const ethereumService_1 = require("./ethereumService");
20
+ const contractService_1 = require("./contractService");
21
+ require('dotenv').config({ path: '.env' });
22
+ const Web3_1 = new web3_1.default(process.env.RPC_1);
23
+ const Web3_10 = new web3_1.default(process.env.RPC_10);
24
+ const Web3_42161 = new web3_1.default(process.env.RPC_42161);
25
+ describe('Feature: ethereumService.ts', () => {
26
+ describe('When testing ethereumService.multicall', () => {
27
+ const examples = [
28
+ [
29
+ [{ 0: 'Wrapped Ether', '__length__': 1 }, { 0: '18', '__length__': 1 }],
30
+ [
31
+ Web3_1,
32
+ enums_1.ChainId.Ethereum,
33
+ [
34
+ {
35
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'name', 'outputs': [{ 'name': '', 'type': 'string' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
36
+ target: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
37
+ params: [],
38
+ },
39
+ {
40
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'decimals', 'outputs': [{ 'name': '', 'type': 'uint8' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
41
+ target: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
42
+ params: [],
43
+ }
44
+ ],
45
+ 'latest',
46
+ ]
47
+ ],
48
+ [
49
+ [{ 0: 'Wrapped Ether', '__length__': 1 }, { 0: '18', '__length__': 1 }],
50
+ [
51
+ Web3_10,
52
+ enums_1.ChainId.Optimism,
53
+ [
54
+ {
55
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'name', 'outputs': [{ 'name': '', 'type': 'string' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
56
+ target: '0x4200000000000000000000000000000000000006',
57
+ params: [],
58
+ },
59
+ {
60
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'decimals', 'outputs': [{ 'name': '', 'type': 'uint8' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
61
+ target: '0x4200000000000000000000000000000000000006',
62
+ params: [],
63
+ }
64
+ ],
65
+ 'latest',
66
+ ]
67
+ ],
68
+ [
69
+ [{ 0: 'Wrapped Ether', '__length__': 1 }, { 0: '18', '__length__': 1 }],
70
+ [
71
+ Web3_42161,
72
+ enums_1.ChainId.Arbitrum,
73
+ [
74
+ {
75
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'name', 'outputs': [{ 'name': '', 'type': 'string' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
76
+ target: '0x82af49447d8a07e3bd95bd0d56f35241523fbab1',
77
+ params: [],
78
+ },
79
+ {
80
+ abiItem: { 'constant': true, 'inputs': [], 'name': 'decimals', 'outputs': [{ 'name': '', 'type': 'uint8' }], 'payable': false, 'stateMutability': 'view', 'type': 'function' },
81
+ target: '0x82af49447d8a07e3bd95bd0d56f35241523fbab1',
82
+ params: [],
83
+ }
84
+ ],
85
+ 'latest',
86
+ ]
87
+ ],
88
+ ];
89
+ examples.forEach(([expected, actual]) => {
90
+ it(`Given ${actual} should return expected value: ${JSON.stringify(expected)}`, () => __awaiter(void 0, void 0, void 0, function* () {
91
+ (0, chai_1.expect)(yield (0, ethereumService_1.multicall)(...actual)).to.eql(expected);
92
+ }));
93
+ });
94
+ });
95
+ describe('When testing ethereumService.getEventsFromContract', () => {
96
+ const examples = [
97
+ [
98
+ [
99
+ {
100
+ 'address': '0x5f98805A4E8be255a32880FDeC7F6728C6568bA0',
101
+ 'blockHash': '0xb92cab2569456dbfbdb853d2c67d72c9a7580543dbcb55d483a77322b40755a4',
102
+ 'blockNumber': 15166163,
103
+ 'event': 'Transfer',
104
+ 'id': 'log_e2258e3a',
105
+ 'logIndex': 385,
106
+ 'raw': {
107
+ 'data': '0x0000000000000000000000000000000000000000000001b58c2186829983fca9',
108
+ 'topics': [
109
+ '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
110
+ '0x000000000000000000000000ea57dc30959eb17c506e4da095fa9181f3e0ac6d',
111
+ '0x0000000000000000000000009ccf93089cb14f94baeb8822f8ceffd91bd71649',
112
+ ],
113
+ },
114
+ 'removed': false,
115
+ 'returnValues': {
116
+ '0': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
117
+ '1': '0x9cCf93089cb14F94BAeB8822F8CeFfd91Bd71649',
118
+ '2': '8071324659946094853289',
119
+ 'from': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
120
+ 'to': '0x9cCf93089cb14F94BAeB8822F8CeFfd91Bd71649',
121
+ 'value': '8071324659946094853289',
122
+ },
123
+ 'signature': '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
124
+ 'transactionHash': '0x95b28d8f71719c219e09b428e6ff781d717088784fbf63681446da13de6b0c4a',
125
+ 'transactionIndex': 187,
126
+ },
127
+ ],
128
+ [
129
+ (0, contractService_1.makeErc20Contract)(Web3_1, (0, tokens_1.getAssetInfo)('LUSD').address, enums_1.ChainId.Ethereum),
130
+ null,
131
+ 'Transfer',
132
+ {
133
+ fromBlock: 15166163,
134
+ toBlock: 15166163,
135
+ filter: {
136
+ from: '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
137
+ to: '0x9cCf93089cb14F94BAeB8822F8CeFfd91Bd71649',
138
+ }
139
+ },
140
+ ]
141
+ ],
142
+ [
143
+ [
144
+ {
145
+ 'address': '0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1',
146
+ 'blockHash': '0xacb0213af63b4c17c436f084a96d1ac385641a59a9a4cf014ae3337cbe545aa7',
147
+ 'blockNumber': 5353002,
148
+ 'event': 'Transfer',
149
+ 'id': 'log_f49645b8',
150
+ 'logIndex': 1,
151
+ 'raw': {
152
+ 'data': '0x000000000000000000000000000000000000000000000001158e460913d00000',
153
+ 'topics': [
154
+ '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
155
+ '0x000000000000000000000000ea57dc30959eb17c506e4da095fa9181f3e0ac6d',
156
+ '0x00000000000000000000000013a22f1bba428eaaf56960530ec11118da916c11',
157
+ ],
158
+ },
159
+ 'removed': false,
160
+ 'returnValues': {
161
+ '0': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
162
+ '1': '0x13A22f1bBa428eaAf56960530Ec11118DA916C11',
163
+ '2': '20000000000000000000',
164
+ 'from': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
165
+ 'to': '0x13A22f1bBa428eaAf56960530Ec11118DA916C11',
166
+ 'value': '20000000000000000000',
167
+ },
168
+ 'signature': '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
169
+ 'transactionHash': '0x37c886a97c938747299c0f6b3e4591304bdd47a938df7c8146454d6fee5a6501',
170
+ 'transactionIndex': 0,
171
+ },
172
+ ],
173
+ [
174
+ (0, contractService_1.makeErc20Contract)(Web3_10, (0, tokens_1.getAssetInfo)('DAI', enums_1.ChainId.Optimism).address, enums_1.ChainId.Optimism),
175
+ null,
176
+ 'Transfer',
177
+ {
178
+ fromBlock: 5353002,
179
+ toBlock: 5353002,
180
+ filter: {
181
+ from: '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
182
+ to: '0x13A22f1bBa428eaAf56960530Ec11118DA916C11',
183
+ }
184
+ },
185
+ ]
186
+ ],
187
+ [
188
+ [
189
+ {
190
+ 'address': '0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1',
191
+ 'blockHash': '0xacb0213af63b4c17c436f084a96d1ac385641a59a9a4cf014ae3337cbe545aa7',
192
+ 'blockNumber': 5353002,
193
+ 'event': 'Transfer',
194
+ 'id': 'log_f49645b8',
195
+ 'logIndex': 1,
196
+ 'raw': {
197
+ 'data': '0x000000000000000000000000000000000000000000000001158e460913d00000',
198
+ 'topics': [
199
+ '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
200
+ '0x000000000000000000000000ea57dc30959eb17c506e4da095fa9181f3e0ac6d',
201
+ '0x00000000000000000000000013a22f1bba428eaaf56960530ec11118da916c11',
202
+ ],
203
+ },
204
+ 'removed': false,
205
+ 'returnValues': {
206
+ '0': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
207
+ '1': '0x13A22f1bBa428eaAf56960530Ec11118DA916C11',
208
+ '2': '20000000000000000000',
209
+ 'from': '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
210
+ 'to': '0x13A22f1bBa428eaAf56960530Ec11118DA916C11',
211
+ 'value': '20000000000000000000',
212
+ },
213
+ 'signature': '0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
214
+ 'transactionHash': '0x37c886a97c938747299c0f6b3e4591304bdd47a938df7c8146454d6fee5a6501',
215
+ 'transactionIndex': 0,
216
+ },
217
+ ],
218
+ [
219
+ (0, contractService_1.makeErc20Contract)(Web3_10, (0, tokens_1.getAssetInfo)('DAI', enums_1.ChainId.Arbitrum).address, enums_1.ChainId.Arbitrum),
220
+ null,
221
+ 'Transfer',
222
+ {
223
+ fromBlock: 5353002,
224
+ toBlock: 5353002,
225
+ filter: {
226
+ from: '0xEA57Dc30959eb17c506E4dA095fa9181f3E0Ac6D',
227
+ to: '0x13a22f1bba428eaaf56960530ec11118da916c11',
228
+ }
229
+ },
230
+ ]
231
+ ],
232
+ ];
233
+ examples.forEach(([expected, actual]) => {
234
+ it(`Given ${actual} should return expected value: ${JSON.stringify(expected)}`, () => __awaiter(void 0, void 0, void 0, function* () {
235
+ const data = yield (0, ethereumService_1.getEventsFromContract)(...actual);
236
+ console.log(data);
237
+ (0, chai_1.expect)(yield (0, ethereumService_1.getEventsFromContract)(...actual)).to.eql(expected);
238
+ }));
239
+ });
240
+ });
241
+ });
@@ -458,6 +458,19 @@ function parseLiquitySavingsLiqProtection(position, parseData) {
458
458
  };
459
459
  return _position;
460
460
  }
461
+ function parseDebtInFrontRepay(position, parseData) {
462
+ const _position = (0, lodash_1.cloneDeep)(position);
463
+ const { subStruct } = parseData.subscriptionEventData;
464
+ const triggerData = triggerService.liquityDebtInFrontWithLimitTrigger.decode(subStruct.triggerData);
465
+ const subData = subDataService.liquityDebtInFrontRepaySubData.decode(subStruct.subData);
466
+ _position.strategyData.decoded.triggerData = triggerData;
467
+ _position.strategyData.decoded.subData = subData;
468
+ _position.specific = {
469
+ debtInFrontMin: triggerData.debtInFrontMin,
470
+ targetRepayRatioIncrease: subData.targetRatioIncrease,
471
+ };
472
+ return _position;
473
+ }
461
474
  const parsingMethodsMapping = {
462
475
  [enums_1.ProtocolIdentifiers.StrategiesAutomation.MakerDAO]: {
463
476
  [enums_1.Strategies.Identifiers.SavingsLiqProtection]: parseMakerSavingsLiqProtection,
@@ -476,6 +489,7 @@ const parsingMethodsMapping = {
476
489
  [enums_1.Strategies.Identifiers.Boost]: parseLiquityLeverageManagement,
477
490
  [enums_1.Strategies.Identifiers.SavingsDsrPayback]: parseLiquitySavingsLiqProtection,
478
491
  [enums_1.Strategies.Identifiers.SavingsDsrSupply]: parseLiquitySavingsLiqProtection,
492
+ [enums_1.Strategies.Identifiers.DebtInFrontRepay]: parseDebtInFrontRepay,
479
493
  },
480
494
  [enums_1.ProtocolIdentifiers.StrategiesAutomation.AaveV2]: {
481
495
  [enums_1.Strategies.Identifiers.Repay]: parseAaveV2LeverageManagement,
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,108 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const chai_1 = require("chai");
13
+ const enums_1 = require("../types/enums");
14
+ const strategiesService_1 = require("./strategiesService");
15
+ describe('Feature: strategiesService.ts', () => {
16
+ describe('When testing strategiesService.parseStrategiesAutomatedPosition', () => __awaiter(void 0, void 0, void 0, function* () {
17
+ // TODO: we should probably write this for every strategy?
18
+ const examples = [
19
+ [
20
+ {
21
+ isEnabled: true,
22
+ chainId: 1,
23
+ subHash: '0xafa4d200be62f171b57b1ae0f4e8348d1ac3f6d0812ad6da74a2adae8037dde1',
24
+ blockNumber: 18015756,
25
+ subId: 379,
26
+ owner: '0x9cB7E19861665366011899d74E75d4F2A419aEeD',
27
+ protocol: {
28
+ id: enums_1.ProtocolIdentifiers.StrategiesAutomation.AaveV3,
29
+ name: 'Aave',
30
+ slug: 'aave',
31
+ version: 'V3',
32
+ fullName: 'Aave V3'
33
+ },
34
+ strategy: {
35
+ isBundle: true,
36
+ strategyOrBundleId: 8,
37
+ strategyId: enums_1.Strategies.IdOverrides.LeverageManagement,
38
+ protocol: {
39
+ id: enums_1.ProtocolIdentifiers.StrategiesAutomation.AaveV3,
40
+ name: 'Aave',
41
+ slug: 'aave',
42
+ version: 'V3',
43
+ fullName: 'Aave V3'
44
+ }
45
+ },
46
+ strategyData: {
47
+ encoded: {
48
+ triggerData: [
49
+ '0x0000000000000000000000009cb7e19861665366011899d74e75d4f2a419aeed0000000000000000000000002f39d218133afab8f2b819b1066c7e434ad94e9e00000000000000000000000000000000000000000000000019ac8532c27900000000000000000000000000000000000000000000000000000000000000000001',
50
+ ],
51
+ subData: [
52
+ '0x0000000000000000000000000000000000000000000000001bc16d674ec80000',
53
+ '0x0000000000000000000000000000000000000000000000000000000000000001',
54
+ '0x0000000000000000000000000000000000000000000000000000000000000001',
55
+ '0x0000000000000000000000000000000000000000000000000000000000000000'
56
+ ]
57
+ },
58
+ decoded: {
59
+ triggerData: {
60
+ owner: '0x9cB7E19861665366011899d74E75d4F2A419aEeD',
61
+ market: '0x2f39d218133AFaB8F2B819B1066c7E434Ad94E9e',
62
+ ratio: 185,
63
+ ratioState: 1
64
+ },
65
+ subData: { targetRatio: 200 }
66
+ }
67
+ },
68
+ specific: {
69
+ triggerRepayRatio: 185,
70
+ targetRepayRatio: 200,
71
+ repayEnabled: true,
72
+ subId1: 379,
73
+ mergeWithSameId: true
74
+ }
75
+ },
76
+ {
77
+ chainId: 1,
78
+ blockNumber: 18015756,
79
+ subscriptionEventData: {
80
+ subId: '379',
81
+ proxy: '0x9cB7E19861665366011899d74E75d4F2A419aEeD',
82
+ subHash: '0xafa4d200be62f171b57b1ae0f4e8348d1ac3f6d0812ad6da74a2adae8037dde1',
83
+ // @ts-ignore
84
+ subStruct: {
85
+ strategyOrBundleId: '8',
86
+ isBundle: true,
87
+ triggerData: ['0x0000000000000000000000009cb7e19861665366011899d74e75d4f2a419aeed0000000000000000000000002f39d218133afab8f2b819b1066c7e434ad94e9e00000000000000000000000000000000000000000000000019ac8532c27900000000000000000000000000000000000000000000000000000000000000000001'],
88
+ subData: [
89
+ '0x0000000000000000000000000000000000000000000000001bc16d674ec80000', '0x0000000000000000000000000000000000000000000000000000000000000001',
90
+ '0x0000000000000000000000000000000000000000000000000000000000000001', '0x0000000000000000000000000000000000000000000000000000000000000000',
91
+ ],
92
+ }
93
+ },
94
+ strategiesSubsData: {
95
+ userProxy: '0x9cb7e19861665366011899d74e75d4f2a419aeed',
96
+ isEnabled: true,
97
+ strategySubHash: '0xafa4d200be62f171b57b1ae0f4e8348d1ac3f6d0812ad6da74a2adae8037dde1'
98
+ }
99
+ },
100
+ ],
101
+ ];
102
+ examples.forEach(([expected, actual]) => {
103
+ it(`Given ${JSON.stringify(actual)} should return expected value: ${JSON.stringify(expected)}`, () => __awaiter(void 0, void 0, void 0, function* () {
104
+ (0, chai_1.expect)((0, strategiesService_1.parseStrategiesAutomatedPosition)(actual)).to.eql(expected);
105
+ }));
106
+ });
107
+ }));
108
+ });
@@ -1,7 +1,8 @@
1
+ import type { OrderType } from '../types/enums';
1
2
  import { Bundles, ChainId, RatioState, Strategies } from '../types/enums';
2
3
  import type { EthereumAddress, StrategyOrBundleIds } from '../types';
3
4
  export declare const makerEncode: {
4
- repayFromSavings(bundleId: StrategyOrBundleIds, vaultId: number, triggerRepayRatio: number, targetRepayRatio: number, isBundle?: boolean, chainId?: ChainId, daiAddr?: EthereumAddress, mcdCdpManagerAddr?: EthereumAddress): (boolean | string[])[];
5
+ repayFromSavings(bundleId: StrategyOrBundleIds, vaultId: number, triggerRepayRatio: number, targetRepayRatio: number, isBundle?: boolean, chainId?: ChainId, daiAddr?: EthereumAddress, mcdCdpManagerAddr?: EthereumAddress): (boolean | string[] | Strategies.MainnetIds | Strategies.OptimismIds | Strategies.ArbitrumIds | Bundles.MainnetIds | Bundles.OptimismIds | Bundles.ArbitrumIds)[];
5
6
  closeOnPrice(vaultId: number, ratioState: RatioState, price: string, closeToAssetAddr: EthereumAddress, chainlinkCollAddress: EthereumAddress, chainId?: ChainId, daiAddr?: EthereumAddress, mcdCdpManagerAddr?: EthereumAddress): (boolean | string[] | Strategies.MainnetIds)[];
6
7
  trailingStop(vaultId: number, triggerPercentage: number, closeToAssetAddr: EthereumAddress, chainlinkCollAddress: EthereumAddress, roundId: number, chainId?: ChainId, daiAddr?: EthereumAddress, mcdCdpManagerAddr?: EthereumAddress): (boolean | string[] | Strategies.MainnetIds)[];
7
8
  leverageManagement(vaultId: number, triggerRepayRatio: string, triggerBoostRatio: string, targetBoostRatio: string, targetRepayRatio: string, boostEnabled: boolean): (string | number | boolean)[];
@@ -13,6 +14,7 @@ export declare const liquityEncode: {
13
14
  leverageManagement(triggerRepayRatio: string, triggerBoostRatio: string, targetBoostRatio: string, targetRepayRatio: string, boostEnabled: boolean): (string | boolean)[];
14
15
  dsrPayback(proxyAddress: EthereumAddress, triggerRatio: number, targetRatio: number): (boolean | string[] | Strategies.MainnetIds)[];
15
16
  dsrSupply(proxyAddress: EthereumAddress, triggerRatio: number, targetRatio: number): (boolean | string[] | Strategies.MainnetIds)[];
17
+ debtInFrontRepay(proxyAddress: EthereumAddress, debtInFrontMin: string, targetRatioIncrease: number): (boolean | string[] | Strategies.MainnetIds)[];
16
18
  };
17
19
  export declare const chickenBondsEncode: {
18
20
  rebond(bondId: number): string[];
@@ -56,8 +58,8 @@ export declare const morphoAaveV2Encode: {
56
58
  leverageManagement(triggerRepayRatio: number, triggerBoostRatio: number, targetBoostRatio: number, targetRepayRatio: number, boostEnabled: boolean): string[];
57
59
  };
58
60
  export declare const exchangeEncode: {
59
- dca(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, timestamp: number, interval: number, network: number): (boolean | string[] | Strategies.MainnetIds | Strategies.OptimismIds | Strategies.ArbitrumIds)[];
60
- limitOrder(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string, orderType: number): string[];
61
+ dca(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, timestamp: number, interval: number, network: ChainId): (boolean | string[] | Strategies.MainnetIds | Strategies.OptimismIds | Strategies.ArbitrumIds)[];
62
+ limitOrder(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType): string[];
61
63
  };
62
64
  export declare const sparkEncode: {
63
65
  leverageManagement(triggerRepayRatio: number, triggerBoostRatio: number, targetBoostRatio: number, targetRepayRatio: number, boostEnabled: boolean): string;
@@ -30,6 +30,7 @@ exports.sparkEncode = exports.exchangeEncode = exports.morphoAaveV2Encode = expo
30
30
  const decimal_js_1 = __importDefault(require("decimal.js"));
31
31
  const tokens_1 = require("@defisaver/tokens");
32
32
  const enums_1 = require("../types/enums");
33
+ const constants_1 = require("../constants");
33
34
  const subDataService = __importStar(require("./subDataService"));
34
35
  const triggerService = __importStar(require("./triggerService"));
35
36
  const utils_1 = require("./utils");
@@ -120,6 +121,14 @@ exports.liquityEncode = {
120
121
  const isBundle = false;
121
122
  return [strategyOrBundleId, isBundle, triggerData, subData];
122
123
  },
124
+ debtInFrontRepay(proxyAddress, debtInFrontMin, targetRatioIncrease) {
125
+ (0, utils_1.requireAddress)(proxyAddress);
126
+ const subData = subDataService.liquityDebtInFrontRepaySubData.encode(targetRatioIncrease);
127
+ const triggerData = triggerService.liquityDebtInFrontWithLimitTrigger.encode(proxyAddress, debtInFrontMin);
128
+ const strategyOrBundleId = enums_1.Strategies.MainnetIds.LIQUITY_DEBT_IN_FRONT_REPAY;
129
+ const isBundle = false;
130
+ return [strategyOrBundleId, isBundle, triggerData, subData];
131
+ },
123
132
  };
124
133
  exports.chickenBondsEncode = {
125
134
  rebond(bondId) {
@@ -180,12 +189,7 @@ exports.exchangeEncode = {
180
189
  (0, utils_1.requireAddresses)([fromToken, toToken]);
181
190
  const subData = subDataService.exchangeDcaSubData.encode(fromToken, toToken, amount, interval);
182
191
  const triggerData = triggerService.exchangeTimestampTrigger.encode(timestamp, interval);
183
- const selectedNetwork = network === 1
184
- ? 'MainnetIds'
185
- : network === 10
186
- ? 'OptimismIds'
187
- : 'ArbitrumIds';
188
- const strategyId = enums_1.Strategies[selectedNetwork].EXCHANGE_DCA;
192
+ const strategyId = constants_1.STRATEGY_IDS[network].EXCHANGE_DCA;
189
193
  return [strategyId, false, triggerData, subData];
190
194
  },
191
195
  limitOrder(fromToken, toToken, amount, targetPrice, goodUntil, orderType) {
@@ -0,0 +1 @@
1
+ export {};