@instadapp/interop-x 0.0.0-dev.73da8c9 → 0.0.0-dev.73e5298

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 (82) hide show
  1. package/dist/package.json +18 -16
  2. package/dist/src/abi/index.js +2 -4
  3. package/dist/src/abi/interopXContract.json +454 -0
  4. package/dist/src/alias.js +10 -0
  5. package/dist/src/api/index.js +6 -3
  6. package/dist/src/config/index.js +11 -1
  7. package/dist/src/constants/addresses.js +7 -7
  8. package/dist/src/constants/index.js +0 -1
  9. package/dist/src/constants/tokens.js +62 -39
  10. package/dist/src/db/models/transaction.js +27 -11
  11. package/dist/src/gnosis/actions/index.js +9 -0
  12. package/dist/src/gnosis/actions/withdraw/index.js +115 -0
  13. package/dist/src/gnosis/index.js +20 -0
  14. package/dist/src/index.js +75 -24
  15. package/dist/src/net/peer/index.js +2 -1
  16. package/dist/src/net/pool/index.js +18 -2
  17. package/dist/src/net/protocol/dial/SignatureDialProtocol.js +8 -2
  18. package/dist/src/net/protocol/dial/TransactionStatusDialProtocol.js +30 -0
  19. package/dist/src/net/protocol/index.js +51 -1
  20. package/dist/src/tasks/AutoUpdateTask.js +70 -0
  21. package/dist/src/tasks/BaseTask.js +11 -3
  22. package/dist/src/tasks/InteropXContract/ProcessBridgeRequestEvents.js +158 -0
  23. package/dist/src/tasks/InteropXContract/SyncBridgeCommittedEvents.js +93 -0
  24. package/dist/src/tasks/InteropXContract/SyncBridgeRequestEvents.js +78 -0
  25. package/dist/src/tasks/InteropXContract/SyncBridgeRequestSentEvents.js +90 -0
  26. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +57 -0
  27. package/dist/src/tasks/index.js +18 -8
  28. package/dist/src/typechain/{InteropBridgeToken.js → InteropXContract.js} +0 -0
  29. package/dist/src/typechain/factories/InteropXContract__factory.js +635 -0
  30. package/dist/src/typechain/factories/index.js +3 -5
  31. package/dist/src/typechain/index.js +3 -5
  32. package/dist/src/utils/index.js +62 -47
  33. package/package.json +18 -16
  34. package/src/abi/index.ts +2 -4
  35. package/src/abi/interopXContract.json +454 -0
  36. package/src/alias.ts +6 -0
  37. package/src/api/index.ts +5 -2
  38. package/src/config/index.ts +11 -1
  39. package/src/constants/addresses.ts +8 -8
  40. package/src/constants/index.ts +0 -1
  41. package/src/constants/tokens.ts +63 -40
  42. package/src/db/models/transaction.ts +76 -27
  43. package/src/gnosis/actions/index.ts +5 -0
  44. package/src/gnosis/actions/withdraw/index.ts +155 -0
  45. package/src/gnosis/index.ts +19 -0
  46. package/src/index.ts +96 -26
  47. package/src/net/peer/index.ts +2 -1
  48. package/src/net/pool/index.ts +25 -5
  49. package/src/net/protocol/dial/SignatureDialProtocol.ts +10 -4
  50. package/src/net/protocol/dial/TransactionStatusDialProtocol.ts +33 -0
  51. package/src/net/protocol/index.ts +67 -1
  52. package/src/tasks/AutoUpdateTask.ts +82 -0
  53. package/src/tasks/BaseTask.ts +13 -3
  54. package/src/tasks/InteropXContract/ProcessBridgeRequestEvents.ts +226 -0
  55. package/src/tasks/InteropXContract/SyncBridgeCommittedEvents.ts +125 -0
  56. package/src/tasks/InteropXContract/SyncBridgeRequestEvents.ts +115 -0
  57. package/src/tasks/InteropXContract/SyncBridgeRequestSentEvents.ts +121 -0
  58. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +69 -0
  59. package/src/tasks/index.ts +27 -9
  60. package/src/typechain/InteropXContract.ts +680 -0
  61. package/src/typechain/factories/InteropXContract__factory.ts +642 -0
  62. package/src/typechain/factories/index.ts +1 -2
  63. package/src/typechain/index.ts +2 -4
  64. package/src/utils/index.ts +103 -66
  65. package/tsconfig.json +7 -2
  66. package/dist/src/abi/interopBridgeToken.json +0 -286
  67. package/dist/src/abi/interopXGateway.json +0 -184
  68. package/dist/src/constants/itokens.js +0 -13
  69. package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +0 -158
  70. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -75
  71. package/dist/src/typechain/InteropXGateway.js +0 -2
  72. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -459
  73. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  74. package/src/abi/interopBridgeToken.json +0 -286
  75. package/src/abi/interopXGateway.json +0 -184
  76. package/src/constants/itokens.ts +0 -10
  77. package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +0 -253
  78. package/src/tasks/InteropXGateway/SyncDepositEvents.ts +0 -126
  79. package/src/typechain/InteropBridgeToken.ts +0 -686
  80. package/src/typechain/InteropXGateway.ts +0 -407
  81. package/src/typechain/factories/InteropBridgeToken__factory.ts +0 -466
  82. package/src/typechain/factories/InteropXGateway__factory.ts +0 -272
