@instadapp/interop-x 0.0.0-dev.5953f3d → 0.0.0-dev.5a90c8d

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 (92) hide show
  1. package/dist/package.json +8 -1
  2. package/dist/src/abi/aaveV2Resolver.json +832 -0
  3. package/dist/src/abi/balanceResolver.json +211 -0
  4. package/dist/src/abi/index.js +6 -0
  5. package/dist/src/abi/instList.json +232 -0
  6. package/dist/src/api/index.js +7 -0
  7. package/dist/src/constants/addresses.js +8 -2
  8. package/dist/src/constants/capPerChain.js +8 -0
  9. package/dist/src/constants/index.js +2 -0
  10. package/dist/src/constants/tokens.js +44 -44
  11. package/dist/src/constants/wrappedNativeToken.js +8 -0
  12. package/dist/src/crons/index.js +3 -0
  13. package/dist/src/crons/prices.js +16 -0
  14. package/dist/src/db/models/transaction.js +15 -7
  15. package/dist/src/errors/index.js +30 -0
  16. package/dist/src/gnosis/actions/aaveV2/source.js +17 -5
  17. package/dist/src/gnosis/actions/aaveV2/target.js +79 -0
  18. package/dist/src/index.js +2 -1
  19. package/dist/src/providers/index.js +17 -0
  20. package/dist/src/providers/retry-provider.js +45 -0
  21. package/dist/src/services/Prices.js +74 -0
  22. package/dist/src/services/index.js +8 -0
  23. package/dist/src/tasks/InteropX/{ProcessSubmitSubmitEvents.js → ProcessSubmitEvents.js} +84 -7
  24. package/dist/src/tasks/InteropX/ProcessValidateEvents.js +185 -0
  25. package/dist/src/tasks/InteropX/SyncLogExecuteEvents.js +113 -0
  26. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +3 -1
  27. package/dist/src/tasks/InteropX/SyncLogValidateEvents.js +106 -0
  28. package/dist/src/tasks/index.js +13 -5
  29. package/dist/src/typechain/AaveV2Resolver.js +2 -0
  30. package/dist/src/typechain/BalanceResolver.js +2 -0
  31. package/dist/src/typechain/InstList.js +2 -0
  32. package/dist/src/typechain/factories/AaveV2Resolver__factory.js +1191 -0
  33. package/dist/src/typechain/factories/BalanceResolver__factory.js +228 -0
  34. package/dist/src/typechain/factories/InstList__factory.js +249 -0
  35. package/dist/src/typechain/factories/index.js +7 -1
  36. package/dist/src/typechain/index.js +7 -1
  37. package/dist/src/utils/async.js +18 -0
  38. package/dist/src/utils/dsa.js +24 -0
  39. package/dist/src/utils/formatting.js +67 -0
  40. package/dist/src/utils/gnosis.js +62 -0
  41. package/dist/src/utils/http.js +10 -0
  42. package/dist/src/utils/index.js +22 -220
  43. package/dist/src/utils/interop.js +16 -0
  44. package/dist/src/utils/tokens.js +22 -0
  45. package/dist/src/utils/validate.js +111 -0
  46. package/dist/src/utils/web3.js +93 -0
  47. package/package.json +8 -1
  48. package/src/abi/aaveV2Resolver.json +832 -0
  49. package/src/abi/balanceResolver.json +211 -0
  50. package/src/abi/index.ts +6 -0
  51. package/src/abi/instList.json +232 -0
  52. package/src/api/index.ts +8 -0
  53. package/src/constants/addresses.ts +19 -3
  54. package/src/constants/capPerChain.ts +5 -0
  55. package/src/constants/index.ts +2 -0
  56. package/src/constants/tokens.ts +44 -44
  57. package/src/constants/wrappedNativeToken.ts +5 -0
  58. package/src/crons/index.ts +1 -0
  59. package/src/crons/prices.ts +12 -0
  60. package/src/db/models/transaction.ts +134 -80
  61. package/src/errors/index.ts +26 -0
  62. package/src/gnosis/actions/aaveV2/source.ts +21 -6
  63. package/src/gnosis/actions/aaveV2/target.ts +131 -2
  64. package/src/index.ts +1 -0
  65. package/src/providers/index.ts +1 -0
  66. package/src/providers/retry-provider.ts +51 -0
  67. package/src/services/Prices.ts +89 -0
  68. package/src/services/index.ts +1 -0
  69. package/src/tasks/InteropX/{ProcessSubmitSubmitEvents.ts → ProcessSubmitEvents.ts} +104 -11
  70. package/src/tasks/InteropX/ProcessValidateEvents.ts +272 -0
  71. package/src/tasks/InteropX/SyncLogExecuteEvents.ts +161 -0
  72. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +6 -6
  73. package/src/tasks/InteropX/SyncLogValidateEvents.ts +151 -0
  74. package/src/tasks/index.ts +16 -5
  75. package/src/typechain/AaveV2Resolver.ts +1017 -0
  76. package/src/typechain/BalanceResolver.ts +266 -0
  77. package/src/typechain/InstList.ts +402 -0
  78. package/src/typechain/factories/AaveV2Resolver__factory.ts +1198 -0
  79. package/src/typechain/factories/BalanceResolver__factory.ts +235 -0
  80. package/src/typechain/factories/InstList__factory.ts +253 -0
  81. package/src/typechain/factories/index.ts +3 -0
  82. package/src/typechain/index.ts +6 -0
  83. package/src/utils/async.ts +22 -0
  84. package/src/utils/dsa.ts +30 -0
  85. package/src/utils/formatting.ts +68 -0
  86. package/src/utils/gnosis.ts +123 -0
  87. package/src/utils/http.ts +6 -0
  88. package/src/utils/index.ts +9 -365
  89. package/src/utils/interop.ts +28 -0
  90. package/src/utils/tokens.ts +21 -0
  91. package/src/utils/validate.ts +174 -0
  92. package/src/utils/web3.ts +132 -0
