@instadapp/interop-x 0.0.0-dev.d4e8223 → 0.0.0-dev.d71f27e

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 (72) hide show
  1. package/dist/package.json +2 -2
  2. package/dist/src/abi/index.js +2 -4
  3. package/dist/src/abi/interopXContract.json +391 -0
  4. package/dist/src/alias.js +10 -0
  5. package/dist/src/constants/addresses.js +3 -3
  6. package/dist/src/constants/index.js +0 -1
  7. package/dist/src/db/models/transaction.js +27 -9
  8. package/dist/src/gnosis/actions/index.js +9 -0
  9. package/dist/src/gnosis/actions/withdraw/index.js +41 -0
  10. package/dist/src/gnosis/index.js +20 -0
  11. package/dist/src/index.js +7 -18
  12. package/dist/src/net/protocol/dial/SignatureDialProtocol.js +9 -10
  13. package/dist/src/net/protocol/dial/TransactionStatusDialProtocol.js +2 -0
  14. package/dist/src/net/protocol/index.js +11 -1
  15. package/dist/src/tasks/{InteropXGateway/ProcessDepositEvents.js → InteropXContract/ProcessBridgeRequestEvents.js} +43 -53
  16. package/dist/src/tasks/InteropXContract/SyncBridgeRequestEvents.js +78 -0
  17. package/dist/src/tasks/InteropXContract/SyncBridgeRequestSentEvents.js +89 -0
  18. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +2 -0
  19. package/dist/src/tasks/index.js +13 -30
  20. package/dist/src/typechain/{InteropBridgeToken.js → InteropXContract.js} +0 -0
  21. package/dist/src/typechain/factories/InteropXContract__factory.js +526 -0
  22. package/dist/src/typechain/factories/index.js +3 -5
  23. package/dist/src/typechain/index.js +3 -5
  24. package/dist/src/utils/index.js +14 -84
  25. package/package.json +2 -2
  26. package/src/abi/index.ts +2 -4
  27. package/src/abi/interopXContract.json +391 -0
  28. package/src/alias.ts +6 -0
  29. package/src/constants/addresses.ts +3 -3
  30. package/src/constants/index.ts +0 -1
  31. package/src/db/models/transaction.ts +66 -21
  32. package/src/gnosis/actions/index.ts +5 -0
  33. package/src/gnosis/actions/withdraw/index.ts +56 -0
  34. package/src/gnosis/index.ts +19 -0
  35. package/src/index.ts +6 -17
  36. package/src/net/protocol/dial/SignatureDialProtocol.ts +11 -13
  37. package/src/net/protocol/dial/TransactionStatusDialProtocol.ts +3 -1
  38. package/src/net/protocol/index.ts +13 -3
  39. package/src/tasks/{InteropXGateway/ProcessDepositEvents.ts → InteropXContract/ProcessBridgeRequestEvents.ts} +62 -103
  40. package/src/tasks/InteropXContract/SyncBridgeRequestEvents.ts +116 -0
  41. package/src/tasks/InteropXContract/SyncBridgeRequestSentEvents.ts +120 -0
  42. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +2 -0
  43. package/src/tasks/index.ts +15 -37
  44. package/src/typechain/InteropXContract.ts +524 -0
  45. package/src/typechain/factories/InteropXContract__factory.ts +533 -0
  46. package/src/typechain/factories/index.ts +1 -2
  47. package/src/typechain/index.ts +2 -4
  48. package/src/utils/index.ts +46 -125
  49. package/tsconfig.json +7 -2
  50. package/dist/src/abi/interopBridgeToken.json +0 -298
  51. package/dist/src/abi/interopXGateway.json +0 -184
  52. package/dist/src/constants/itokens.js +0 -13
  53. package/dist/src/tasks/InteropBridge/ProcessWithdrawEvents.js +0 -146
  54. package/dist/src/tasks/InteropBridge/SyncBurnEvents.js +0 -71
  55. package/dist/src/tasks/InteropBridge/SyncMintEvents.js +0 -67
  56. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -74
  57. package/dist/src/tasks/InteropXGateway/SyncWithdrawtEvents.js +0 -72
  58. package/dist/src/typechain/InteropXGateway.js +0 -2
  59. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -471
  60. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  61. package/src/abi/interopBridgeToken.json +0 -298
  62. package/src/abi/interopXGateway.json +0 -184
  63. package/src/constants/itokens.ts +0 -10
  64. package/src/tasks/InteropBridge/ProcessWithdrawEvents.ts +0 -231
  65. package/src/tasks/InteropBridge/SyncBurnEvents.ts +0 -121
  66. package/src/tasks/InteropBridge/SyncMintEvents.ts +0 -99
  67. package/src/tasks/InteropXGateway/SyncDepositEvents.ts +0 -124
  68. package/src/tasks/InteropXGateway/SyncWithdrawtEvents.ts +0 -105
  69. package/src/typechain/InteropBridgeToken.ts +0 -692
  70. package/src/typechain/InteropXGateway.ts +0 -407
  71. package/src/typechain/factories/InteropBridgeToken__factory.ts +0 -478
  72. package/src/typechain/factories/InteropXGateway__factory.ts +0 -272