@@ -23,13 +23,11 @@ var __importStar = (this && this.__importStar) || function (mod) {
23
23
  return result;
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.InteropXGateway__factory = exports.InteropBridgeToken__factory = exports.GnosisSafe__factory = exports.Erc20__factory = exports.factories = void 0;
26
+ exports.InteropXContract__factory = exports.GnosisSafe__factory = exports.Erc20__factory = exports.factories = void 0;
27
27
  exports.factories = __importStar(require("./factories"));
28
28
  var Erc20__factory_1 = require("./factories/Erc20__factory");
29
29
  Object.defineProperty(exports, "Erc20__factory", { enumerable: true, get: function () { return Erc20__factory_1.Erc20__factory; } });
30
30
  var GnosisSafe__factory_1 = require("./factories/GnosisSafe__factory");
31
31
  Object.defineProperty(exports, "GnosisSafe__factory", { enumerable: true, get: function () { return GnosisSafe__factory_1.GnosisSafe__factory; } });
32
- var InteropBridgeToken__factory_1 = require("./factories/InteropBridgeToken__factory");
33
- Object.defineProperty(exports, "InteropBridgeToken__factory", { enumerable: true, get: function () { return InteropBridgeToken__factory_1.InteropBridgeToken__factory; } });
34
- var InteropXGateway__factory_1 = require("./factories/InteropXGateway__factory");
35
- Object.defineProperty(exports, "InteropXGateway__factory", { enumerable: true, get: function () { return InteropXGateway__factory_1.InteropXGateway__factory; } });
32
+ var InteropXContract__factory_1 = require("./factories/InteropXContract__factory");
33
+ Object.defineProperty(exports, "InteropXContract__factory", { enumerable: true, get: function () { return InteropXContract__factory_1.InteropXContract__factory; } });
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getContract = exports.buildDataForTransaction = exports.generateInteropTransactionHash = exports.asyncCallWithTimeout = exports.buildSignatureBytes = exports.getRpcProviderUrl = exports.signGnosisSafeTx = exports.short = exports.http = void 0;
6
+ exports.LiquidityError = exports.generateGnosisTransaction = exports.getContract = exports.ContractError = exports.generateInteropTransactionHash = exports.asyncCallWithTimeout = exports.buildSignatureBytes = exports.getRpcProviderUrl = exports.signGnosisSafeTx = exports.short = exports.shortenHash = exports.http = void 0;
7
7
  /**
8
8
  * @module util
9
9
  */
@@ -11,11 +11,19 @@ const axios_1 = __importDefault(require("axios"));
11
11
  const axios_retry_1 = __importDefault(require("axios-retry"));
12
12
  const constants_1 = require("@/constants");
13
13
  const ethers_1 = require("ethers");
14
- const ethers_multisend_1 = require("ethers-multisend");
15
- const config_1 = __importDefault(require("@/config"));
16
- const abi_1 = __importDefault(require("@/abi"));
14
+ const async_retry_1 = __importDefault(require("async-retry"));
17
15
  exports.http = axios_1.default.create();
18
16
  (0, axios_retry_1.default)(exports.http, { retries: 3, retryDelay: axios_retry_1.default.exponentialDelay });
17
+ function shortenHash(hash, length = 4) {
18
+ if (!hash)
19
+ return;
20
+ if (hash.length < 12)
21
+ return hash;
22
+ const beginningChars = hash.startsWith("0x") ? length + 2 : length;
23
+ const shortened = hash.substr(0, beginningChars) + "…" + hash.substr(-length);
24
+ return shortened;
25
+ }
26
+ exports.shortenHash = shortenHash;
19
27
  function short(buffer) {
20
28
  return buffer.toString('hex').slice(0, 8) + '...';
21
29
  }
@@ -59,11 +67,11 @@ exports.signGnosisSafeTx = signGnosisSafeTx;
59
67
  const getRpcProviderUrl = (chainId) => {
60
68
  switch (chainId) {
61
69
  case 1:
62
- return 'https://rpc.instadapp.io/mainnet';
70
+ return 'https://rpc.ankr.com/eth';
63
71
  case 137:
64
- return 'https://rpc.instadapp.io/polygon';
72
+ return 'https://rpc.ankr.com/polygon';
65
73
  case 43114:
66
- return 'https://rpc.instadapp.io/avalanche';
74
+ return 'https://rpc.ankr.com/avalanche';
67
75
  default:
68
76
  throw new Error(`Unknown chainId: ${chainId}`);
69
77
  }
@@ -94,62 +102,48 @@ const asyncCallWithTimeout = async (asyncPromise, timeout) => {
94
102
  };
95
103
  exports.asyncCallWithTimeout = asyncCallWithTimeout;
96
104
  const generateInteropTransactionHash = (data) => {
97
- return ethers_1.ethers.utils.solidityKeccak256(['string', 'string', 'string', 'string'], [
98
- String(data.action),
99
- String(data.submitTransactionHash),
105
+ return ethers_1.ethers.utils.solidityKeccak256(['string', 'string', 'string', 'string', 'string'], [
106
+ String(data.actionId),
107
+ String(data.bridger),
108
+ String(data.requestTransactionHash),
100
109
  String(data.sourceChainId),
101
110
  String(data.targetChainId),
102
111
  ]);
103
112
  };
104
113
  exports.generateInteropTransactionHash = generateInteropTransactionHash;
105
- const buildDataForTransaction = async (transaction, type) => {
106
- type = type || transaction.sourceStatus === 'pending' ? 'source' : 'target';
107
- const transactions = [];
108
- if (transaction.action != 'deposit') {
109
- throw new Error('Invalid action');
110
- }
111
- if (transaction.action === 'deposit' && transaction.sourceStatus === 'pending') {
112
- throw Error('Cannot build data for pending deposit transaction');
113
- }
114
- if (!transaction.submitEvent) {
115
- throw Error('Cannot build data for transaction without submitEvent');
116
- }
117
- const token = constants_1.tokens[transaction.sourceChainId].find(token => token.address.toLowerCase() === transaction.submitEvent.token.toLowerCase());
118
- if (!token) {
119
- throw Error('Cannot build data for transaction without token');
120
- }
121
- const itoken = constants_1.itokens[transaction.targetChainId].find(itoken => itoken.symbol.toLowerCase() === token.symbol.toLowerCase());
122
- if (!itoken) {
123
- throw Error('Cannot build data for transaction without itoken');
124
- }
125
- const targetChainProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, exports.getRpcProviderUrl)(transaction.targetChainId));
126
- const targetWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, targetChainProvider);
127
- const interopBridgeContract = getContract(itoken.address, abi_1.default.interopBridgeToken, targetWallet);
128
- const { data } = await interopBridgeContract.populateTransaction.mint(transaction.submitEvent.user, ethers_1.ethers.BigNumber.from(transaction.submitEvent.amount.toString()), ethers_1.ethers.BigNumber.from(transaction.submitEvent.sourceChainId.toString()), transaction.sourceTransactionHash);
129
- transactions.push({
130
- to: itoken.address,
131
- data: data,
132
- value: '0',
133
- operation: ethers_multisend_1.OperationType.Call,
134
- });
135
- return (0, ethers_multisend_1.encodeMulti)(transactions).data;
136
- };
137
- exports.buildDataForTransaction = buildDataForTransaction;
114
+ class ContractError extends Error {
115
+ }
116
+ exports.ContractError = ContractError;
138
117
  function getContract(address, contractInterface, signerOrProvider) {
139
118
  if (!ethers_1.ethers.utils.getAddress(address) || address === ethers_1.ethers.constants.AddressZero) {
140
119
  throw Error(`Invalid 'address' parameter '${address}'.`);
141
120
  }
142
121
  const contract = new ethers_1.ethers.Contract(address, contractInterface, signerOrProvider);
122
+ // Make sure the contract properties is writable
123
+ const desc = Object.getOwnPropertyDescriptor(contract, 'functions');
124
+ if (!desc || desc.writable !== true) {
125
+ return contract;
126
+ }
143
127
  return new Proxy(contract, {
144
128
  get(target, prop, receiver) {
145
129
  const value = Reflect.get(target, prop, receiver);
146
130
  if (typeof value === 'function' && (contract.functions.hasOwnProperty(prop) || ['queryFilter'].includes(String(prop)))) {
131
+ let isConstant = false;
132
+ try {
133
+ isConstant = contract.interface.getFunction(String(prop)).constant;
134
+ }
135
+ catch (error) {
136
+ }
147
137
  return async (...args) => {
148
138
  try {
149
- return await value.bind(contract)(...args);
139
+ return await (0, async_retry_1.default)(async () => await value.bind(contract)(...args), { retries: isConstant ? 1 : 3 });
150
140
  }
151
141
  catch (error) {
152
- throw new Error(`Error calling "${String(prop)}" on "${address}": ${error.reason || error.message}`);
142
+ const err = new ContractError(`Error calling "${String(prop)}" on "${address}": ${error.reason || error.message}`);
143
+ err.method = String(prop);
144
+ err.address = address;
145
+ err.args = [...args];
146
+ throw err;
153
147
  }
154
148
  };
155
149
  }
@@ -161,10 +155,14 @@ function getContract(address, contractInterface, signerOrProvider) {
161
155
  if (typeof value === 'function') {
162
156
  return async (...args) => {
163
157
  try {
164
- return await value.bind(contract)(...args);
158
+ return await (0, async_retry_1.default)(async () => await value.bind(contract)(...args), { retries: parentProp === 'callStatic' ? 3 : 1 });
165
159
  }
166
160
  catch (error) {
167
- throw new Error(`Error calling "${String(prop)}" using "${parentProp}" on "${address}": ${error.reason || error.message}`);
161
+ const err = new ContractError(`Error calling "${String(prop)}" using "${parentProp}" on "${address}": ${error.reason || error.message}`);
162
+ err.method = String(prop);
163
+ err.address = address;
164
+ err.args = [...args];
165
+ throw err;
168
166
  }
169
167
  };
170
168
  }
@@ -176,3 +174,20 @@ function getContract(address, contractInterface, signerOrProvider) {
176
174
  });
177
175
  }
178
176
  exports.getContract = getContract;
177
+ const generateGnosisTransaction = async (transactionData, safeContract) => {
178
+ console.log(transactionData);
179
+ let isExecuted = await safeContract.dataHashes(await safeContract.getTransactionHash(transactionData.to, transactionData.value, transactionData.data, transactionData.operation, transactionData.safeTxGas, transactionData.baseGas, transactionData.gasPrice, transactionData.gasToken, transactionData.refundReceiver, transactionData.nonce));
180
+ while (isExecuted == 1) {
181
+ transactionData.safeTxGas = ethers_1.ethers.BigNumber.from(String(transactionData.safeTxGas)).add(1).toString();
182
+ isExecuted = await safeContract.dataHashes(await safeContract.getTransactionHash(transactionData.to, transactionData.value, transactionData.data, transactionData.operation, transactionData.safeTxGas, transactionData.baseGas, transactionData.gasPrice, transactionData.gasToken, transactionData.refundReceiver, transactionData.nonce));
183
+ }
184
+ return transactionData;
185
+ };
186
+ exports.generateGnosisTransaction = generateGnosisTransaction;
187
+ class LiquidityError extends Error {
188
+ constructor(message) {
189
+ super(message || 'Not enough liquidity');
190
+ Object.setPrototypeOf(this, new.target.prototype);
191
+ }
192
+ }
193
+ exports.LiquidityError = LiquidityError;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@instadapp/interop-x",
3
- "version": "0.0.0-dev.73da8c9",
3
+ "version": "0.0.0-dev.73e5298",
4
4
  "license": "MIT",
5
5
  "main": "dist/index.js",
6
6
  "engines": {
@@ -11,7 +11,7 @@
11
11
  "start": "yarn build && node bin/interop-x",
12
12
  "build": "yarn generate-abi-types && export GIT_REF=$(git rev-parse --short HEAD) && rimraf ./dist && tsc -p tsconfig.json && replace-in-file '@GIT_SHORT_HASH@' $GIT_REF ./dist/**/*.js",
13
13
  "dev": "yarn generate-abi-types && NODE_ENV=development nodemon",
14
- "generate-abi-types": "typechain --target=ethers-v5 'src/abi/*.json' --out-dir 'src/typechain'",
14
+ "generate-abi-types": "rimraf src/typechain && typechain --target=ethers-v5 'src/abi/*.json' --out-dir 'src/typechain'",
15
15
  "prepublishOnly": "yarn build",
16
16
  "postinstall": "patch-package"
17
17
  },
@@ -24,17 +24,19 @@
24
24
  },
25
25
  "dependencies": {
26
26
  "@achingbrain/libp2p-gossipsub": "^0.12.2",
27
- "axios": "^0.27.1",
28
- "axios-retry": "^3.2.4",
29
- "bignumber.js": "^9.0.2",
27
+ "@fastify/cors": "^7.0.0",
28
+ "async-retry": "^1.3.3",
29
+ "await-spawn": "^4.0.2",
30
+ "axios": "^0.27.2",
31
+ "axios-retry": "^3.2.5",
30
32
  "chalk": "4.1.2",
31
- "dotenv": "^16.0.0",
33
+ "dotenv": "^16.0.1",
32
34
  "ethereumjs-util": "^7.1.4",
33
- "ethers": "^5.6.4",
35
+ "ethers": "^5.6.5",
34
36
  "ethers-multisend": "^2.1.1",
35
37
  "expand-home-dir": "^0.0.3",
36
- "fastify": "^3.28.0",
37
- "fastify-cors": "^6.0.3",
38
+ "fastify": "^3.29.0",
39
+ "fs-extra": "^10.1.0",
38
40
  "libp2p": "^0.36.2",
39
41
  "libp2p-bootstrap": "^0.14.0",
40
42
  "libp2p-kad-dht": "^0.28.6",
@@ -44,10 +46,12 @@
44
46
  "libp2p-pubsub-peer-discovery": "^4.0.0",
45
47
  "libp2p-tcp": "^0.17.2",
46
48
  "libp2p-websockets": "^0.16.2",
47
- "luxon": "^2.3.2",
49
+ "luxon": "^2.4.0",
48
50
  "module-alias": "^2.2.2",
51
+ "patch-package": "^6.4.7",
52
+ "postinstall-postinstall": "^2.1.0",
49
53
  "sequelize": "6.18.0",
50
- "sqlite3": "^5.0.5",
54
+ "sqlite3": "^5.0.8",
51
55
  "waait": "^1.0.5"
52
56
  },
53
57
  "bin": {
@@ -58,15 +62,13 @@
58
62
  "@typechain/ethers-v5": "^10.0.0",
59
63
  "@types/bn.js": "^5.1.0",
60
64
  "@types/fs-extra": "^9.0.13",
61
- "@types/node": "^17.0.17",
62
- "nodemon": "^2.0.15",
63
- "patch-package": "^6.4.7",
64
- "postinstall-postinstall": "^2.1.0",
65
+ "@types/node": "^17.0.33",
66
+ "nodemon": "^2.0.16",
65
67
  "replace-in-file": "^6.3.2",
66
68
  "rimraf": "^3.0.2",
67
69
  "ts-node": "^10.5.0",
68
70
  "tsconfig-paths": "^3.12.0",
69
71
  "typechain": "^8.0.0",
70
- "typescript": "^4.5.5"
72
+ "typescript": "^4.6.4"
71
73
  }
72
74
  }
package/src/abi/index.ts CHANGED
@@ -1,11 +1,9 @@
1
1
  import gnosisSafe from "./gnosisSafe.json";
2
2
  import erc20 from "./erc20.json";
3
- import interopXGateway from "./interopXGateway.json";
4
- import interopBridgeToken from "./interopBridgeToken.json";
3
+ import interopXContract from "./interopXContract.json";
5
4
 
6
5
  export default {
7
6
  gnosisSafe,
8
7
  erc20,
9
- interopXGateway,
10
- interopBridgeToken,
8
+ interopXContract,
11
9
  }