@@ -10,7 +10,7 @@ Transaction.init({
10
10
  id: {
11
11
  type: sequelize_2.DataTypes.INTEGER,
12
12
  autoIncrement: true,
13
- primaryKey: true
13
+ primaryKey: true,
14
14
  },
15
15
  transactionHash: sequelize_2.DataTypes.STRING,
16
16
  actionId: sequelize_2.DataTypes.STRING,
@@ -26,7 +26,7 @@ Transaction.init({
26
26
  sourceBlockNumber: sequelize_2.DataTypes.NUMBER,
27
27
  sourceStatus: {
28
28
  type: sequelize_2.DataTypes.STRING,
29
- defaultValue: 'pending'
29
+ defaultValue: "pending",
30
30
  },
31
31
  sourceErrors: {
32
32
  type: sequelize_2.DataTypes.JSON,
@@ -38,7 +38,7 @@ Transaction.init({
38
38
  },
39
39
  sourceCreatedAt: {
40
40
  type: sequelize_2.DataTypes.DATE,
41
- defaultValue: Date.now()
41
+ defaultValue: Date.now(),
42
42
  },
43
43
  sourceDelayUntil: sequelize_2.DataTypes.STRING,
44
44
  targetChainId: sequelize_2.DataTypes.NUMBER,
@@ -47,7 +47,7 @@ Transaction.init({
47
47
  targetBlockNumber: sequelize_2.DataTypes.NUMBER,
48
48
  targetStatus: {
49
49
  type: sequelize_2.DataTypes.STRING,
50
- defaultValue: 'pending'
50
+ defaultValue: "pending",
51
51
  },
52
52
  targetErrors: {
53
53
  type: sequelize_2.DataTypes.JSON,
@@ -61,12 +61,20 @@ Transaction.init({
61
61
  targetDelayUntil: sequelize_2.DataTypes.DATE,
62
62
  submitEvent: {
63
63
  type: sequelize_2.DataTypes.JSON,
64
- allowNull: false
64
+ allowNull: false,
65
+ },
66
+ validateEvent: {
67
+ type: sequelize_2.DataTypes.JSON,
68
+ allowNull: true,
69
+ },
70
+ executeEvent: {
71
+ type: sequelize_2.DataTypes.JSON,
72
+ allowNull: true,
65
73
  },
66
74
  status: {
67
75
  type: sequelize_2.DataTypes.STRING,
68
- defaultValue: 'pending'
76
+ defaultValue: "pending",
69
77
  },
70
78
  createdAt: sequelize_2.DataTypes.DATE,
71
79
  updatedAt: sequelize_2.DataTypes.DATE,
72
- }, { sequelize: sequelize_1.sequelize, tableName: 'transactions' });
80
+ }, { sequelize: sequelize_1.sequelize, tableName: "transactions" });
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LowLiquidityError = exports.InvalidChaindIdError = exports.LiquidityError = exports.UnsupportedChaindIdError = void 0;
4
+ class UnsupportedChaindIdError extends Error {
5
+ constructor(chainId) {
6
+ super(`Unsupported chainId: ${chainId}`);
7
+ }
8
+ }
9
+ exports.UnsupportedChaindIdError = UnsupportedChaindIdError;
10
+ class LiquidityError extends Error {
11
+ constructor(message) {
12
+ super(message || "Not enough liquidity");
13
+ Object.setPrototypeOf(this, new.target.prototype);
14
+ }
15
+ }
16
+ exports.LiquidityError = LiquidityError;
17
+ class InvalidChaindIdError extends Error {
18
+ constructor(message) {
19
+ super(message || "Invalid chain id");
20
+ Object.setPrototypeOf(this, new.target.prototype);
21
+ }
22
+ }
23
+ exports.InvalidChaindIdError = InvalidChaindIdError;
24
+ class LowLiquidityError extends Error {
25
+ constructor(message) {
26
+ super(message || "Low liquidity");
27
+ Object.setPrototypeOf(this, new.target.prototype);
28
+ }
29
+ }
30
+ exports.LowLiquidityError = LowLiquidityError;
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const abi_1 = __importDefault(require("@/abi"));
7
7
  const config_1 = __importDefault(require("@/config"));
8
8
  const constants_1 = require("@/constants");
9
+ const providers_1 = require("@/providers");
9
10
  const utils_1 = require("@/utils");
10
11
  const ethers_1 = require("ethers");
11
12
  const ethers_multisend_1 = require("ethers-multisend");
@@ -13,8 +14,10 @@ async function default_1(transaction) {
13
14
  const transactions = [];
14
15
  const logs = [];
15
16
  const { position, actionId, actionIdHashHash, sourceSender, sourceDsaId, targetDsaId, sourceChainId, targetChainId, vnonce, metadata, } = transaction.submitEvent;
16
- const sourceChainProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(sourceChainId));
17
+ const sourceChainProvider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(sourceChainId));
17
18
  const sourceWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, sourceChainProvider);
19
+ const dsaAddress = constants_1.addresses[sourceChainId].dsaAddress;
20
+ const sourceUserAddress = Number(sourceDsaId) == 0 ? sourceSender : dsaAddress;
18
21
  const interopAddress = constants_1.addresses[sourceChainId].interopX;
19
22
  const contract = (0, utils_1.getContract)(interopAddress, abi_1.default.interopX, sourceWallet);
20
23
  const sourceSpells = [];
@@ -26,9 +29,18 @@ async function default_1(transaction) {
26
29
  args: [withdraw.sourceToken, withdraw.amount, "2", "0", "0"],
27
30
  };
28
31
  sourceSpells.push({
29
- connector: spellData.method,
32
+ connector: spellData.connector,
30
33
  data: (0, utils_1.encodeConnectorMethod)(spellData),
31
34
  });
35
+ let spellDataBasicWithdraw = {
36
+ connector: "BASIC-A",
37
+ method: "withdraw",
38
+ args: [withdraw.sourceToken, withdraw.amount, sourceUserAddress, "0", "0"],
39
+ };
40
+ commonSpells.push({
41
+ connector: spellDataBasicWithdraw.connector,
42
+ data: (0, utils_1.encodeConnectorMethod)(spellDataBasicWithdraw),
43
+ });
32
44
  }
33
45
  for (const supply of position.supply) {
34
46
  let spellDataWithdraw = {
@@ -37,16 +49,16 @@ async function default_1(transaction) {
37
49
  args: [supply.sourceToken, supply.amount, "0", "0"],
38
50
  };
39
51
  sourceSpells.push({
40
- connector: spellDataWithdraw.method,
52
+ connector: spellDataWithdraw.connector,
41
53
  data: (0, utils_1.encodeConnectorMethod)(spellDataWithdraw),
42
54
  });
43
55
  let spellDataBasicWithdraw = {
44
56
  connector: "BASIC-A",
45
57
  method: "withdraw",
46
- args: [supply.sourceToken, supply.amount, interopAddress, "0", "0"],
58
+ args: [supply.sourceToken, supply.amount, dsaAddress, "0", "0"],
47
59
  };
48
60
  sourceSpells.push({
49
- connector: spellDataBasicWithdraw.method,
61
+ connector: spellDataBasicWithdraw.connector,
50
62
  data: (0, utils_1.encodeConnectorMethod)(spellDataBasicWithdraw),
51
63
  });
52
64
  }
@@ -1,8 +1,87 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ const abi_1 = __importDefault(require("@/abi"));
7
+ const config_1 = __importDefault(require("@/config"));
8
+ const constants_1 = require("@/constants");
9
+ const providers_1 = require("@/providers");
10
+ const utils_1 = require("@/utils");
11
+ const ethers_1 = require("ethers");
12
+ const ethers_multisend_1 = require("ethers-multisend");
3
13
  async function default_1(transaction) {
4
14
  const transactions = [];
5
15
  const logs = [];
16
+ const { sourceSpells, position, actionId, sourceSender, sourceDsaId, targetDsaId, sourceChainId, targetChainId, vnonce, metadata, } = transaction.validateEvent;
17
+ const targetChainProvider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(targetChainId));
18
+ const targetWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, targetChainProvider);
19
+ const targetInstListContract = (0, utils_1.getContract)(constants_1.addresses[targetChainId].instList, abi_1.default.instList, targetChainProvider);
20
+ const targetDsaAddress = await targetInstListContract.accountAddr(targetDsaId);
21
+ const dsaAddress = constants_1.addresses[targetChainId].dsaAddress;
22
+ const interopAddress = constants_1.addresses[targetChainId].interopX;
23
+ const contract = (0, utils_1.getContract)(interopAddress, abi_1.default.interopX, targetWallet);
24
+ const targetSpells = [];
25
+ const commonSpells = [];
26
+ for (const supplyToken of position.supply) {
27
+ let spellData = {
28
+ connector: "AAVE-V2-A",
29
+ method: "deposit",
30
+ args: [supplyToken.targetToken, supplyToken.amount, "0", "0"],
31
+ };
32
+ targetSpells.push({
33
+ connector: spellData.connector,
34
+ data: (0, utils_1.encodeConnectorMethod)(spellData),
35
+ });
36
+ let spellDataBasicWithdraw = {
37
+ connector: "BASIC-A",
38
+ method: "withdraw",
39
+ args: [supplyToken.targetToken, supplyToken.amount, targetDsaAddress, "0", "0"],
40
+ };
41
+ commonSpells.push({
42
+ connector: spellDataBasicWithdraw.connector,
43
+ data: (0, utils_1.encodeConnectorMethod)(spellDataBasicWithdraw),
44
+ });
45
+ }
46
+ for (const withdrawToken of position.withdraw) {
47
+ let spellData = {
48
+ connector: "AAVE-V2-A",
49
+ method: "borrow",
50
+ args: [
51
+ withdrawToken.targetToken,
52
+ withdrawToken.amount,
53
+ "2",
54
+ "0",
55
+ "0",
56
+ ],
57
+ };
58
+ targetSpells.push({
59
+ connector: spellData.connector,
60
+ data: (0, utils_1.encodeConnectorMethod)(spellData),
61
+ });
62
+ let spellData2 = {
63
+ connector: "BASIC-A",
64
+ method: "withdraw",
65
+ args: [
66
+ withdrawToken.targetToken,
67
+ withdrawToken.amount,
68
+ dsaAddress,
69
+ "0",
70
+ "0",
71
+ ],
72
+ };
73
+ targetSpells.push({
74
+ connector: spellData.connector,
75
+ data: (0, utils_1.encodeConnectorMethod)(spellData2),
76
+ });
77
+ }
78
+ const { data } = await contract.populateTransaction.targetAction(sourceSpells, targetSpells, commonSpells, position, actionId, sourceSender, sourceDsaId, targetDsaId, sourceChainId, targetChainId, vnonce, metadata);
79
+ transactions.push({
80
+ to: interopAddress,
81
+ data: data,
82
+ value: "0",
83
+ operation: ethers_multisend_1.OperationType.Call,
84
+ });
6
85
  return { transactions, logs };
7
86
  }
8
87
  exports.default = default_1;
package/dist/src/index.js CHANGED
@@ -13,7 +13,7 @@ const package_json_1 = __importDefault(require("../package.json"));
13
13
  dotenv_1.default.config();
14
14
  const logger_1 = __importDefault(require("@/logger"));
15
15
  const logger = new logger_1.default('Process');
16
- const GIT_SHORT_HASH = '5953f3d';
16
+ const GIT_SHORT_HASH = '5a90c8d';
17
17
  const printUsage = () => {
18
18
  console.log();
19
19
  console.log(`Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
@@ -69,6 +69,7 @@ const net_1 = require("@/net");
69
69
  const api_1 = require("@/api");
70
70
  const db_1 = require("./db");
71
71
  const utils_1 = require("./utils");
72
+ require("./crons");
72
73
  async function main() {
73
74
  (0, net_1.startPeer)({});
74
75
  const tasks = new tasks_1.Tasks();
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./retry-provider"), exports);
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.JsonRpcRetryProvider = exports.retryOperation = exports.promiseTimeout = void 0;
7
+ const ethers_1 = require("ethers");
8
+ const waait_1 = __importDefault(require("waait"));
9
+ const bluebird_1 = __importDefault(require("bluebird"));
10
+ function promiseTimeout(ms, promise) {
11
+ return bluebird_1.default.resolve(promise).timeout(ms);
12
+ }
13
+ exports.promiseTimeout = promiseTimeout;
14
+ function retryOperation(retriesLeft, operation, options) {
15
+ return new Promise((resolve, reject) => {
16
+ const { timeouts } = options;
17
+ // Find the timeout for this specific iteration
18
+ const timeout = timeouts[timeouts.length - retriesLeft];
19
+ // Wrap the original operation in a timeout
20
+ const execution = promiseTimeout(timeout, operation());
21
+ // If the promise is successful, resolve it and bubble the result up
22
+ return execution.then(resolve).catch((reason) => {
23
+ // If there are any retries left, we call the same retryOperation function again,
24
+ // but decrementing the number of retries left by 1
25
+ if (retriesLeft - 1 > 0) {
26
+ // Delay the new attempt slightly
27
+ return (0, waait_1.default)(options.delay || 50)
28
+ .then(retryOperation.bind(null, retriesLeft - 1, operation, options))
29
+ .then(resolve)
30
+ .catch(reject);
31
+ }
32
+ // Reject (and bubble the result up) if there are no more retries
33
+ return reject(reason);
34
+ });
35
+ });
36
+ }
37
+ exports.retryOperation = retryOperation;
38
+ class JsonRpcRetryProvider extends ethers_1.ethers.providers.JsonRpcProvider {
39
+ perform(method, params) {
40
+ const timeouts = [5000, 10000];
41
+ const operation = () => super.perform(method, params);
42
+ return retryOperation(2, operation, { timeouts, delay: 50 });
43
+ }
44
+ }
45
+ exports.JsonRpcRetryProvider = JsonRpcRetryProvider;
@@ -0,0 +1,74 @@
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 web3_utils_1 = __importDefault(require("web3-utils"));
7
+ const path_1 = __importDefault(require("path"));
8
+ const fs_1 = __importDefault(require("fs"));
9
+ const constants_1 = require("@/constants");
10
+ const expand_home_dir_1 = __importDefault(require("expand-home-dir"));
11
+ const config_1 = __importDefault(require("@/config"));
12
+ const utils_1 = require("@/utils");
13
+ const basePath = (0, expand_home_dir_1.default)(`~/.interop-x/data/${config_1.default.publicAddress}/${config_1.default.staging ? 'staging' : ''}`);
14
+ const mainnetPricesFilePath = path_1.default.resolve(basePath, "./mainnetPrices.json");
15
+ const networkTokenPricesFilePath = path_1.default.resolve(basePath, "./networkTokenPrices.json");
16
+ class Prices {
17
+ static async fetch() {
18
+ if (!fs_1.default.existsSync(mainnetPricesFilePath)) {
19
+ fs_1.default.writeFileSync(mainnetPricesFilePath, JSON.stringify({}));
20
+ }
21
+ if (!fs_1.default.existsSync(networkTokenPricesFilePath)) {
22
+ fs_1.default.writeFileSync(networkTokenPricesFilePath, JSON.stringify({}));
23
+ }
24
+ this.mainnetPrices = JSON.parse(fs_1.default.readFileSync(mainnetPricesFilePath, "utf8"));
25
+ this.networkTokenPrices = JSON.parse(fs_1.default.readFileSync(networkTokenPricesFilePath, "utf8"));
26
+ try {
27
+ const path = constants_1.tokens["1"]
28
+ .filter((a) => a.symbol !== "ETH")
29
+ .map((token) => token.address)
30
+ .join(",");
31
+ const [response, ethResponse, avaxResponse, polygonResponse] = await Promise.all([
32
+ utils_1.http.get("https://api.coingecko.com/api/v3/simple/token_price/ethereum", {
33
+ params: { contract_addresses: path, vs_currencies: "usd" },
34
+ }),
35
+ utils_1.http.get("https://api.coingecko.com/api/v3/simple/price", {
36
+ params: { ids: "ethereum", vs_currencies: "usd" },
37
+ }),
38
+ utils_1.http.get("https://api.coingecko.com/api/v3/simple/price", {
39
+ params: { ids: "avalanche-2", vs_currencies: "usd" },
40
+ }),
41
+ utils_1.http.get("https://api.coingecko.com/api/v3/simple/price", {
42
+ params: { ids: "matic-network", vs_currencies: "usd" },
43
+ }),
44
+ ]);
45
+ this.networkTokenPrices = {
46
+ "1": ethResponse.data.ethereum.usd.toString(),
47
+ "137": polygonResponse.data["matic-network"].usd.toString(),
48
+ "43114": avaxResponse.data["avalanche-2"].usd.toString(),
49
+ };
50
+ const data = response.data;
51
+ for (const key in data) {
52
+ const _key = web3_utils_1.default.toChecksumAddress(key);
53
+ if (!data[key].usd)
54
+ continue;
55
+ this.mainnetPrices[_key] = data[key].usd.toString();
56
+ }
57
+ this.mainnetPrices["0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE"] =
58
+ ethResponse.data.ethereum.usd.toString();
59
+ }
60
+ catch (error) { }
61
+ fs_1.default.writeFileSync(mainnetPricesFilePath, JSON.stringify(this.mainnetPrices));
62
+ fs_1.default.writeFileSync(networkTokenPricesFilePath, JSON.stringify(this.networkTokenPrices));
63
+ return this.mainnetPrices;
64
+ }
65
+ static getMainnetPrices() {
66
+ return this.mainnetPrices;
67
+ }
68
+ static getNetworkTokenPrices() {
69
+ return this.networkTokenPrices;
70
+ }
71
+ }
72
+ Prices.mainnetPrices = {};
73
+ Prices.networkTokenPrices = {};
74
+ exports.default = Prices;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Prices = void 0;
7
+ var Prices_1 = require("./Prices");
8
+ Object.defineProperty(exports, "Prices", { enumerable: true, get: function () { return __importDefault(Prices_1).default; } });
@@ -16,10 +16,14 @@ 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
- class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
19
+ const errors_1 = require("@/errors");
20
+ const bignumber_js_1 = require("bignumber.js");
21
+ const dedent_1 = __importDefault(require("dedent"));
22
+ const providers_1 = require("@/providers");
23
+ class ProcessSubmitEvents extends BaseTask_1.BaseTask {
20
24
  constructor({ chainId }) {
21
25
  super({
22
- logger: new logger_1.default("InteropX::ProcessSubmitSubmitEvents"),
26
+ logger: new logger_1.default("InteropX::ProcessSubmitEvents"),
23
27
  });
24
28
  this.leadNodeOnly = true;
25
29
  this.blockConfirmationsCount = 12;
@@ -51,16 +55,80 @@ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
51
55
  if (!transaction) {
52
56
  return;
53
57
  }
58
+ this.logger.debug(`Processing transaction ${transaction.transactionHash}`);
54
59
  transaction.sourceStatus = "proccessing";
55
60
  await transaction.save();
61
+ const { submitEvent: { position, sourceChainId, targetChainId } } = transaction;
62
+ try {
63
+ (0, utils_1.validateChains)({ sourceChainId, targetChainId });
64
+ }
65
+ catch (error) {
66
+ transaction.sourceErrors = [error.message];
67
+ transaction.sourceStatus = "failed";
68
+ transaction.targetStatus = "failed";
69
+ transaction.status = "failed";
70
+ await transaction.save();
71
+ return;
72
+ }
73
+ const walletBalance = (await this.sourceWallet.getBalance()).toString();
74
+ const currentGasPrice = (await this.sourceWallet.getGasPrice()).toString();
75
+ const minBalanceRequired = new bignumber_js_1.BigNumber(currentGasPrice)
76
+ .multipliedBy(4000000)
77
+ .multipliedBy(2); // 2x balance
78
+ if (new bignumber_js_1.BigNumber(walletBalance).isLessThan(minBalanceRequired)) {
79
+ console.log((0, dedent_1.default) `Not enough balance in wallet ${(0, utils_1.getExplorerUrl)(sourceChainId, '/address/' + this.sourceWallet.address)} on ${(0, utils_1.chainIdToName)(sourceChainId)}
80
+ Balance: ${ethers_1.ethers.utils.parseEther(walletBalance)} ${(0, utils_1.getChainIdNativeSymbol)(sourceChainId)}
81
+ Required Balance: ${ethers_1.ethers.utils.parseEther(minBalanceRequired.toString())}
82
+ Require more: ${ethers_1.ethers.utils.parseEther(minBalanceRequired.minus(walletBalance).toString())}`);
83
+ transaction.sourceDelayUntil = (0, moment_1.default)().add({ minutes: 5 }).toDate();
84
+ transaction.sourceStatus = "pending";
85
+ await transaction.save();
86
+ return;
87
+ }
88
+ try {
89
+ await (0, utils_1.validateLiquidityCap)(position, sourceChainId, targetChainId);
90
+ }
91
+ catch (error) {
92
+ transaction.sourceErrors = [error.message];
93
+ transaction.sourceStatus = "failed";
94
+ transaction.targetStatus = "failed";
95
+ transaction.status = "failed";
96
+ await transaction.save();
97
+ return;
98
+ }
99
+ try {
100
+ await (0, utils_1.validateSourceLiquidity)({
101
+ position,
102
+ sourceChainId,
103
+ sourceProvider: this.sourceProvider,
104
+ });
105
+ }
106
+ catch (error) {
107
+ if (error instanceof errors_1.UnsupportedChaindIdError) {
108
+ console.log(`Dropping transaction ${transaction.transactionHash}`);
109
+ transaction.sourceErrors = [error.message];
110
+ transaction.sourceStatus = "failed";
111
+ transaction.targetStatus = "failed";
112
+ transaction.status = "failed";
113
+ await transaction.save();
114
+ }
115
+ else {
116
+ transaction.sourceStatus = "pending";
117
+ transaction.sourceDelayUntil = (0, moment_1.default)().add({ minutes: 5 }).toDate();
118
+ await transaction.save();
119
+ console.log("[validateSourceLiquidity][Warning]", error.message);
120
+ return;
121
+ }
122
+ }
56
123
  const ownersThreshold = await this.sourceGnosisContract.getThreshold();
57
124
  await (0, waait_1.default)(10000);
125
+ this.logger.debug(`Build gnosis action for ${transaction.transactionHash}`);
58
126
  let data, logs = [];
59
127
  try {
60
128
  ({ data, logs } = await (0, gnosis_1.buildGnosisAction)(transaction, "source"));
61
129
  }
62
130
  catch (error) {
63
- if (error instanceof utils_1.LiquidityError) {
131
+ if (error instanceof errors_1.LiquidityError) {
64
132
  await transaction.save();
65
133
  transaction.sourceDelayUntil = new Date(Date.now() + 60 * 5 * 1000);
66
134
  transaction.sourceStatus = "pending";
@@ -76,6 +144,7 @@ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
76
144
  net_1.protocol.sendTransaction(transaction);
77
145
  return;
78
146
  }
147
+ this.logger.debug(`Generating gnosis tx for ${transaction.transactionHash}`);
79
148
  let gnosisTx = await (0, utils_1.generateGnosisTransaction)({
80
149
  baseGas: "0",
81
150
  data,
@@ -121,10 +190,19 @@ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
121
190
  }
122
191
  console.log(`Executing transaction for execution ${transaction.transactionHash}`);
123
192
  const { data: txData } = await this.sourceGnosisContract.populateTransaction.execTransaction(gnosisTx.to, gnosisTx.value, gnosisTx.data, gnosisTx.operation, gnosisTx.safeTxGas, gnosisTx.baseGas, gnosisTx.gasPrice, gnosisTx.gasToken, gnosisTx.refundReceiver, (0, utils_1.buildSignatureBytes)(validSignatures));
193
+ const [gasPrice, gasLimit] = await Promise.all([
194
+ this.sourceProvider.getGasPrice(),
195
+ this.sourceProvider.estimateGas({
196
+ from: this.sourceWallet.address,
197
+ to: this.sourceGnosisContract.address,
198
+ data: txData,
199
+ }),
200
+ ]);
124
201
  const txSent = await this.sourceWallet.sendTransaction({
125
202
  from: this.sourceWallet.address,
126
- gasPrice: ethers_1.ethers.BigNumber.from(120 * 10 ** 9),
127
203
  to: this.sourceGnosisContract.address,
204
+ gasPrice: gasPrice.mul(120).div(100),
205
+ gasLimit: 5000000,
128
206
  data: txData,
129
207
  });
130
208
  console.log(txSent);
@@ -151,7 +229,6 @@ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
151
229
  if (txSent.blockNumber)
152
230
  transaction.sourceBlockNumber = txSent.blockNumber;
153
231
  transaction.sourceTransactionHash = txSent.hash;
154
- transaction.sourceTransactionHash = txSent.hash;
155
232
  transaction.status = "failed";
156
233
  await transaction.save();
157
234
  }
@@ -159,10 +236,10 @@ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
159
236
  }
160
237
  async start() {
161
238
  this.blockConfirmationsCount = constants_1.blockConfirmations[this.chainId] + 1;
162
- this.sourceProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
239
+ this.sourceProvider = new providers_1.JsonRpcRetryProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
163
240
  this.sourceWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, this.sourceProvider);
164
241
  this.sourceGnosisContract = (0, utils_1.getContract)(constants_1.addresses[this.chainId].gnosisSafe, abi_1.default.gnosisSafe, this.sourceWallet);
165
242
  await super.start();
166
243
  }
167
244
  }
168
- exports.default = ProcessSubmitSubmitEvents;
245
+ exports.default = ProcessSubmitEvents;