@instadapp/interop-x 0.0.0-dev.cbee93c → 0.0.0-dev.d37d6ff

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 (255) hide show
  1. package/.github/workflows/ci.yml +19 -0
  2. package/dist/package.json +16 -13
  3. package/dist/src/abi/connectors/index.js +36 -0
  4. package/dist/src/abi/connectors/v1/aave.js +148 -0
  5. package/dist/src/abi/connectors/v1/aave_claim.js +4 -0
  6. package/dist/src/abi/connectors/v1/aave_migrate.js +109 -0
  7. package/dist/src/abi/connectors/v1/aave_polygon_migrate.js +110 -0
  8. package/dist/src/abi/connectors/v1/aave_stake.js +4 -0
  9. package/dist/src/abi/connectors/v1/aave_v1_import.js +54 -0
  10. package/dist/src/abi/connectors/v1/aave_v2.js +230 -0
  11. package/dist/src/abi/connectors/v1/aave_v2_import.js +59 -0
  12. package/dist/src/abi/connectors/v1/authority.js +100 -0
  13. package/dist/src/abi/connectors/v1/basic.js +136 -0
  14. package/dist/src/abi/connectors/v1/chi.js +36 -0
  15. package/dist/src/abi/connectors/v1/comp.js +4 -0
  16. package/dist/src/abi/connectors/v1/compound.js +4 -0
  17. package/dist/src/abi/connectors/v1/compoundImport.js +69 -0
  18. package/dist/src/abi/connectors/v1/compoundImport_v2.js +4 -0
  19. package/dist/src/abi/connectors/v1/compound_old.js +448 -0
  20. package/dist/src/abi/connectors/v1/curve.js +140 -0
  21. package/dist/src/abi/connectors/v1/curve_claim.js +63 -0
  22. package/dist/src/abi/connectors/v1/curve_gauge.js +158 -0
  23. package/dist/src/abi/connectors/v1/curve_sbtc.js +140 -0
  24. package/dist/src/abi/connectors/v1/curve_susd.js +140 -0
  25. package/dist/src/abi/connectors/v1/curve_three.js +79 -0
  26. package/dist/src/abi/connectors/v1/curve_y.js +140 -0
  27. package/dist/src/abi/connectors/v1/dsa_migrate_v1_to_v2.js +4 -0
  28. package/dist/src/abi/connectors/v1/dydx.js +148 -0
  29. package/dist/src/abi/connectors/v1/dydx_flash.js +52 -0
  30. package/dist/src/abi/connectors/v1/fee.js +50 -0
  31. package/dist/src/abi/connectors/v1/gelato.js +1138 -0
  32. package/dist/src/abi/connectors/v1/index.js +58 -0
  33. package/dist/src/abi/connectors/v1/instapool.js +439 -0
  34. package/dist/src/abi/connectors/v1/instapool_v2.js +126 -0
  35. package/dist/src/abi/connectors/v1/kyber.js +117 -0
  36. package/dist/src/abi/connectors/v1/maker.js +480 -0
  37. package/dist/src/abi/connectors/v1/maker_old.js +300 -0
  38. package/dist/src/abi/connectors/v1/math.js +43 -0
  39. package/dist/src/abi/connectors/v1/migrate.js +46 -0
  40. package/dist/src/abi/connectors/v1/oasis.js +198 -0
  41. package/dist/src/abi/connectors/v1/oneInch.js +160 -0
  42. package/dist/src/abi/connectors/v1/polygon_bridge.js +4 -0
  43. package/dist/src/abi/connectors/v1/refinance.js +4 -0
  44. package/dist/src/abi/connectors/v1/staking.js +220 -0
  45. package/dist/src/abi/connectors/v1/swerve.js +179 -0
  46. package/dist/src/abi/connectors/v1/uniswap.js +297 -0
  47. package/dist/src/abi/connectors/v2/1INCH-A.js +4 -0
  48. package/dist/src/abi/connectors/v2/1INCH-B.js +4 -0
  49. package/dist/src/abi/connectors/v2/AAVE-CLAIM-A.js +4 -0
  50. package/dist/src/abi/connectors/v2/AAVE-CLAIM-B.js +166 -0
  51. package/dist/src/abi/connectors/v2/AAVE-STAKE-A.js +4 -0
  52. package/dist/src/abi/connectors/v2/AAVE-V1-A.js +130 -0
  53. package/dist/src/abi/connectors/v2/AAVE-V1-IMPORT-A.js +4 -0
  54. package/dist/src/abi/connectors/v2/AAVE-V2-A.js +230 -0
  55. package/dist/src/abi/connectors/v2/AAVE-V2-IMPORT-A.js +4 -0
  56. package/dist/src/abi/connectors/v2/AAVE-V2-IMPORT-B.js +225 -0
  57. package/dist/src/abi/connectors/v2/AUTHORITY-A.js +100 -0
  58. package/dist/src/abi/connectors/v2/B-COMPOUND-A.js +4 -0
  59. package/dist/src/abi/connectors/v2/B-LIQUITY-A.js +4 -0
  60. package/dist/src/abi/connectors/v2/B-MAKERDAO-A.js +4 -0
  61. package/dist/src/abi/connectors/v2/BASIC-A.js +136 -0
  62. package/dist/src/abi/connectors/v2/BASIC-B.js +4 -0
  63. package/dist/src/abi/connectors/v2/BASIC-C.js +4 -0
  64. package/dist/src/abi/connectors/v2/COMP-A.js +4 -0
  65. package/dist/src/abi/connectors/v2/COMPOUND-A.js +4 -0
  66. package/dist/src/abi/connectors/v2/COMPOUND-IMPORT-A.js +4 -0
  67. package/dist/src/abi/connectors/v2/COMPOUND-IMPORT-B.js +195 -0
  68. package/dist/src/abi/connectors/v2/G-UNISWAP-A.js +4 -0
  69. package/dist/src/abi/connectors/v2/GELATO-AAVE-A.js +4 -0
  70. package/dist/src/abi/connectors/v2/INST-A.js +4 -0
  71. package/dist/src/abi/connectors/v2/INST-LM-A.js +4 -0
  72. package/dist/src/abi/connectors/v2/INST-STAKING-A.js +4 -0
  73. package/dist/src/abi/connectors/v2/INST-STAKING-B.js +4 -0
  74. package/dist/src/abi/connectors/v2/INSTAPOOL-A.js +4 -0
  75. package/dist/src/abi/connectors/v2/LIQUITY-A.js +4 -0
  76. package/dist/src/abi/connectors/v2/MAKERDAO-A.js +4 -0
  77. package/dist/src/abi/connectors/v2/MAKERDAO-CLAIM-A.js +136 -0
  78. package/dist/src/abi/connectors/v2/PARASWAP-A.js +4 -0
  79. package/dist/src/abi/connectors/v2/POLYGON-BRIDGE-A.js +4 -0
  80. package/dist/src/abi/connectors/v2/REFINANCE-A.js +4 -0
  81. package/dist/src/abi/connectors/v2/REFLEXER-A.js +4 -0
  82. package/dist/src/abi/connectors/v2/STAKE-ERC20-A.js +4 -0
  83. package/dist/src/abi/connectors/v2/UNISWAP-A.js +297 -0
  84. package/dist/src/abi/connectors/v2/UNISWAP-V2-A.js +4 -0
  85. package/dist/src/abi/connectors/v2/UNISWAP-V3-A.js +4 -0
  86. package/dist/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.js +4 -0
  87. package/dist/src/abi/connectors/v2/WETH-A.js +4 -0
  88. package/dist/src/abi/connectors/v2/YEARN-VAULT-A.js +4 -0
  89. package/dist/src/abi/connectors/v2/index.js +89 -0
  90. package/dist/src/abi/index.js +4 -4
  91. package/dist/src/abi/interopX.json +1436 -0
  92. package/dist/src/alias.js +10 -0
  93. package/dist/src/api/index.js +3 -0
  94. package/dist/src/config/index.js +10 -1
  95. package/dist/src/constants/addresses.js +4 -7
  96. package/dist/src/constants/index.js +0 -1
  97. package/dist/src/constants/tokens.js +62 -39
  98. package/dist/src/db/models/transaction.js +29 -11
  99. package/dist/src/gnosis/actions/aaveV2/index.js +11 -0
  100. package/dist/src/gnosis/actions/aaveV2/source.js +62 -0
  101. package/dist/src/gnosis/actions/aaveV2/target.js +8 -0
  102. package/dist/src/gnosis/actions/index.js +9 -0
  103. package/dist/src/gnosis/index.js +20 -0
  104. package/dist/src/index.js +34 -22
  105. package/dist/src/net/protocol/dial/SignatureDialProtocol.js +9 -10
  106. package/dist/src/net/protocol/dial/{SignatureDialProtocol.1.js → TransactionStatusDialProtocol.js} +2 -0
  107. package/dist/src/net/protocol/index.js +17 -7
  108. package/dist/src/tasks/AutoUpdateTask.js +6 -2
  109. package/dist/src/tasks/BaseTask.js +4 -0
  110. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +86 -0
  111. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +8 -3
  112. package/dist/src/tasks/index.js +9 -19
  113. package/dist/src/typechain/{InteropBridgeToken.js → InteropX.js} +0 -0
  114. package/dist/src/typechain/factories/InteropX__factory.js +1928 -0
  115. package/dist/src/typechain/factories/index.js +3 -5
  116. package/dist/src/typechain/index.js +3 -5
  117. package/dist/src/utils/index.js +96 -112
  118. package/package.json +16 -13
  119. package/src/abi/connectors/index.ts +14 -0
  120. package/src/abi/connectors/v1/aave.ts +147 -0
  121. package/src/abi/connectors/v1/aave_claim.ts +3 -0
  122. package/src/abi/connectors/v1/aave_migrate.ts +108 -0
  123. package/src/abi/connectors/v1/aave_polygon_migrate.ts +109 -0
  124. package/src/abi/connectors/v1/aave_stake.ts +3 -0
  125. package/src/abi/connectors/v1/aave_v1_import.ts +53 -0
  126. package/src/abi/connectors/v1/aave_v2.ts +229 -0
  127. package/src/abi/connectors/v1/aave_v2_import.ts +58 -0
  128. package/src/abi/connectors/v1/authority.ts +99 -0
  129. package/src/abi/connectors/v1/basic.ts +135 -0
  130. package/src/abi/connectors/v1/chi.ts +35 -0
  131. package/src/abi/connectors/v1/comp.ts +3 -0
  132. package/src/abi/connectors/v1/compound.ts +3 -0
  133. package/src/abi/connectors/v1/compoundImport.ts +68 -0
  134. package/src/abi/connectors/v1/compoundImport_v2.ts +3 -0
  135. package/src/abi/connectors/v1/compound_old.ts +447 -0
  136. package/src/abi/connectors/v1/curve.ts +139 -0
  137. package/src/abi/connectors/v1/curve_claim.ts +62 -0
  138. package/src/abi/connectors/v1/curve_gauge.ts +157 -0
  139. package/src/abi/connectors/v1/curve_sbtc.ts +139 -0
  140. package/src/abi/connectors/v1/curve_susd.ts +139 -0
  141. package/src/abi/connectors/v1/curve_three.ts +78 -0
  142. package/src/abi/connectors/v1/curve_y.ts +139 -0
  143. package/src/abi/connectors/v1/dsa_migrate_v1_to_v2.ts +3 -0
  144. package/src/abi/connectors/v1/dydx.ts +147 -0
  145. package/src/abi/connectors/v1/dydx_flash.ts +51 -0
  146. package/src/abi/connectors/v1/fee.ts +49 -0
  147. package/src/abi/connectors/v1/gelato.ts +1137 -0
  148. package/src/abi/connectors/v1/index.ts +42 -0
  149. package/src/abi/connectors/v1/instapool.ts +438 -0
  150. package/src/abi/connectors/v1/instapool_v2.ts +125 -0
  151. package/src/abi/connectors/v1/kyber.ts +116 -0
  152. package/src/abi/connectors/v1/maker.ts +479 -0
  153. package/src/abi/connectors/v1/maker_old.ts +299 -0
  154. package/src/abi/connectors/v1/math.ts +42 -0
  155. package/src/abi/connectors/v1/migrate.ts +45 -0
  156. package/src/abi/connectors/v1/oasis.ts +197 -0
  157. package/src/abi/connectors/v1/oneInch.ts +159 -0
  158. package/src/abi/connectors/v1/polygon_bridge.ts +3 -0
  159. package/src/abi/connectors/v1/refinance.ts +3 -0
  160. package/src/abi/connectors/v1/staking.ts +219 -0
  161. package/src/abi/connectors/v1/swerve.ts +178 -0
  162. package/src/abi/connectors/v1/uniswap.ts +297 -0
  163. package/src/abi/connectors/v2/1INCH-A.ts +3 -0
  164. package/src/abi/connectors/v2/1INCH-B.ts +3 -0
  165. package/src/abi/connectors/v2/AAVE-CLAIM-A.ts +3 -0
  166. package/src/abi/connectors/v2/AAVE-CLAIM-B.ts +165 -0
  167. package/src/abi/connectors/v2/AAVE-STAKE-A.ts +3 -0
  168. package/src/abi/connectors/v2/AAVE-V1-A.ts +130 -0
  169. package/src/abi/connectors/v2/AAVE-V1-IMPORT-A.ts +3 -0
  170. package/src/abi/connectors/v2/AAVE-V2-A.ts +229 -0
  171. package/src/abi/connectors/v2/AAVE-V2-IMPORT-A.ts +3 -0
  172. package/src/abi/connectors/v2/AAVE-V2-IMPORT-B.ts +224 -0
  173. package/src/abi/connectors/v2/AUTHORITY-A.ts +99 -0
  174. package/src/abi/connectors/v2/B-COMPOUND-A.ts +3 -0
  175. package/src/abi/connectors/v2/B-LIQUITY-A.ts +3 -0
  176. package/src/abi/connectors/v2/B-MAKERDAO-A.ts +3 -0
  177. package/src/abi/connectors/v2/BASIC-A.ts +135 -0
  178. package/src/abi/connectors/v2/BASIC-B.ts +3 -0
  179. package/src/abi/connectors/v2/BASIC-C.ts +3 -0
  180. package/src/abi/connectors/v2/COMP-A.ts +3 -0
  181. package/src/abi/connectors/v2/COMPOUND-A.ts +3 -0
  182. package/src/abi/connectors/v2/COMPOUND-IMPORT-A.ts +3 -0
  183. package/src/abi/connectors/v2/COMPOUND-IMPORT-B.ts +194 -0
  184. package/src/abi/connectors/v2/G-UNISWAP-A.ts +3 -0
  185. package/src/abi/connectors/v2/GELATO-AAVE-A.ts +3 -0
  186. package/src/abi/connectors/v2/INST-A.ts +3 -0
  187. package/src/abi/connectors/v2/INST-LM-A.ts +3 -0
  188. package/src/abi/connectors/v2/INST-STAKING-A.ts +3 -0
  189. package/src/abi/connectors/v2/INST-STAKING-B.ts +3 -0
  190. package/src/abi/connectors/v2/INSTAPOOL-A.ts +3 -0
  191. package/src/abi/connectors/v2/LIQUITY-A.ts +3 -0
  192. package/src/abi/connectors/v2/MAKERDAO-A.ts +3 -0
  193. package/src/abi/connectors/v2/MAKERDAO-CLAIM-A.ts +135 -0
  194. package/src/abi/connectors/v2/PARASWAP-A.ts +3 -0
  195. package/src/abi/connectors/v2/POLYGON-BRIDGE-A.ts +3 -0
  196. package/src/abi/connectors/v2/REFINANCE-A.ts +3 -0
  197. package/src/abi/connectors/v2/REFLEXER-A.ts +3 -0
  198. package/src/abi/connectors/v2/STAKE-ERC20-A.ts +3 -0
  199. package/src/abi/connectors/v2/UNISWAP-A.ts +297 -0
  200. package/src/abi/connectors/v2/UNISWAP-V2-A.ts +3 -0
  201. package/src/abi/connectors/v2/UNISWAP-V3-A.ts +3 -0
  202. package/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.ts +3 -0
  203. package/src/abi/connectors/v2/WETH-A.ts +3 -0
  204. package/src/abi/connectors/v2/YEARN-VAULT-A.ts +3 -0
  205. package/src/abi/connectors/v2/index.ts +87 -0
  206. package/src/abi/index.ts +7 -7
  207. package/src/abi/interopX.json +1436 -0
  208. package/src/alias.ts +6 -0
  209. package/src/api/index.ts +3 -0
  210. package/src/config/index.ts +9 -1
  211. package/src/constants/addresses.ts +5 -8
  212. package/src/constants/index.ts +0 -1
  213. package/src/constants/tokens.ts +63 -40
  214. package/src/db/models/transaction.ts +65 -25
  215. package/src/gnosis/actions/aaveV2/index.ts +9 -0
  216. package/src/gnosis/actions/aaveV2/source.ts +104 -0
  217. package/src/gnosis/actions/aaveV2/target.ts +13 -0
  218. package/src/gnosis/actions/index.ts +5 -0
  219. package/src/gnosis/index.ts +19 -0
  220. package/src/index.ts +47 -26
  221. package/src/net/protocol/dial/SignatureDialProtocol.ts +11 -13
  222. package/src/net/protocol/dial/{SignatureDialProtocol.1.ts → TransactionStatusDialProtocol.ts} +3 -1
  223. package/src/net/protocol/index.ts +17 -7
  224. package/src/tasks/AutoUpdateTask.ts +12 -9
  225. package/src/tasks/BaseTask.ts +5 -0
  226. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +138 -0
  227. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +8 -3
  228. package/src/tasks/index.ts +12 -22
  229. package/src/typechain/InteropX.ts +1216 -0
  230. package/src/typechain/factories/InteropX__factory.ts +1932 -0
  231. package/src/typechain/factories/index.ts +1 -2
  232. package/src/typechain/index.ts +2 -4
  233. package/src/utils/index.ts +229 -183
  234. package/tsconfig.json +7 -2
  235. package/dist/src/abi/interopBridgeToken.json +0 -286
  236. package/dist/src/abi/interopXGateway.json +0 -184
  237. package/dist/src/constants/itokens.js +0 -13
  238. package/dist/src/tasks/InteropBridge/ProcessWithdrawEvents.js +0 -146
  239. package/dist/src/tasks/InteropBridge/SyncWithdrawEvents.js +0 -69
  240. package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +0 -149
  241. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -74
  242. package/dist/src/typechain/InteropXGateway.js +0 -2
  243. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -459
  244. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  245. package/src/abi/interopBridgeToken.json +0 -286
  246. package/src/abi/interopXGateway.json +0 -184
  247. package/src/constants/itokens.ts +0 -10
  248. package/src/tasks/InteropBridge/ProcessWithdrawEvents.ts +0 -231
  249. package/src/tasks/InteropBridge/SyncWithdrawEvents.ts +0 -119
  250. package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +0 -243
  251. package/src/tasks/InteropXGateway/SyncDepositEvents.ts +0 -124
  252. package/src/typechain/InteropBridgeToken.ts +0 -686
  253. package/src/typechain/InteropXGateway.ts +0 -407
  254. package/src/typechain/factories/InteropBridgeToken__factory.ts +0 -466
  255. package/src/typechain/factories/InteropXGateway__factory.ts +0 -272
