@instadapp/interop-x 0.0.0-dev.c696e38 → 0.0.0-dev.cdc0510

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 (106) hide show
  1. package/dist/package.json +9 -2
  2. package/dist/src/abi/aaveV2Resolver.json +832 -0
  3. package/dist/src/abi/aaveV3Resolver.json +628 -0
  4. package/dist/src/abi/balanceResolver.json +211 -0
  5. package/dist/src/abi/index.js +8 -0
  6. package/dist/src/abi/instList.json +232 -0
  7. package/dist/src/api/index.js +7 -0
  8. package/dist/src/constants/addresses.js +9 -1
  9. package/dist/src/constants/capPerChain.js +8 -0
  10. package/dist/src/constants/index.js +2 -0
  11. package/dist/src/constants/tokens.js +44 -44
  12. package/dist/src/constants/wrappedNativeToken.js +8 -0
  13. package/dist/src/crons/index.js +3 -0
  14. package/dist/src/crons/prices.js +16 -0
  15. package/dist/src/db/models/transaction.js +4 -0
  16. package/dist/src/errors/index.js +30 -0
  17. package/dist/src/gnosis/actions/aaveV2/source.js +2 -1
  18. package/dist/src/gnosis/actions/aaveV2/target.js +5 -3
  19. package/dist/src/gnosis/actions/aaveV3/index.js +11 -0
  20. package/dist/src/gnosis/actions/aaveV3/source.js +74 -0
  21. package/dist/src/gnosis/actions/aaveV3/target.js +87 -0
  22. package/dist/src/gnosis/actions/index.js +2 -0
  23. package/dist/src/index.js +2 -1
  24. package/dist/src/providers/index.js +17 -0
  25. package/dist/src/providers/retry-provider.js +45 -0
  26. package/dist/src/services/Prices.js +74 -0
  27. package/dist/src/services/index.js +8 -0
  28. package/dist/src/tasks/InteropX/{ProcessSubmitSubmitEvents.js → ProcessSubmitEvents.js} +106 -14
  29. package/dist/src/tasks/InteropX/ProcessValidateEvents.js +30 -10
  30. package/dist/src/tasks/InteropX/SyncLogExecuteEvents.js +113 -0
  31. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +2 -1
  32. package/dist/src/tasks/InteropX/SyncLogValidateEvents.js +5 -4
  33. package/dist/src/tasks/index.js +7 -5
  34. package/dist/src/typechain/AaveV2Resolver.js +2 -0
  35. package/dist/src/typechain/AaveV3Resolver.js +2 -0
  36. package/dist/src/typechain/BalanceResolver.js +2 -0
  37. package/dist/src/typechain/InstList.js +2 -0
  38. package/dist/src/typechain/factories/AaveV2Resolver__factory.js +1191 -0
  39. package/dist/src/typechain/factories/AaveV3Resolver__factory.js +887 -0
  40. package/dist/src/typechain/factories/BalanceResolver__factory.js +228 -0
  41. package/dist/src/typechain/factories/InstList__factory.js +249 -0
  42. package/dist/src/typechain/factories/index.js +9 -1
  43. package/dist/src/typechain/index.js +9 -1
  44. package/dist/src/utils/async.js +18 -0
  45. package/dist/src/utils/dsa.js +24 -0
  46. package/dist/src/utils/formatting.js +67 -0
  47. package/dist/src/utils/gnosis.js +87 -0
  48. package/dist/src/utils/http.js +10 -0
  49. package/dist/src/utils/index.js +22 -220
  50. package/dist/src/utils/interop.js +16 -0
  51. package/dist/src/utils/tokens.js +22 -0
  52. package/dist/src/utils/validate.js +111 -0
  53. package/dist/src/utils/web3.js +93 -0
  54. package/package.json +9 -2
  55. package/src/abi/aaveV2Resolver.json +832 -0
  56. package/src/abi/aaveV3Resolver.json +628 -0
  57. package/src/abi/balanceResolver.json +211 -0
  58. package/src/abi/index.ts +8 -0
  59. package/src/abi/instList.json +232 -0
  60. package/src/api/index.ts +8 -0
  61. package/src/constants/addresses.ts +20 -2
  62. package/src/constants/capPerChain.ts +5 -0
  63. package/src/constants/index.ts +2 -0
  64. package/src/constants/tokens.ts +44 -44
  65. package/src/constants/wrappedNativeToken.ts +5 -0
  66. package/src/crons/index.ts +1 -0
  67. package/src/crons/prices.ts +12 -0
  68. package/src/db/models/transaction.ts +21 -0
  69. package/src/errors/index.ts +26 -0
  70. package/src/gnosis/actions/aaveV2/source.ts +2 -1
  71. package/src/gnosis/actions/aaveV2/target.ts +13 -3
  72. package/src/gnosis/actions/aaveV3/index.ts +9 -0
  73. package/src/gnosis/actions/aaveV3/source.ts +119 -0
  74. package/src/gnosis/actions/aaveV3/target.ts +142 -0
  75. package/src/gnosis/actions/index.ts +2 -0
  76. package/src/index.ts +1 -0
  77. package/src/providers/index.ts +1 -0
  78. package/src/providers/retry-provider.ts +51 -0
  79. package/src/services/Prices.ts +89 -0
  80. package/src/services/index.ts +1 -0
  81. package/src/tasks/InteropX/{ProcessSubmitSubmitEvents.ts → ProcessSubmitEvents.ts} +133 -20
  82. package/src/tasks/InteropX/ProcessValidateEvents.ts +42 -19
  83. package/src/tasks/InteropX/SyncLogExecuteEvents.ts +161 -0
  84. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +5 -6
  85. package/src/tasks/InteropX/SyncLogValidateEvents.ts +8 -9
  86. package/src/tasks/index.ts +8 -5
  87. package/src/typechain/AaveV2Resolver.ts +1017 -0
  88. package/src/typechain/AaveV3Resolver.ts +935 -0
  89. package/src/typechain/BalanceResolver.ts +266 -0
  90. package/src/typechain/InstList.ts +402 -0
  91. package/src/typechain/factories/AaveV2Resolver__factory.ts +1198 -0
  92. package/src/typechain/factories/AaveV3Resolver__factory.ts +894 -0
  93. package/src/typechain/factories/BalanceResolver__factory.ts +235 -0
  94. package/src/typechain/factories/InstList__factory.ts +253 -0
  95. package/src/typechain/factories/index.ts +4 -0
  96. package/src/typechain/index.ts +8 -0
  97. package/src/utils/async.ts +22 -0
  98. package/src/utils/dsa.ts +30 -0
  99. package/src/utils/formatting.ts +68 -0
  100. package/src/utils/gnosis.ts +166 -0
  101. package/src/utils/http.ts +6 -0
  102. package/src/utils/index.ts +9 -365
  103. package/src/utils/interop.ts +28 -0
  104. package/src/utils/tokens.ts +21 -0
  105. package/src/utils/validate.ts +174 -0
  106. package/src/utils/web3.ts +132 -0