@@ -3,15 +3,10 @@
3
3
  */
4
4
  import axios from 'axios'
5
5
  import axiosRetry from "axios-retry";
6
- import { addresses, itokens, tokens } from '@/constants';
6
+ import { addresses } from '@/constants';
7
7
  import { ChainId } from '@/types'
8
8
  import { ethers } from 'ethers';
9
- import { encodeMulti, MetaTransaction, OperationType } from 'ethers-multisend';
10
- import { Transaction } from '@/db';
11
- import config from '@/config';
12
- import abi from '@/abi';
13
- import { InteropBridgeToken, InteropXGateway } from '@/typechain';
14
-
9
+ import { GnosisSafe } from '@/typechain';
15
10
  export const http = axios.create();
16
11
 
17
12
  axiosRetry(http, { retries: 3, retryDelay: axiosRetry.exponentialDelay });
@@ -136,130 +131,16 @@ export const asyncCallWithTimeout = async <T>(asyncPromise: Promise<T>, timeout:
136
131
  }
137
132
 
138
133
 
139
- export const generateInteropTransactionHash = (data: { action: string, submitTransactionHash: string, sourceChainId: string | number, targetChainId: string | number }) => {
140
- return ethers.utils.solidityKeccak256(['string', 'string', 'string', 'string'], [
134
+ export const generateInteropTransactionHash = (data: { action: string, bridger: string, requestTransactionHash: string, sourceChainId: string | number, targetChainId: string | number }) => {
135
+ return ethers.utils.solidityKeccak256(['string', 'string', 'string', 'string', 'string'], [
141
136
  String(data.action),
142
- String(data.submitTransactionHash),
137
+ String(data.bridger),
138
+ String(data.requestTransactionHash),
143
139
  String(data.sourceChainId),
144
140
  String(data.targetChainId),
145
141
  ]);
146
142
  }
147
143
 
148
- export const buildDataForTransaction = async (transaction: Transaction, type?: 'source' | 'target') => {
149
- type = type || transaction.sourceStatus === 'pending' ? 'source' : 'target';
150
-
151
- switch (transaction.action) {
152
- case "deposit":
153
- return await buildDepositDataForTransaction(transaction, type);
154
- case "withdraw":
155
- return await buildWithdrawDataForTransaction(transaction, type);
156
- default:
157
- throw new Error(`Unknown action: ${transaction.action}`);
158
- }
159
- }
160
-
161
- export const buildDepositDataForTransaction = async (transaction: Transaction, type: 'source' | 'target') => {
162
- const transactions: MetaTransaction[] = [];
163
-
164
- if (transaction.action !== 'deposit') {
165
- throw new Error(`Invalid action: ${transaction.action}`)
166
- }
167
-
168
- if (transaction.action === 'deposit' && transaction.sourceStatus === 'pending') {
169
- throw Error('Cannot build data for pending deposit transaction');
170
- }
171
-
172
- if (!transaction.submitEvent) {
173
- throw Error('Cannot build data for transaction without submitEvent');
174
- }
175
-
176
-
177
- const token = tokens[transaction.sourceChainId].find(token => token.address.toLowerCase() === transaction.submitEvent.token.toLowerCase());
178
-
179
- if (!token) {
180
- throw Error('Cannot build data for transaction without token');
181
- }
182
-
183
- const itoken = itokens[transaction.targetChainId].find(itoken => itoken.symbol.toLowerCase() === token.symbol.toLowerCase());
184
-
185
- if (!itoken) {
186
- throw Error('Cannot build data for transaction without itoken');
187
- }
188
-
189
- const targetChainProvider = new ethers.providers.JsonRpcProvider(getRpcProviderUrl(transaction.targetChainId as ChainId));
190
- const targetWallet = new ethers.Wallet(config.privateKey, targetChainProvider);
191
- const interopBridgeContract = getContract<InteropBridgeToken>(itoken.address, abi.interopBridgeToken, targetWallet);
192
-
193
- const { data } = await interopBridgeContract.populateTransaction.mint(
194
- transaction.submitEvent.user,
195
- ethers.BigNumber.from(transaction.submitEvent.amount.toString()),
196
- ethers.BigNumber.from(transaction.submitEvent.sourceChainId.toString()),
197
- transaction.submitTransactionHash,
198
- );
199
-
200
- transactions.push({
201
- to: itoken.address,
202
- data: data!,
203
- value: '0',
204
- operation: OperationType.Call,
205
- });
206
-
207
- return encodeMulti(transactions).data
208
- }
209
-
210
- export const buildWithdrawDataForTransaction = async (transaction: Transaction, type: 'source' | 'target') => {
211
- const transactions: MetaTransaction[] = [];
212
-
213
- if (transaction.action !== 'withdraw') {
214
- throw new Error(`Invalid action: ${transaction.action}`)
215
- }
216
-
217
- if (transaction.action === 'withdraw' && transaction.sourceStatus === 'pending') {
218
- throw Error('Cannot build data for pending withdraw transaction');
219
- }
220
-
221
- if (!transaction.submitEvent) {
222
- throw Error('Cannot build data for transaction without submitEvent');
223
- }
224
-
225
- const { to, amount, sourceChainId, targetChainId, itoken: itokenAddress } = transaction.submitEvent;
226
-
227
- const itoken = itokens[sourceChainId].find(token => token.address.toLowerCase() === itokenAddress.toLowerCase());
228
-
229
- if (!itoken) {
230
- throw Error('Cannot build data for transaction without itoken');
231
- }
232
-
233
- const token = tokens[targetChainId].find(t => t.symbol.toLowerCase() === itoken.symbol.toLowerCase());
234
-
235
- if (!token) {
236
- throw Error('Cannot build data for transaction without token');
237
- }
238
-
239
- const targetChainProvider = new ethers.providers.JsonRpcProvider(getRpcProviderUrl(targetChainId as ChainId));
240
- const targetWallet = new ethers.Wallet(config.privateKey, targetChainProvider);
241
- const gatewayAddress = addresses[targetChainId].interopXGateway;
242
- const interopBridgeContract = getContract<InteropXGateway>(gatewayAddress, abi.interopXGateway, targetWallet);
243
-
244
- const { data } = await interopBridgeContract.populateTransaction.systemWithdraw(
245
- ethers.BigNumber.from(amount.toString()),
246
- to,
247
- token.address,
248
- ethers.BigNumber.from(sourceChainId.toString()),
249
- transaction.submitTransactionHash,
250
- );
251
-
252
- transactions.push({
253
- to: gatewayAddress,
254
- data: data!,
255
- value: '0',
256
- operation: OperationType.Call,
257
- });
258
-
259
- return encodeMulti(transactions).data
260
- }
261
-
262
-
263
144
  export function getContract<TContract extends ethers.Contract>(address: string, contractInterface: ethers.ContractInterface | any, signerOrProvider?: ethers.Signer | ethers.providers.Provider) {
264
145
  if (!ethers.utils.getAddress(address) || address === ethers.constants.AddressZero) {
265
146
  throw Error(`Invalid 'address' parameter '${address}'.`)
@@ -316,4 +197,44 @@ export function getContract<TContract extends ethers.Contract>(address: string,
316
197
  return value;
317
198
  },
318
199
  });
200
+ }
201
+
202
+ export const generateGnosisTransaction = async (transactionData: any, safeContract: GnosisSafe) => {
203
+ console.log(transactionData);
204
+
205
+ let isExecuted = await safeContract.dataHashes(
206
+ await safeContract.getTransactionHash(
207
+ transactionData.to,
208
+ transactionData.value,
209
+ transactionData.data,
210
+ transactionData.operation,
211
+ transactionData.safeTxGas,
212
+ transactionData.baseGas,
213
+ transactionData.gasPrice,
214
+ transactionData.gasToken,
215
+ transactionData.refundReceiver,
216
+ transactionData.nonce
217
+ )
218
+ )
219
+
220
+ while (isExecuted == 1) {
221
+ transactionData.safeTxGas = ethers.BigNumber.from(String(transactionData.safeTxGas)).add(1).toString()
222
+
223
+ isExecuted = await safeContract.dataHashes(
224
+ await safeContract.getTransactionHash(
225
+ transactionData.to,
226
+ transactionData.value,
227
+ transactionData.data,
228
+ transactionData.operation,
229
+ transactionData.safeTxGas,
230
+ transactionData.baseGas,
231
+ transactionData.gasPrice,
232
+ transactionData.gasToken,
233
+ transactionData.refundReceiver,
234
+ transactionData.nonce
235
+ )
236
+ )
237
+ }
238
+
239
+ return transactionData
319
240
  }
package/tsconfig.json CHANGED
@@ -16,8 +16,13 @@
16
16
  "noEmit": false,
17
17
  "outDir": "dist",
18
18
  "baseUrl": "src",
19
- "paths": {
20
- "@/*" : ["./*" ]
19
+ "paths": {
20
+ "@/*": [
21
+ "*"
22
+ ],
23
+ "@": [
24
+ "/"
25
+ ]
21
26
  },
22
27
  "typeRoots": [
23
28
  "./node_modules/@types",
@@ -1,298 +0,0 @@
1
- [
2
- {
3
- "inputs": [
4
- { "internalType": "address", "name": "__owner", "type": "address" }
5
- ],
6
- "stateMutability": "nonpayable",
7
- "type": "constructor"
8
- },
9
- {
10
- "anonymous": false,
11
- "inputs": [
12
- {
13
- "indexed": true,
14
- "internalType": "address",
15
- "name": "owner",
16
- "type": "address"
17
- },
18
- {
19
- "indexed": true,
20
- "internalType": "address",
21
- "name": "spender",
22
- "type": "address"
23
- },
24
- {
25
- "indexed": false,
26
- "internalType": "uint256",
27
- "name": "value",
28
- "type": "uint256"
29
- }
30
- ],
31
- "name": "Approval",
32
- "type": "event"
33
- },
34
- {
35
- "anonymous": false,
36
- "inputs": [
37
- {
38
- "indexed": true,
39
- "internalType": "address",
40
- "name": "to",
41
- "type": "address"
42
- },
43
- {
44
- "indexed": false,
45
- "internalType": "uint256",
46
- "name": "amount",
47
- "type": "uint256"
48
- },
49
- {
50
- "indexed": false,
51
- "internalType": "uint32",
52
- "name": "sourceChainId",
53
- "type": "uint32"
54
- },
55
- {
56
- "indexed": true,
57
- "internalType": "uint32",
58
- "name": "targetChainId",
59
- "type": "uint32"
60
- }
61
- ],
62
- "name": "Burn",
63
- "type": "event"
64
- },
65
- {
66
- "anonymous": false,
67
- "inputs": [
68
- {
69
- "indexed": true,
70
- "internalType": "address",
71
- "name": "to",
72
- "type": "address"
73
- },
74
- {
75
- "indexed": false,
76
- "internalType": "uint256",
77
- "name": "amount",
78
- "type": "uint256"
79
- },
80
- {
81
- "indexed": true,
82
- "internalType": "uint32",
83
- "name": "sourceChainId",
84
- "type": "uint32"
85
- },
86
- {
87
- "indexed": false,
88
- "internalType": "uint32",
89
- "name": "targetChainId",
90
- "type": "uint32"
91
- },
92
- {
93
- "indexed": true,
94
- "internalType": "bytes32",
95
- "name": "submitTransactionHash",
96
- "type": "bytes32"
97
- }
98
- ],
99
- "name": "Mint",
100
- "type": "event"
101
- },
102
- {
103
- "anonymous": false,
104
- "inputs": [
105
- {
106
- "indexed": true,
107
- "internalType": "address",
108
- "name": "previousOwner",
109
- "type": "address"
110
- },
111
- {
112
- "indexed": true,
113
- "internalType": "address",
114
- "name": "newOwner",
115
- "type": "address"
116
- }
117
- ],
118
- "name": "OwnershipTransferred",
119
- "type": "event"
120
- },
121
- {
122
- "anonymous": false,
123
- "inputs": [
124
- {
125
- "indexed": true,
126
- "internalType": "address",
127
- "name": "from",
128
- "type": "address"
129
- },
130
- {
131
- "indexed": true,
132
- "internalType": "address",
133
- "name": "to",
134
- "type": "address"
135
- },
136
- {
137
- "indexed": false,
138
- "internalType": "uint256",
139
- "name": "value",
140
- "type": "uint256"
141
- }
142
- ],
143
- "name": "Transfer",
144
- "type": "event"
145
- },
146
- {
147
- "inputs": [
148
- { "internalType": "address", "name": "owner", "type": "address" },
149
- { "internalType": "address", "name": "spender", "type": "address" }
150
- ],
151
- "name": "allowance",
152
- "outputs": [{ "internalType": "uint256", "name": "", "type": "uint256" }],
153
- "stateMutability": "view",
154
- "type": "function"
155
- },
156
- {
157
- "inputs": [
158
- { "internalType": "address", "name": "spender", "type": "address" },
159
- { "internalType": "uint256", "name": "amount", "type": "uint256" }
160
- ],
161
- "name": "approve",
162
- "outputs": [{ "internalType": "bool", "name": "", "type": "bool" }],
163
- "stateMutability": "nonpayable",
164
- "type": "function"
165
- },
166
- {
167
- "inputs": [
168
- { "internalType": "address", "name": "account", "type": "address" }
169
- ],
170
- "name": "balanceOf",
171
- "outputs": [{ "internalType": "uint256", "name": "", "type": "uint256" }],
172
- "stateMutability": "view",
173
- "type": "function"
174
- },
175
- {
176
- "inputs": [
177
- { "internalType": "address", "name": "to", "type": "address" },
178
- { "internalType": "uint256", "name": "amount", "type": "uint256" },
179
- { "internalType": "uint32", "name": "chainId", "type": "uint32" }
180
- ],
181
- "name": "burn",
182
- "outputs": [],
183
- "stateMutability": "nonpayable",
184
- "type": "function"
185
- },
186
- {
187
- "inputs": [],
188
- "name": "decimals",
189
- "outputs": [{ "internalType": "uint8", "name": "", "type": "uint8" }],
190
- "stateMutability": "view",
191
- "type": "function"
192
- },
193
- {
194
- "inputs": [
195
- { "internalType": "address", "name": "spender", "type": "address" },
196
- {
197
- "internalType": "uint256",
198
- "name": "subtractedValue",
199
- "type": "uint256"
200
- }
201
- ],
202
- "name": "decreaseAllowance",
203
- "outputs": [{ "internalType": "bool", "name": "", "type": "bool" }],
204
- "stateMutability": "nonpayable",
205
- "type": "function"
206
- },
207
- {
208
- "inputs": [
209
- { "internalType": "address", "name": "spender", "type": "address" },
210
- { "internalType": "uint256", "name": "addedValue", "type": "uint256" }
211
- ],
212
- "name": "increaseAllowance",
213
- "outputs": [{ "internalType": "bool", "name": "", "type": "bool" }],
214
- "stateMutability": "nonpayable",
215
- "type": "function"
216
- },
217
- {
218
- "inputs": [
219
- { "internalType": "address", "name": "to", "type": "address" },
220
- { "internalType": "uint256", "name": "amount", "type": "uint256" },
221
- { "internalType": "uint32", "name": "chainId", "type": "uint32" },
222
- {
223
- "internalType": "bytes32",
224
- "name": "transactionHash",
225
- "type": "bytes32"
226
- }
227
- ],
228
- "name": "mint",
229
- "outputs": [],
230
- "stateMutability": "nonpayable",
231
- "type": "function"
232
- },
233
- {
234
- "inputs": [],
235
- "name": "name",
236
- "outputs": [{ "internalType": "string", "name": "", "type": "string" }],
237
- "stateMutability": "view",
238
- "type": "function"
239
- },
240
- {
241
- "inputs": [],
242
- "name": "owner",
243
- "outputs": [{ "internalType": "address", "name": "", "type": "address" }],
244
- "stateMutability": "view",
245
- "type": "function"
246
- },
247
- {
248
- "inputs": [],
249
- "name": "renounceOwnership",
250
- "outputs": [],
251
- "stateMutability": "nonpayable",
252
- "type": "function"
253
- },
254
- {
255
- "inputs": [],
256
- "name": "symbol",
257
- "outputs": [{ "internalType": "string", "name": "", "type": "string" }],
258
- "stateMutability": "view",
259
- "type": "function"
260
- },
261
- {
262
- "inputs": [],
263
- "name": "totalSupply",
264
- "outputs": [{ "internalType": "uint256", "name": "", "type": "uint256" }],
265
- "stateMutability": "view",
266
- "type": "function"
267
- },
268
- {
269
- "inputs": [
270
- { "internalType": "address", "name": "to", "type": "address" },
271
- { "internalType": "uint256", "name": "amount", "type": "uint256" }
272
- ],
273
- "name": "transfer",
274
- "outputs": [{ "internalType": "bool", "name": "", "type": "bool" }],
275
- "stateMutability": "nonpayable",
276
- "type": "function"
277
- },
278
- {
279
- "inputs": [
280
- { "internalType": "address", "name": "from", "type": "address" },
281
- { "internalType": "address", "name": "to", "type": "address" },
282
- { "internalType": "uint256", "name": "amount", "type": "uint256" }
283
- ],
284
- "name": "transferFrom",
285
- "outputs": [{ "internalType": "bool", "name": "", "type": "bool" }],
286
- "stateMutability": "nonpayable",
287
- "type": "function"
288
- },
289
- {
290
- "inputs": [
291
- { "internalType": "address", "name": "newOwner", "type": "address" }
292
- ],
293
- "name": "transferOwnership",
294
- "outputs": [],
295
- "stateMutability": "nonpayable",
296
- "type": "function"
297
- }
298
- ]