@@ -2,12 +2,13 @@ import { BaseDialProtocol } from "./BaseDialProtocol";
2
2
  import wait from "waait";
3
3
  import config from "@/config";
4
4
  import { Transaction } from "@/db";
5
- import { buildDataForTransaction, signGnosisSafeTx } from "@/utils";
5
+ import { signGnosisSafeTx } from "@/utils";
6
6
  import { addresses } from "@/constants";
7
7
  import { ChainId } from "@/types";
8
+ import { buildGnosisAction } from "@/gnosis";
8
9
 
9
10
  export interface ISignatureRequest {
10
- type: 'source' | 'target' ,
11
+ type: 'source' | 'target',
11
12
  transactionHash: string
12
13
  safeTxGas: string
13
14
  safeNonce: string
@@ -25,6 +26,10 @@ export class SignatureDialProtocol extends BaseDialProtocol<ISignatureRequest, I
25
26
  }
26
27
 
27
28
  async response(data: ISignatureRequest): Promise<ISignatureResponse> {
29
+ console.log({
30
+ tag: 'SignatureDialProtocol',
31
+ data
32
+ })
28
33
  const signer = config.wallet;
29
34
 
30
35
  let transaction: Transaction | null;
@@ -46,19 +51,12 @@ export class SignatureDialProtocol extends BaseDialProtocol<ISignatureRequest, I
46
51
  error: 'Event not found'
47
52
  };
48
53
  }
49
-
50
- console.log("signing:", {
51
- to: addresses[transaction.targetChainId].multisend,
52
- data: await buildDataForTransaction(transaction, data.type),
53
- chainId: transaction.targetChainId as ChainId,
54
- safeTxGas: data.safeTxGas,
55
- nonce: data.safeNonce,
56
- });
54
+ const { data: gnosisData } = await buildGnosisAction(transaction, data.type);
57
55
 
58
56
  const signedData = await signGnosisSafeTx({
59
- to: addresses[transaction.targetChainId].multisend,
60
- data: await buildDataForTransaction(transaction, data.type),
61
- chainId: transaction.targetChainId as ChainId,
57
+ to: addresses[transaction.sourceChainId].multisend,
58
+ data: gnosisData,
59
+ chainId: transaction.sourceChainId as ChainId,
62
60
  safeTxGas: data.safeTxGas,
63
61
  nonce: data.safeNonce,
64
62
  }, { signer });
@@ -1,7 +1,7 @@
1
1
  import { BaseDialProtocol } from "./BaseDialProtocol";
2
2
  import { Transaction } from "@/db";
3
3
 
4
- export class TransactionStatusDialProtocol extends BaseDialProtocol<string, Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'status'> | null> {
4
+ export class TransactionStatusDialProtocol extends BaseDialProtocol<string, Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'sourceLogs' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'targetLogs' | 'status'> | null> {
5
5
  protected timeout = 30000;
6
6
 
7
7
  constructor(libp2p) {
@@ -20,10 +20,12 @@ export class TransactionStatusDialProtocol extends BaseDialProtocol<string, Pick
20
20
  sourceStatus: transaction.sourceStatus,
21
21
  sourceTransactionHash: transaction.sourceTransactionHash,
22
22
  sourceErrors: transaction.sourceErrors,
23
+ sourceLogs: transaction.sourceLogs,
23
24
 
24
25
  targetStatus: transaction.targetStatus,
25
26
  targetTransactionHash: transaction.targetTransactionHash,
26
27
  targetErrors: transaction.targetErrors,
28
+ targetLogs: transaction.targetLogs,
27
29
 
28
30
  status: transaction.status,
29
31
  }
@@ -6,7 +6,7 @@ import { IPeerInfo, peerPool } from "..";
6
6
  import config from "@/config";
7
7
  import { Event } from "@/types";
8
8
  import { Transaction } from "@/db";
9
- import { TransactionStatusDialProtocol } from "./dial/SignatureDialProtocol.1";
9
+ import { TransactionStatusDialProtocol } from "./dial/TransactionStatusDialProtocol";
10
10
 
11
11
  export interface ProtocolOptions {
12
12
  /* Handshake timeout in ms (default: 8000) */
@@ -36,7 +36,7 @@ interface PeerInfoEvent extends BaseMessageEvent {
36
36
  }
37
37
 
38
38
  interface TransactionStatusEvent extends BaseMessageEvent {
39
- data: Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'status'>
39
+ data: Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'sourceLogs' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'targetLogs' | 'status'>
40
40
  }
41
41
 
42
42
  declare interface Protocol {
@@ -66,25 +66,35 @@ class Protocol extends EventEmitter {
66
66
  Buffer.from(transaction.transactionHash),
67
67
 
68
68
  Buffer.from(transaction.sourceStatus),
69
- Buffer.from(transaction.sourceTransactionHash),
69
+ Buffer.from(transaction.sourceTransactionHash || ''),
70
70
  transaction.sourceErrors ? transaction.sourceErrors.map((e) => Buffer.from(e)) : [],
71
+ transaction.sourceLogs ? transaction.sourceLogs.map((e) => [Buffer.from(e.type), Buffer.from(e.message)]) : [],
71
72
 
72
73
  Buffer.from(transaction.targetStatus),
73
- Buffer.from(transaction.targetTransactionHash),
74
+ Buffer.from(transaction.targetTransactionHash || ''),
74
75
  transaction.targetErrors ? transaction.targetErrors.map((e) => Buffer.from(e)) : [],
76
+ transaction.targetLogs ? transaction.targetLogs.map((e) => [Buffer.from(e.type), Buffer.from(e.message)]) : [],
75
77
 
76
78
  Buffer.from(transaction.status),
77
79
  ],
78
- decode: ([transactionHash, sourceStatus, sourceTransactionHash, sourceErrors, targetStatus, targetTransactionHash, targetErrors, status]: [Buffer, Buffer, Buffer, Buffer[], Buffer, Buffer, Buffer[], Buffer]) => ({
80
+ decode: ([transactionHash, sourceStatus, sourceTransactionHash, sourceErrors, sourceLogs, targetStatus, targetTransactionHash, targetErrors, targetLogs, status]: [Buffer, Buffer, Buffer, Buffer[],[Buffer,Buffer][], Buffer, Buffer, Buffer[],[Buffer,Buffer][], Buffer]) => ({
79
81
  transactionHash: transactionHash.toString(),
80
82
 
81
83
  sourceStatus: sourceStatus.toString(),
82
- sourceTransactionHash: sourceTransactionHash.toString(),
84
+ sourceTransactionHash: sourceTransactionHash.toString() || null,
83
85
  sourceErrors: sourceErrors.map((e) => e.toString()),
86
+ sourceLogs: sourceLogs.map(e => ({
87
+ type: e[0].toString(),
88
+ message: e[1].toString(),
89
+ })),
84
90
 
85
91
  targetStatus: targetStatus.toString(),
86
- targetTransactionHash: targetTransactionHash.toString(),
92
+ targetTransactionHash: targetTransactionHash.toString() || null,
87
93
  targetErrors: targetErrors.map((e) => e.toString()),
94
+ targetLogs: targetLogs.map(e => ({
95
+ type: e[0].toString(),
96
+ message: e[1].toString(),
97
+ })),
88
98
 
89
99
  status: status.toString(),
90
100
  }),
@@ -1,7 +1,7 @@
1
1
  import { BaseTask } from "./BaseTask";
2
2
  import Logger from '@/logger';
3
- import { http } from "@/utils";
4
- import spawn from 'await-spawn';
3
+ import spawnAsync from 'await-spawn';
4
+ import { spawn } from 'child_process'
5
5
  import config from "@/config";
6
6
  import wait from "waait";
7
7
  import packageJson from "../../package.json";
@@ -24,22 +24,20 @@ class AutoUpdateTask extends BaseTask {
24
24
 
25
25
  async getInstalledVersion() {
26
26
  try {
27
- const stdout = await spawn('npm', ['-g', 'ls', '--depth=0', '--json'])
27
+ const stdout = await spawnAsync('npm', ['-g', 'ls', '--depth=0', '--json'])
28
28
  return JSON.parse(stdout.toString()).dependencies[packageJson.name].version
29
29
  } catch (error) {
30
30
  this.logger.error(error)
31
-
32
31
  return currentVersion
33
32
  }
34
33
  }
35
34
 
36
35
  async getLatestVersion() {
37
36
  try {
38
- const stdout = await spawn('npm', ['view', `${packageJson.name}@${tag}`, 'version'])
37
+ const stdout = await spawnAsync('npm', ['view', `${packageJson.name}@${tag}`, 'version'])
39
38
  return stdout.toString().trim()
40
39
  } catch (error) {
41
40
  this.logger.error(error)
42
-
43
41
  return currentVersion
44
42
  }
45
43
  }
@@ -55,7 +53,7 @@ class AutoUpdateTask extends BaseTask {
55
53
 
56
54
  this.logger.info('Updating...')
57
55
 
58
- await spawn('npm', ['-g', 'install', `@instadapp/interop-x@${tag}`, '-f']);
56
+ await spawnAsync('npm', ['-g', 'install', `@instadapp/interop-x@${tag}`, '-f']);
59
57
 
60
58
  await wait(5000)
61
59
 
@@ -67,11 +65,16 @@ class AutoUpdateTask extends BaseTask {
67
65
  this.logger.warn(`Installed version ${version}`)
68
66
  this.logger.warn(`Restarting...`)
69
67
 
70
- spawn(process.argv[0], process.argv.slice(1), {
68
+
69
+ // TODO: its restarting in the bg, but it should be in the fg
70
+ const subprocess = spawn(process.argv[0], process.argv.slice(1), {
71
71
  cwd: process.cwd(),
72
- stdio: "inherit"
72
+ stdio: "inherit",
73
+ // shell: process.env.SHELL,
73
74
  });
74
75
 
76
+ subprocess.unref();
77
+
75
78
  process.exit()
76
79
  }
77
80
  }
@@ -46,6 +46,11 @@ export class BaseTask extends EventEmitter implements IBaseTask {
46
46
  }
47
47
 
48
48
  prePollHandler(): boolean {
49
+ if(config.isMaintenanceMode()){
50
+ this.logger.warn('Maintenance mode is enabled. Skipping task.')
51
+ return false
52
+ }
53
+
49
54
  if (this.exceptLeadNode) {
50
55
  return !config.isLeadNode();
51
56
  }
@@ -0,0 +1,138 @@
1
+ import { BaseTask } from "../BaseTask";
2
+ import Logger from "@/logger";
3
+ import { ethers } from "ethers";
4
+ import abi from "@/abi";
5
+ import { Transaction } from "@/db";
6
+ import {
7
+ generateInteropTransactionHash,
8
+ getContract,
9
+ getRpcProviderUrl,
10
+ } from "@/utils";
11
+ import { addresses } from "@/constants";
12
+ import { ChainId } from "@/types";
13
+ import config from "@/config";
14
+ import { InteropX } from "@/typechain";
15
+
16
+ class SyncLogSubmitEvents extends BaseTask {
17
+ contractAddress: string;
18
+ provider: ethers.providers.JsonRpcProvider;
19
+ contract: InteropX;
20
+ chainId: ChainId;
21
+
22
+ constructor({ chainId }: { chainId: ChainId }) {
23
+ super({
24
+ logger: new Logger("InteropX::SyncLogSubmitEvents"),
25
+ });
26
+ this.chainId = chainId;
27
+ }
28
+
29
+ async pollHandler() {
30
+ const currentBlock = await this.provider.getBlockNumber();
31
+
32
+ const events = await this.contract.queryFilter(
33
+ this.contract.filters.LogSubmit(),
34
+ currentBlock - 2000,
35
+ currentBlock
36
+ );
37
+
38
+ let processedEvents = 0;
39
+
40
+ for (const event of events) {
41
+ try {
42
+ if (!event.args) {
43
+ continue;
44
+ }
45
+
46
+ const {
47
+ position,
48
+ actionId,
49
+ actionIdHashHash,
50
+ sourceSender,
51
+ sourceDsaId,
52
+ targetDsaId,
53
+ sourceChainId,
54
+ targetChainId,
55
+ vnonce,
56
+ metadata,
57
+ } = event.args;
58
+
59
+ const uniqueIdentifier = {
60
+ actionId,
61
+ vnonce: vnonce.toString(),
62
+ sourceSender: sourceSender.toString(),
63
+ sourceChainId: sourceChainId.toNumber(),
64
+ targetChainId: targetChainId.toNumber(),
65
+ sourceDsaId: sourceDsaId.toString(),
66
+ targetDsaId: targetDsaId.toString(),
67
+ };
68
+
69
+ let transactionHash = generateInteropTransactionHash(uniqueIdentifier);
70
+
71
+ const transaction = await Transaction.findOne({
72
+ where: { transactionHash },
73
+ });
74
+
75
+ if (transaction) {
76
+ continue;
77
+ }
78
+
79
+ await Transaction.create({
80
+ transactionHash,
81
+ ...uniqueIdentifier,
82
+ submitChainId: this.chainId,
83
+ submitTransactionHash: event.transactionHash,
84
+ submitBlockNumber: event.blockNumber,
85
+ submitCreatedAt: new Date(),
86
+ submitEvent: {
87
+ actionId,
88
+ actionIdHashHash,
89
+ vnonce: vnonce.toString(),
90
+ position: {
91
+ withdraw: position.withdraw.map((v) => ({
92
+ sourceToken: v.sourceToken,
93
+ targetToken: v.targetToken,
94
+ amount: v.amount.toString(),
95
+ })),
96
+ supply: position.supply.map((v) => ({
97
+ sourceToken: v.sourceToken,
98
+ targetToken: v.targetToken,
99
+ amount: v.amount.toString(),
100
+ })),
101
+ },
102
+ sourceChainId: sourceChainId.toNumber(),
103
+ targetChainId: targetChainId.toNumber(),
104
+ sourceSender,
105
+ sourceDsaId: sourceDsaId.toString(),
106
+ targetDsaId: targetDsaId.toString(),
107
+ metadata,
108
+ },
109
+ });
110
+
111
+ this.logger.info(`New InteropX tranaction: ${transactionHash} `);
112
+ } catch (error) {
113
+ this.logger.error(error);
114
+ }
115
+ }
116
+
117
+ if (processedEvents > 0)
118
+ this.logger.info(`${processedEvents} events processed`);
119
+ }
120
+
121
+ async start(): Promise<void> {
122
+ this.contractAddress = addresses[this.chainId].interopX;
123
+
124
+ this.provider = new ethers.providers.JsonRpcProvider(
125
+ getRpcProviderUrl(this.chainId)
126
+ );
127
+
128
+ this.contract = getContract<InteropX>(
129
+ this.contractAddress,
130
+ abi.interopX,
131
+ new ethers.Wallet(config.privateKey!, this.provider)
132
+ );
133
+
134
+ await super.start();
135
+ }
136
+ }
137
+
138
+ export default SyncLogSubmitEvents;
@@ -20,14 +20,17 @@ class SyncTransactionStatusTask extends BaseTask {
20
20
  const leadNode = peerPool.getLeadPeer();
21
21
 
22
22
  if (!leadNode) {
23
+ console.log("No lead node found");
23
24
  return;
24
25
  }
25
26
 
26
27
  const transaction = await Transaction.findOne({
27
28
  where: {
28
- status: 'pending',
29
- sourceCreatedAt: {
30
- [Op.gte]: new Date(Date.now() - 60 * 60 * 1000),
29
+ status: {
30
+ [Op.notIn] : ['success', 'failed'],
31
+ },
32
+ createdAt: {
33
+ [Op.lt]: new Date(Date.now() - 15 * 60 * 1000),
31
34
  },
32
35
  }
33
36
  })
@@ -49,10 +52,12 @@ class SyncTransactionStatusTask extends BaseTask {
49
52
  transaction.sourceStatus = transactionStatus.sourceStatus
50
53
  transaction.sourceTransactionHash = transactionStatus.sourceTransactionHash
51
54
  transaction.sourceErrors = transactionStatus.sourceErrors
55
+ transaction.sourceLogs = transactionStatus.sourceLogs
52
56
 
53
57
  transaction.targetStatus = transactionStatus.targetStatus
54
58
  transaction.targetTransactionHash = transactionStatus.targetTransactionHash
55
59
  transaction.targetErrors = transactionStatus.targetErrors
60
+ transaction.targetLogs = transactionStatus.targetLogs
56
61
 
57
62
  transaction.status = transactionStatus.status
58
63
 
@@ -1,40 +1,30 @@
1
1
  import { BaseTask } from "./BaseTask";
2
- import InteropXGatewayProcessDepositEvents from "./InteropXGateway/ProcessDepositEvents";
3
- import InteropXGatewaySyncDepositEvents from "./InteropXGateway/SyncDepositEvents";
2
+ import wait from "waait";
4
3
 
5
- import InteropBridgeSyncWithdrawEvents from "./InteropBridge/SyncWithdrawEvents";
6
- import InteropBridgeProcessWithdrawEvents from "./InteropBridge/ProcessWithdrawEvents";
7
- import AutoUpdateTask from "./AutoUpdateTask";
8
4
  import SyncTransactionStatusTask from "./Transactions/SyncTransactionStatusTask";
9
5
 
6
+ import AutoUpdateTask from "./AutoUpdateTask";
7
+
8
+ import SyncLogSubmitEvents from "./InteropX/SyncLogSubmitEvents";
9
+
10
10
  export class Tasks {
11
-
11
+
12
12
  tasks: BaseTask[] = [
13
- new SyncTransactionStatusTask(),
13
+ // new SyncTransactionStatusTask(),
14
14
  new AutoUpdateTask(),
15
15
 
16
- new InteropXGatewaySyncDepositEvents({
17
- chainId: 43114
18
- }),
19
-
20
- new InteropXGatewayProcessDepositEvents({
21
- chainId: 43114
22
- }),
16
+ // InteropX
17
+ new SyncLogSubmitEvents({ chainId: 137 }),
18
+ new SyncLogSubmitEvents({ chainId: 43114 }),
23
19
 
24
- new InteropBridgeSyncWithdrawEvents({
25
- chainId: 137,
26
- itokenAddress: '0xEab02fe1F016eE3e4106c1C6aad35FeEe657268E',
27
- }),
28
-
29
- new InteropBridgeProcessWithdrawEvents({
30
- chainId: 137,
31
- })
20
+ new SyncTransactionStatusTask(),
32
21
  ];
33
22
 
34
23
  async start() {
35
24
  for (const task of this.tasks) {
36
25
  try {
37
26
  task.start();
27
+ await wait(1000)
38
28
  } catch (error) {
39
29
  console.error(`Error starting task: ${task.constructor.name}`);
40
30
  }