@@ -16,6 +16,8 @@ const sequelize_1 = require("sequelize");
16
16
  const gnosis_1 = require("@/gnosis");
17
17
  const net_1 = require("@/net");
18
18
  const waait_1 = __importDefault(require("waait"));
19
+ const errors_1 = require("@/errors");
20
+ const providers_1 = require("@/providers");
19
21
  class ProcessValidateEvents extends BaseTask_1.BaseTask {
20
22
  constructor({ chainId }) {
21
23
  super({
@@ -57,7 +59,7 @@ class ProcessValidateEvents extends BaseTask_1.BaseTask {
57
59
  transaction.targetStatus = "proccessing";
58
60
  await transaction.save();
59
61
  const { sourceChainId, targetChainId } = transaction.validateEvent;
60
- const targetProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(targetChainId));
62
+ const targetProvider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(targetChainId));
61
63
  const targetWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, targetProvider);
62
64
  const targetGnosisContract = (0, utils_1.getContract)(constants_1.addresses[targetChainId].gnosisSafe, abi_1.default.gnosisSafe, targetWallet);
63
65
  const ownersThreshold = await targetGnosisContract.getThreshold();
@@ -68,7 +70,7 @@ class ProcessValidateEvents extends BaseTask_1.BaseTask {
68
70
  ({ data, logs } = await (0, gnosis_1.buildGnosisAction)(transaction, "target"));
69
71
  }
70
72
  catch (error) {
71
- if (error instanceof utils_1.LiquidityError) {
73
+ if (error instanceof errors_1.LiquidityError) {
72
74
  await transaction.save();
73
75
  transaction.targetDelayUntil = new Date(Date.now() + 60 * 5 * 1000);
74
76
  transaction.targetStatus = "pending";
@@ -97,14 +99,18 @@ class ProcessValidateEvents extends BaseTask_1.BaseTask {
97
99
  to: constants_1.addresses[transaction.targetChainId].multisend,
98
100
  value: "0",
99
101
  }, targetGnosisContract);
100
- const owners = await targetGnosisContract
101
- .getOwners()
102
- .then((owners) => owners.map((owner) => owner.toLowerCase()));
103
- const ownerPeerIds = net_1.peerPool.activePeers
104
- .filter((peer) => owners.includes(peer.publicAddress.toLowerCase()))
105
- .map((peer) => peer.id);
102
+ const ownerPeerIds = await (0, utils_1.getGnosisOwnerPeerIds)({
103
+ gnosisContract: targetGnosisContract,
104
+ });
106
105
  console.log(`Collecting signatures for execution ${transaction.transactionHash}`);
107
106
  console.log(ownerPeerIds);
107
+ const message = (0, utils_1.generateGnosisSignatureMessage)({
108
+ to: constants_1.addresses[data.chainId].multisend,
109
+ data,
110
+ chainId: this.chainId,
111
+ safeTxGas: gnosisTx.safeTxGas,
112
+ nonce: gnosisTx.safeNonce,
113
+ });
108
114
  const signatures = await net_1.protocol.requestSignatures({
109
115
  type: "target",
110
116
  transactionHash: transaction.transactionHash,
@@ -112,7 +118,21 @@ class ProcessValidateEvents extends BaseTask_1.BaseTask {
112
118
  safeNonce: gnosisTx.nonce,
113
119
  chainId: targetChainId,
114
120
  }, ownerPeerIds);
115
- const validSignatures = signatures.filter((s) => !!s.data && s.data !== "0x");
121
+ const validSignatures = signatures
122
+ .filter((s) => !!s.data && s.data !== "0x")
123
+ .filter((s) => {
124
+ try {
125
+ const address = (0, utils_1.getGnosisSignatureAddress)({
126
+ message,
127
+ signature: s.data,
128
+ chainId: this.chainId,
129
+ });
130
+ return (address === null || address === void 0 ? void 0 : address.toLowerCase()) === s.signer.toLowerCase();
131
+ }
132
+ catch (error) {
133
+ return false;
134
+ }
135
+ });
116
136
  console.log({
117
137
  signatures,
118
138
  validSignatures,
@@ -176,7 +196,7 @@ class ProcessValidateEvents extends BaseTask_1.BaseTask {
176
196
  }
177
197
  async start() {
178
198
  this.blockConfirmationsCount = constants_1.blockConfirmations[this.chainId] + 1;
179
- this.sourceProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
199
+ this.sourceProvider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
180
200
  await super.start();
181
201
  }
182
202
  }
@@ -0,0 +1,113 @@
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 BaseTask_1 = require("../BaseTask");
7
+ const logger_1 = __importDefault(require("@/logger"));
8
+ const ethers_1 = require("ethers");
9
+ const abi_1 = __importDefault(require("@/abi"));
10
+ const db_1 = require("@/db");
11
+ const utils_1 = require("@/utils");
12
+ const constants_1 = require("@/constants");
13
+ const config_1 = __importDefault(require("@/config"));
14
+ const sequelize_1 = require("sequelize");
15
+ const providers_1 = require("@/providers");
16
+ class SyncLogExecuteEvents extends BaseTask_1.BaseTask {
17
+ constructor({ targetChainId }) {
18
+ super({
19
+ logger: new logger_1.default("InteropX::SyncLogExecuteEvents"),
20
+ });
21
+ this.targetChainId = targetChainId;
22
+ }
23
+ async pollHandler() {
24
+ const currentBlock = await this.provider.getBlockNumber();
25
+ const events = await this.contract.queryFilter(this.contract.filters.LogExecute(), currentBlock - 2000, currentBlock);
26
+ let processedEvents = 0;
27
+ for (const event of events) {
28
+ try {
29
+ if (!event.args) {
30
+ continue;
31
+ }
32
+ const { sourceSpells, targetSpells, position, actionId, actionIdHash, sourceSender, sourceDsaId, targetDsaId, sourceChainId, targetChainId, vnonce, metadata, } = event.args;
33
+ const uniqueIdentifier = {
34
+ actionId,
35
+ vnonce: vnonce.toString(),
36
+ sourceSender: sourceSender.toString(),
37
+ sourceChainId: sourceChainId.toNumber(),
38
+ targetChainId: targetChainId.toNumber(),
39
+ sourceDsaId: sourceDsaId.toString(),
40
+ targetDsaId: targetDsaId.toString(),
41
+ };
42
+ let transactionHash = (0, utils_1.generateInteropTransactionHash)(uniqueIdentifier);
43
+ const transaction = await db_1.Transaction.findOne({
44
+ where: {
45
+ transactionHash,
46
+ executeEvent: { [sequelize_1.Op.eq]: null },
47
+ },
48
+ });
49
+ if (!transaction) {
50
+ continue;
51
+ }
52
+ if (transaction.targetStatus != "success") {
53
+ transaction.targetStatus = "success";
54
+ }
55
+ if (transaction.status != "success") {
56
+ transaction.status = "success";
57
+ }
58
+ if (!transaction.targetCreatedAt) {
59
+ transaction.targetCreatedAt = new Date();
60
+ }
61
+ transaction.targetTransactionHash = event.transactionHash;
62
+ transaction.targetBlockNumber = event.blockNumber;
63
+ transaction.targetLogs = [];
64
+ transaction.executeEvent = {
65
+ actionId,
66
+ actionIdHashHash: actionIdHash,
67
+ actionIdHash,
68
+ vnonce: vnonce.toString(),
69
+ sourceSpells: sourceSpells.map(({ connector, data }) => ({
70
+ connector,
71
+ data,
72
+ })),
73
+ targetSpells: targetSpells.map(({ connector, data }) => ({
74
+ connector,
75
+ data,
76
+ })),
77
+ position: {
78
+ withdraw: position.withdraw.map((v) => ({
79
+ sourceToken: v.sourceToken,
80
+ targetToken: v.targetToken,
81
+ amount: v.amount.toString(),
82
+ })),
83
+ supply: position.supply.map((v) => ({
84
+ sourceToken: v.sourceToken,
85
+ targetToken: v.targetToken,
86
+ amount: v.amount.toString(),
87
+ })),
88
+ },
89
+ sourceChainId: sourceChainId.toNumber(),
90
+ targetChainId: targetChainId.toNumber(),
91
+ sourceSender,
92
+ sourceDsaId: sourceDsaId.toString(),
93
+ targetDsaId: targetDsaId.toString(),
94
+ metadata,
95
+ };
96
+ await transaction.save();
97
+ this.logger.info(`New InteropX tranaction: ${transactionHash} `);
98
+ }
99
+ catch (error) {
100
+ this.logger.error(error);
101
+ }
102
+ }
103
+ if (processedEvents > 0)
104
+ this.logger.info(`${processedEvents} events processed`);
105
+ }
106
+ async start() {
107
+ this.contractAddress = constants_1.addresses[this.targetChainId].interopX;
108
+ this.provider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(this.targetChainId));
109
+ this.contract = (0, utils_1.getContract)(this.contractAddress, abi_1.default.interopX, new ethers_1.ethers.Wallet(config_1.default.privateKey, this.provider));
110
+ await super.start();
111
+ }
112
+ }
113
+ exports.default = SyncLogExecuteEvents;
@@ -11,6 +11,7 @@ const db_1 = require("@/db");
11
11
  const utils_1 = require("@/utils");
12
12
  const constants_1 = require("@/constants");
13
13
  const config_1 = __importDefault(require("@/config"));
14
+ const providers_1 = require("@/providers");
14
15
  class SyncLogSubmitEvents extends BaseTask_1.BaseTask {
15
16
  constructor({ chainId }) {
16
17
  super({
@@ -79,7 +80,7 @@ class SyncLogSubmitEvents extends BaseTask_1.BaseTask {
79
80
  }
80
81
  async start() {
81
82
  this.contractAddress = constants_1.addresses[this.chainId].interopX;
82
- this.provider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
83
+ this.provider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
83
84
  this.contract = (0, utils_1.getContract)(this.contractAddress, abi_1.default.interopX, new ethers_1.ethers.Wallet(config_1.default.privateKey, this.provider));
84
85
  await super.start();
85
86
  }
@@ -12,6 +12,7 @@ const utils_1 = require("@/utils");
12
12
  const constants_1 = require("@/constants");
13
13
  const config_1 = __importDefault(require("@/config"));
14
14
  const sequelize_1 = require("sequelize");
15
+ const providers_1 = require("@/providers");
15
16
  class SyncLogValidateEvents extends BaseTask_1.BaseTask {
16
17
  constructor({ chainId }) {
17
18
  super({
@@ -57,7 +58,7 @@ class SyncLogValidateEvents extends BaseTask_1.BaseTask {
57
58
  transaction.sourceTransactionHash = event.transactionHash;
58
59
  transaction.sourceBlockNumber = event.blockNumber;
59
60
  transaction.sourceLogs = [];
60
- (transaction.validateEvent = {
61
+ transaction.validateEvent = {
61
62
  actionId,
62
63
  actionIdHashHash: actionIdHash,
63
64
  actionIdHash,
@@ -84,8 +85,8 @@ class SyncLogValidateEvents extends BaseTask_1.BaseTask {
84
85
  sourceDsaId: sourceDsaId.toString(),
85
86
  targetDsaId: targetDsaId.toString(),
86
87
  metadata,
87
- }),
88
- await transaction.save();
88
+ };
89
+ await transaction.save();
89
90
  this.logger.info(`New InteropX tranaction: ${transactionHash} `);
90
91
  }
91
92
  catch (error) {
@@ -97,7 +98,7 @@ class SyncLogValidateEvents extends BaseTask_1.BaseTask {
97
98
  }
98
99
  async start() {
99
100
  this.contractAddress = constants_1.addresses[this.chainId].interopX;
100
- this.provider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
101
+ this.provider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
101
102
  this.contract = (0, utils_1.getContract)(this.contractAddress, abi_1.default.interopX, new ethers_1.ethers.Wallet(config_1.default.privateKey, this.provider));
102
103
  await super.start();
103
104
  }
@@ -8,23 +8,25 @@ const waait_1 = __importDefault(require("waait"));
8
8
  const SyncTransactionStatusTask_1 = __importDefault(require("./Transactions/SyncTransactionStatusTask"));
9
9
  const AutoUpdateTask_1 = __importDefault(require("./AutoUpdateTask"));
10
10
  const SyncLogSubmitEvents_1 = __importDefault(require("./InteropX/SyncLogSubmitEvents"));
11
- const ProcessSubmitSubmitEvents_1 = __importDefault(require("./InteropX/ProcessSubmitSubmitEvents"));
11
+ const ProcessSubmitEvents_1 = __importDefault(require("./InteropX/ProcessSubmitEvents"));
12
12
  const SyncLogValidateEvents_1 = __importDefault(require("./InteropX/SyncLogValidateEvents"));
13
13
  const ProcessValidateEvents_1 = __importDefault(require("./InteropX/ProcessValidateEvents"));
14
+ const SyncLogExecuteEvents_1 = __importDefault(require("./InteropX/SyncLogExecuteEvents"));
14
15
  class Tasks {
15
16
  constructor() {
16
17
  this.tasks = [
17
- // new SyncTransactionStatusTask(),
18
18
  new AutoUpdateTask_1.default(),
19
19
  // InteropX
20
20
  new SyncLogSubmitEvents_1.default({ chainId: 137 }),
21
21
  new SyncLogSubmitEvents_1.default({ chainId: 43114 }),
22
- new ProcessSubmitSubmitEvents_1.default({ chainId: 137 }),
23
- new ProcessSubmitSubmitEvents_1.default({ chainId: 43114 }),
22
+ new ProcessSubmitEvents_1.default({ chainId: 137 }),
23
+ new ProcessSubmitEvents_1.default({ chainId: 43114 }),
24
24
  new SyncLogValidateEvents_1.default({ chainId: 137 }),
25
25
  new SyncLogValidateEvents_1.default({ chainId: 43114 }),
26
26
  new ProcessValidateEvents_1.default({ chainId: 137 }),
27
27
  new ProcessValidateEvents_1.default({ chainId: 43114 }),
28
+ new SyncLogExecuteEvents_1.default({ targetChainId: 137 }),
29
+ new SyncLogExecuteEvents_1.default({ targetChainId: 43114 }),
28
30
  new SyncTransactionStatusTask_1.default(),
29
31
  ];
30
32
  }
@@ -32,7 +34,7 @@ class Tasks {
32
34
  for (const task of this.tasks) {
33
35
  try {
34
36
  task.start();
35
- await (0, waait_1.default)(1000);
37
+ await (0, waait_1.default)(300);
36
38
  }
37
39
  catch (error) {
38
40
  console.error(`Error starting task: ${task.constructor.name}`);
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });