@instadapp/interop-x 0.0.0-dev.e69b5e8 → 0.0.0-dev.ee3d74b

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) 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/blockConfirmations.js +8 -0
  97. package/dist/src/constants/index.js +1 -1
  98. package/dist/src/constants/tokens.js +62 -39
  99. package/dist/src/db/models/transaction.js +29 -11
  100. package/dist/src/gnosis/actions/aaveV2/index.js +11 -0
  101. package/dist/src/gnosis/actions/aaveV2/source.js +62 -0
  102. package/dist/src/gnosis/actions/aaveV2/target.js +8 -0
  103. package/dist/src/gnosis/actions/index.js +9 -0
  104. package/dist/src/gnosis/index.js +20 -0
  105. package/dist/src/index.js +34 -22
  106. package/dist/src/net/protocol/dial/SignatureDialProtocol.js +9 -10
  107. package/dist/src/net/protocol/dial/{SignatureDialProtocol.1.js → TransactionStatusDialProtocol.js} +2 -0
  108. package/dist/src/net/protocol/index.js +17 -7
  109. package/dist/src/tasks/AutoUpdateTask.js +10 -7
  110. package/dist/src/tasks/BaseTask.js +4 -0
  111. package/dist/src/tasks/InteropX/ProcessSubmitSubmitEvents.js +168 -0
  112. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +86 -0
  113. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +8 -3
  114. package/dist/src/tasks/index.js +12 -19
  115. package/dist/src/typechain/{InteropBridgeToken.js → InteropX.js} +0 -0
  116. package/dist/src/typechain/factories/InteropX__factory.js +1928 -0
  117. package/dist/src/typechain/factories/index.js +3 -5
  118. package/dist/src/typechain/index.js +3 -5
  119. package/dist/src/utils/index.js +96 -112
  120. package/package.json +16 -13
  121. package/src/abi/connectors/index.ts +14 -0
  122. package/src/abi/connectors/v1/aave.ts +147 -0
  123. package/src/abi/connectors/v1/aave_claim.ts +3 -0
  124. package/src/abi/connectors/v1/aave_migrate.ts +108 -0
  125. package/src/abi/connectors/v1/aave_polygon_migrate.ts +109 -0
  126. package/src/abi/connectors/v1/aave_stake.ts +3 -0
  127. package/src/abi/connectors/v1/aave_v1_import.ts +53 -0
  128. package/src/abi/connectors/v1/aave_v2.ts +229 -0
  129. package/src/abi/connectors/v1/aave_v2_import.ts +58 -0
  130. package/src/abi/connectors/v1/authority.ts +99 -0
  131. package/src/abi/connectors/v1/basic.ts +135 -0
  132. package/src/abi/connectors/v1/chi.ts +35 -0
  133. package/src/abi/connectors/v1/comp.ts +3 -0
  134. package/src/abi/connectors/v1/compound.ts +3 -0
  135. package/src/abi/connectors/v1/compoundImport.ts +68 -0
  136. package/src/abi/connectors/v1/compoundImport_v2.ts +3 -0
  137. package/src/abi/connectors/v1/compound_old.ts +447 -0
  138. package/src/abi/connectors/v1/curve.ts +139 -0
  139. package/src/abi/connectors/v1/curve_claim.ts +62 -0
  140. package/src/abi/connectors/v1/curve_gauge.ts +157 -0
  141. package/src/abi/connectors/v1/curve_sbtc.ts +139 -0
  142. package/src/abi/connectors/v1/curve_susd.ts +139 -0
  143. package/src/abi/connectors/v1/curve_three.ts +78 -0
  144. package/src/abi/connectors/v1/curve_y.ts +139 -0
  145. package/src/abi/connectors/v1/dsa_migrate_v1_to_v2.ts +3 -0
  146. package/src/abi/connectors/v1/dydx.ts +147 -0
  147. package/src/abi/connectors/v1/dydx_flash.ts +51 -0
  148. package/src/abi/connectors/v1/fee.ts +49 -0
  149. package/src/abi/connectors/v1/gelato.ts +1137 -0
  150. package/src/abi/connectors/v1/index.ts +42 -0
  151. package/src/abi/connectors/v1/instapool.ts +438 -0
  152. package/src/abi/connectors/v1/instapool_v2.ts +125 -0
  153. package/src/abi/connectors/v1/kyber.ts +116 -0
  154. package/src/abi/connectors/v1/maker.ts +479 -0
  155. package/src/abi/connectors/v1/maker_old.ts +299 -0
  156. package/src/abi/connectors/v1/math.ts +42 -0
  157. package/src/abi/connectors/v1/migrate.ts +45 -0
  158. package/src/abi/connectors/v1/oasis.ts +197 -0
  159. package/src/abi/connectors/v1/oneInch.ts +159 -0
  160. package/src/abi/connectors/v1/polygon_bridge.ts +3 -0
  161. package/src/abi/connectors/v1/refinance.ts +3 -0
  162. package/src/abi/connectors/v1/staking.ts +219 -0
  163. package/src/abi/connectors/v1/swerve.ts +178 -0
  164. package/src/abi/connectors/v1/uniswap.ts +297 -0
  165. package/src/abi/connectors/v2/1INCH-A.ts +3 -0
  166. package/src/abi/connectors/v2/1INCH-B.ts +3 -0
  167. package/src/abi/connectors/v2/AAVE-CLAIM-A.ts +3 -0
  168. package/src/abi/connectors/v2/AAVE-CLAIM-B.ts +165 -0
  169. package/src/abi/connectors/v2/AAVE-STAKE-A.ts +3 -0
  170. package/src/abi/connectors/v2/AAVE-V1-A.ts +130 -0
  171. package/src/abi/connectors/v2/AAVE-V1-IMPORT-A.ts +3 -0
  172. package/src/abi/connectors/v2/AAVE-V2-A.ts +229 -0
  173. package/src/abi/connectors/v2/AAVE-V2-IMPORT-A.ts +3 -0
  174. package/src/abi/connectors/v2/AAVE-V2-IMPORT-B.ts +224 -0
  175. package/src/abi/connectors/v2/AUTHORITY-A.ts +99 -0
  176. package/src/abi/connectors/v2/B-COMPOUND-A.ts +3 -0
  177. package/src/abi/connectors/v2/B-LIQUITY-A.ts +3 -0
  178. package/src/abi/connectors/v2/B-MAKERDAO-A.ts +3 -0
  179. package/src/abi/connectors/v2/BASIC-A.ts +135 -0
  180. package/src/abi/connectors/v2/BASIC-B.ts +3 -0
  181. package/src/abi/connectors/v2/BASIC-C.ts +3 -0
  182. package/src/abi/connectors/v2/COMP-A.ts +3 -0
  183. package/src/abi/connectors/v2/COMPOUND-A.ts +3 -0
  184. package/src/abi/connectors/v2/COMPOUND-IMPORT-A.ts +3 -0
  185. package/src/abi/connectors/v2/COMPOUND-IMPORT-B.ts +194 -0
  186. package/src/abi/connectors/v2/G-UNISWAP-A.ts +3 -0
  187. package/src/abi/connectors/v2/GELATO-AAVE-A.ts +3 -0
  188. package/src/abi/connectors/v2/INST-A.ts +3 -0
  189. package/src/abi/connectors/v2/INST-LM-A.ts +3 -0
  190. package/src/abi/connectors/v2/INST-STAKING-A.ts +3 -0
  191. package/src/abi/connectors/v2/INST-STAKING-B.ts +3 -0
  192. package/src/abi/connectors/v2/INSTAPOOL-A.ts +3 -0
  193. package/src/abi/connectors/v2/LIQUITY-A.ts +3 -0
  194. package/src/abi/connectors/v2/MAKERDAO-A.ts +3 -0
  195. package/src/abi/connectors/v2/MAKERDAO-CLAIM-A.ts +135 -0
  196. package/src/abi/connectors/v2/PARASWAP-A.ts +3 -0
  197. package/src/abi/connectors/v2/POLYGON-BRIDGE-A.ts +3 -0
  198. package/src/abi/connectors/v2/REFINANCE-A.ts +3 -0
  199. package/src/abi/connectors/v2/REFLEXER-A.ts +3 -0
  200. package/src/abi/connectors/v2/STAKE-ERC20-A.ts +3 -0
  201. package/src/abi/connectors/v2/UNISWAP-A.ts +297 -0
  202. package/src/abi/connectors/v2/UNISWAP-V2-A.ts +3 -0
  203. package/src/abi/connectors/v2/UNISWAP-V3-A.ts +3 -0
  204. package/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.ts +3 -0
  205. package/src/abi/connectors/v2/WETH-A.ts +3 -0
  206. package/src/abi/connectors/v2/YEARN-VAULT-A.ts +3 -0
  207. package/src/abi/connectors/v2/index.ts +87 -0
  208. package/src/abi/index.ts +7 -7
  209. package/src/abi/interopX.json +1436 -0
  210. package/src/alias.ts +6 -0
  211. package/src/api/index.ts +3 -0
  212. package/src/config/index.ts +9 -1
  213. package/src/constants/addresses.ts +5 -8
  214. package/src/constants/blockConfirmations.ts +5 -0
  215. package/src/constants/index.ts +1 -1
  216. package/src/constants/tokens.ts +63 -40
  217. package/src/db/models/transaction.ts +65 -25
  218. package/src/gnosis/actions/aaveV2/index.ts +9 -0
  219. package/src/gnosis/actions/aaveV2/source.ts +104 -0
  220. package/src/gnosis/actions/aaveV2/target.ts +13 -0
  221. package/src/gnosis/actions/index.ts +5 -0
  222. package/src/gnosis/index.ts +19 -0
  223. package/src/index.ts +47 -26
  224. package/src/net/protocol/dial/SignatureDialProtocol.ts +12 -13
  225. package/src/net/protocol/dial/{SignatureDialProtocol.1.ts → TransactionStatusDialProtocol.ts} +3 -1
  226. package/src/net/protocol/index.ts +17 -7
  227. package/src/tasks/AutoUpdateTask.ts +14 -13
  228. package/src/tasks/BaseTask.ts +5 -0
  229. package/src/tasks/InteropX/ProcessSubmitSubmitEvents.ts +252 -0
  230. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +138 -0
  231. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +8 -3
  232. package/src/tasks/index.ts +15 -21
  233. package/src/typechain/InteropX.ts +1216 -0
  234. package/src/typechain/factories/InteropX__factory.ts +1932 -0
  235. package/src/typechain/factories/index.ts +1 -2
  236. package/src/typechain/index.ts +2 -4
  237. package/src/utils/index.ts +229 -183
  238. package/tsconfig.json +7 -2
  239. package/dist/src/abi/interopBridgeToken.json +0 -286
  240. package/dist/src/abi/interopXGateway.json +0 -184
  241. package/dist/src/constants/itokens.js +0 -13
  242. package/dist/src/tasks/InteropBridge/ProcessWithdrawEvents.js +0 -146
  243. package/dist/src/tasks/InteropBridge/SyncWithdrawEvents.js +0 -69
  244. package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +0 -149
  245. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -74
  246. package/dist/src/typechain/InteropXGateway.js +0 -2
  247. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -459
  248. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  249. package/src/abi/interopBridgeToken.json +0 -286
  250. package/src/abi/interopXGateway.json +0 -184
  251. package/src/constants/itokens.ts +0 -10
  252. package/src/tasks/InteropBridge/ProcessWithdrawEvents.ts +0 -231
  253. package/src/tasks/InteropBridge/SyncWithdrawEvents.ts +0 -119
  254. package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +0 -243
  255. package/src/tasks/InteropXGateway/SyncDepositEvents.ts +0 -124
  256. package/src/typechain/InteropBridgeToken.ts +0 -686
  257. package/src/typechain/InteropXGateway.ts +0 -407
  258. package/src/typechain/factories/InteropBridgeToken__factory.ts +0 -466
  259. package/src/typechain/factories/InteropXGateway__factory.ts +0 -272
package/src/index.ts CHANGED
@@ -1,21 +1,7 @@
1
- import moduleAlias from 'module-alias';
2
-
3
- moduleAlias.addAliases({
4
- "@/": __dirname + "/",
5
- "@/logger": __dirname + "/logger",
6
- "@/tasks": __dirname + "/tasks",
7
- "@/utils": __dirname + "/utils",
8
- "@/api": __dirname + "/api",
9
- "@/net": __dirname + "/net",
10
- "@/db": __dirname + "/db",
11
- "@/config": __dirname + "/config",
12
- "@/types": __dirname + "/types",
13
- "@/abi": __dirname + "/abi",
14
- "@/constants": __dirname + "/constants",
15
- "@/typechain": __dirname + "/typechain"
16
- })
1
+ import './alias'
2
+ import expandHomeDir from "expand-home-dir";
3
+ import fs from 'fs-extra'
17
4
 
18
- moduleAlias();
19
5
  import dotenv from "dotenv";
20
6
  import chalk from 'chalk';
21
7
  import { ethers } from "ethers";
@@ -25,12 +11,30 @@ dotenv.config();
25
11
  import Logger from "@/logger";
26
12
  const logger = new Logger('Process')
27
13
 
14
+ const GIT_SHORT_HASH = '@GIT_SHORT_HASH@';
15
+
28
16
  const printUsage = () => {
17
+ console.log()
18
+ console.log(`Interop X Node (v${packageJson.version} - rev.${GIT_SHORT_HASH})`)
19
+ console.log()
20
+
29
21
  console.log('Usage:')
30
- console.log(' PRIVATE_KEY=abcd1234 interop-x')
31
- console.log(' PRIVATE_KEY=abcd1234 STAGING=true interop-x')
32
- console.log(' PRIVATE_KEY=abcd1234 AUTO_UPDATE=true interop-x')
33
- console.log(' PRIVATE_KEY=abcd1234 API_HOST=0.0.0.0 API_PORT=8080 interop-x')
22
+ console.log(' interop-x help Show this message')
23
+ console.log(' interop-x version Print out the installed version of Interop X')
24
+
25
+ console.log()
26
+
27
+ console.log(' interop-x down Put the node into maintenance mode')
28
+ console.log(' interop-x up Take the node out of maintenance mode')
29
+
30
+ console.log()
31
+
32
+ console.log(' PRIVATE_KEY=abcd1234 interop-x Start the node with the given private key')
33
+ console.log(' PRIVATE_KEY=abcd1234 STAGING=true interop-x Start the node in staging mode')
34
+ console.log(' PRIVATE_KEY=abcd1234 AUTO_UPDATE=true interop-x Start the node in auto update mode')
35
+ console.log(' PRIVATE_KEY=abcd1234 API_HOST=0.0.0.0 API_PORT=8080 interop-x Start the node with custom API host and port')
36
+ console.log()
37
+
34
38
  }
35
39
 
36
40
  if (process.argv.at(-1) === 'help') {
@@ -38,14 +42,27 @@ if (process.argv.at(-1) === 'help') {
38
42
  process.exit(0)
39
43
  }
40
44
 
41
- const GIT_SHORT_HASH = '@GIT_SHORT_HASH@';
45
+ const basePath = expandHomeDir(`~/.interop-x`);
46
+
47
+ if (process.argv.at(-1) === 'down') {
48
+ fs.outputFileSync(basePath + '/maintenance', Date.now().toString())
49
+ console.log(chalk.red('Maintenance mode enabled'))
50
+ process.exit(0)
51
+ }
52
+
53
+ if (process.argv.at(-1) === 'up') {
54
+ fs.removeSync(basePath + '/maintenance')
55
+ console.log(chalk.green('Maintenance mode disabled'))
56
+ process.exit(0)
57
+ }
58
+
42
59
 
43
60
  if (process.argv.at(-1) === 'version') {
44
61
  console.log(`Interop X Node (v${packageJson.version} - rev.${GIT_SHORT_HASH})`)
45
62
  process.exit(0)
46
63
  }
47
64
 
48
- if(! process.env.PRIVATE_KEY) {
65
+ if (!process.env.PRIVATE_KEY) {
49
66
  console.error(chalk.bgRed.white.bold('Please provide a private key\n'))
50
67
  printUsage()
51
68
  process.exit(1)
@@ -72,7 +89,9 @@ async function main() {
72
89
 
73
90
  const tasks = new Tasks()
74
91
 
75
- tasks.start();
92
+ setTimeout(() => {
93
+ tasks.start();
94
+ }, 10000)
76
95
 
77
96
  startApiServer()
78
97
 
@@ -80,10 +99,10 @@ async function main() {
80
99
  if (!peerPool.isLeadNode(payload.peerId)) {
81
100
  const peer = peerPool.getPeer(payload.peerId)
82
101
 
83
- if(! peer) {
102
+ if (!peer) {
84
103
  return;
85
104
  }
86
-
105
+
87
106
  logger.info(`ignored transaction status from ${payload.peerId} ${shortenHash(peer.publicAddress)} `)
88
107
  return;
89
108
  }
@@ -97,10 +116,12 @@ async function main() {
97
116
  transaction.sourceStatus = payload.data.sourceStatus
98
117
  transaction.sourceTransactionHash = payload.data.sourceTransactionHash
99
118
  transaction.sourceErrors = payload.data.sourceErrors
119
+ transaction.sourceLogs = payload.data.sourceLogs
100
120
 
101
121
  transaction.targetStatus = payload.data.targetStatus
102
122
  transaction.targetTransactionHash = payload.data.targetTransactionHash
103
123
  transaction.targetErrors = payload.data.targetErrors
124
+ transaction.targetLogs = payload.data.targetLogs
104
125
 
105
126
  transaction.status = payload.data.status
106
127
 
@@ -2,15 +2,17 @@ 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
15
+ chainId: number
14
16
  }
15
17
  export interface ISignatureResponse {
16
18
  signer: string,
@@ -25,6 +27,10 @@ export class SignatureDialProtocol extends BaseDialProtocol<ISignatureRequest, I
25
27
  }
26
28
 
27
29
  async response(data: ISignatureRequest): Promise<ISignatureResponse> {
30
+ console.log({
31
+ tag: 'SignatureDialProtocol',
32
+ data
33
+ })
28
34
  const signer = config.wallet;
29
35
 
30
36
  let transaction: Transaction | null;
@@ -46,19 +52,12 @@ export class SignatureDialProtocol extends BaseDialProtocol<ISignatureRequest, I
46
52
  error: 'Event not found'
47
53
  };
48
54
  }
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
- });
55
+ const { data: gnosisData } = await buildGnosisAction(transaction, data.type);
57
56
 
58
57
  const signedData = await signGnosisSafeTx({
59
- to: addresses[transaction.targetChainId].multisend,
60
- data: await buildDataForTransaction(transaction, data.type),
61
- chainId: transaction.targetChainId as ChainId,
58
+ to: addresses[data.chainId].multisend,
59
+ data: gnosisData,
60
+ chainId: data.chainId as ChainId,
62
61
  safeTxGas: data.safeTxGas,
63
62
  nonce: data.safeNonce,
64
63
  }, { 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,15 +1,16 @@
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";
8
8
 
9
9
  const currentVersion = packageJson.version;
10
+ const tag = config.staging ? 'dev' : 'latest';
10
11
 
11
12
  class AutoUpdateTask extends BaseTask {
12
- pollIntervalMs: number = 60 * 5 * 1000
13
+ pollIntervalMs: number = 60 * 10 * 1000
13
14
 
14
15
  constructor() {
15
16
  super({
@@ -23,22 +24,20 @@ class AutoUpdateTask extends BaseTask {
23
24
 
24
25
  async getInstalledVersion() {
25
26
  try {
26
- const stdout = await spawn('npm', ['-g', 'ls', '--depth=0', '--json'])
27
+ const stdout = await spawnAsync('npm', ['-g', 'ls', '--depth=0', '--json'])
27
28
  return JSON.parse(stdout.toString()).dependencies[packageJson.name].version
28
29
  } catch (error) {
29
30
  this.logger.error(error)
30
-
31
31
  return currentVersion
32
32
  }
33
33
  }
34
34
 
35
35
  async getLatestVersion() {
36
36
  try {
37
- const stdout = await spawn('npm', ['view', packageJson.name, 'version'])
37
+ const stdout = await spawnAsync('npm', ['view', `${packageJson.name}@${tag}`, 'version'])
38
38
  return stdout.toString().trim()
39
39
  } catch (error) {
40
40
  this.logger.error(error)
41
-
42
41
  return currentVersion
43
42
  }
44
43
  }
@@ -52,12 +51,9 @@ class AutoUpdateTask extends BaseTask {
52
51
 
53
52
  this.logger.warn(`New version ${version} available.`)
54
53
 
55
-
56
54
  this.logger.info('Updating...')
57
55
 
58
- const spawner = spawn('npm', ['-g', 'install', '@instadapp/interop-x@latest', '-f']);
59
- spawner.child.on('data', console.log)
60
- await spawner
56
+ await spawnAsync('npm', ['-g', 'install', `@instadapp/interop-x@${tag}`, '-f']);
61
57
 
62
58
  await wait(5000)
63
59
 
@@ -69,11 +65,16 @@ class AutoUpdateTask extends BaseTask {
69
65
  this.logger.warn(`Installed version ${version}`)
70
66
  this.logger.warn(`Restarting...`)
71
67
 
72
- 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), {
73
71
  cwd: process.cwd(),
74
- stdio: "inherit"
72
+ stdio: "inherit",
73
+ // shell: process.env.SHELL,
75
74
  });
76
75
 
76
+ subprocess.unref();
77
+
77
78
  process.exit()
78
79
  }
79
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,252 @@
1
+ import { BaseTask } from "../BaseTask";
2
+ import Logger from "@/logger";
3
+ import { ethers, Wallet } from "ethers";
4
+ import abi from "@/abi";
5
+ import { Transaction } from "@/db";
6
+ import {
7
+ buildSignatureBytes,
8
+ generateGnosisTransaction,
9
+ generateInteropTransactionHash,
10
+ getContract,
11
+ getRpcProviderUrl,
12
+ LiquidityError,
13
+ Signature,
14
+ } from "@/utils";
15
+ import { addresses, blockConfirmations } from "@/constants";
16
+ import { ChainId } from "@/types";
17
+ import config from "@/config";
18
+ import { GnosisSafe, InteropX } from "@/typechain";
19
+ import moment from "moment";
20
+ import { Op } from "sequelize";
21
+ import { buildGnosisAction } from "@/gnosis";
22
+ import { peerPool, protocol } from "@/net";
23
+ import { LogDescription } from "ethers/lib/utils";
24
+ import wait from "waait";
25
+
26
+ class ProcessSubmitSubmitEvents extends BaseTask {
27
+ sourceProvider: ethers.providers.JsonRpcProvider;
28
+ sourceGnosisContract: GnosisSafe;
29
+ sourceWallet: Wallet;
30
+ chainId: ChainId;
31
+ leadNodeOnly: boolean = true;
32
+ blockConfirmationsCount: number = 12;
33
+
34
+ constructor({ chainId }: { chainId: ChainId }) {
35
+ super({
36
+ logger: new Logger("InteropX::ProcessSubmitSubmitEvents"),
37
+ });
38
+ this.chainId = chainId;
39
+ }
40
+
41
+ async pollHandler() {
42
+ const currentBlockNumber = await this.sourceProvider.getBlockNumber();
43
+
44
+ const transaction = await Transaction.findOne({
45
+ where: {
46
+ status: "pending",
47
+ sourceStatus: "pending",
48
+ sourceChainId: this.chainId,
49
+ submitBlockNumber: {
50
+ [Op.lt]: currentBlockNumber - this.blockConfirmationsCount,
51
+ },
52
+ sourceDelayUntil: {
53
+ [Op.or]: {
54
+ [Op.is]: null,
55
+ [Op.lt]: new Date(),
56
+ },
57
+ },
58
+
59
+ submitEvent: { $ne: null },
60
+
61
+ createdAt: {
62
+ [Op.gt]: moment().subtract({ hours: 12 }).toDate(),
63
+ },
64
+ },
65
+ });
66
+
67
+ if (!transaction) {
68
+ return;
69
+ }
70
+
71
+ transaction.sourceStatus = "proccessing";
72
+ await transaction.save();
73
+
74
+ const ownersThreshold = await this.sourceGnosisContract.getThreshold();
75
+ await wait(10000);
76
+
77
+ let data,
78
+ logs = [];
79
+
80
+ try {
81
+ ({ data, logs } = await buildGnosisAction(transaction, "source"));
82
+ } catch (error) {
83
+ if (error instanceof LiquidityError) {
84
+ await transaction.save();
85
+ transaction.sourceDelayUntil = new Date(Date.now() + 60 * 5 * 1000);
86
+ transaction.sourceStatus = "pending";
87
+
88
+ await transaction.save();
89
+
90
+ throw error;
91
+ return;
92
+ }
93
+
94
+ transaction.sourceStatus = "failed";
95
+ transaction.sourceErrors = [error.message];
96
+ transaction.targetStatus = "failed";
97
+
98
+ transaction.status = "failed";
99
+ await transaction.save();
100
+ protocol.sendTransaction(transaction);
101
+ return;
102
+ }
103
+
104
+ let gnosisTx = await generateGnosisTransaction(
105
+ {
106
+ baseGas: "0",
107
+ data,
108
+ gasPrice: "0",
109
+ gasToken: "0x0000000000000000000000000000000000000000",
110
+ nonce: "0",
111
+ operation: "1",
112
+ refundReceiver: "0x0000000000000000000000000000000000000000",
113
+ safeAddress: this.sourceGnosisContract.address,
114
+ safeTxGas: "79668",
115
+ to: addresses[transaction.sourceChainId].multisend,
116
+ value: "0",
117
+ },
118
+ this.sourceGnosisContract
119
+ );
120
+
121
+ const owners = await this.sourceGnosisContract
122
+ .getOwners()
123
+ .then((owners) => owners.map((owner) => owner.toLowerCase()));
124
+
125
+ const ownerPeerIds = peerPool.activePeers
126
+ .filter((peer) => owners.includes(peer.publicAddress.toLowerCase()))
127
+ .map((peer) => peer.id);
128
+
129
+ console.log(
130
+ `Collecting signatures for execution ${transaction.transactionHash}`
131
+ );
132
+
133
+ console.log(ownerPeerIds);
134
+
135
+ const signatures = await protocol.requestSignatures(
136
+ {
137
+ type: "source",
138
+ transactionHash: transaction.transactionHash,
139
+ safeTxGas: gnosisTx.safeTxGas,
140
+ safeNonce: gnosisTx.nonce,
141
+ chainId: this.chainId,
142
+ },
143
+ ownerPeerIds
144
+ );
145
+
146
+ const validSignatures = signatures.filter(
147
+ (s) => !!s.data && s.data !== "0x"
148
+ ) as Signature[];
149
+
150
+ console.log({
151
+ signatures,
152
+ validSignatures,
153
+ ownersThreshold: ownersThreshold.toString(),
154
+ });
155
+
156
+ if (
157
+ validSignatures.length === 0 ||
158
+ ownersThreshold.gt(validSignatures.length)
159
+ ) {
160
+ await transaction.save();
161
+ transaction.sourceDelayUntil = new Date(Date.now() + 30 * 1000);
162
+ transaction.sourceStatus = "pending";
163
+
164
+ await transaction.save();
165
+ const errorMessage = signatures.find((s) => !!s.error)?.error;
166
+ throw new Error(
167
+ `Not enough signatures` + (errorMessage ? `: ${errorMessage}` : "")
168
+ );
169
+ }
170
+
171
+ console.log(
172
+ `Executing transaction for execution ${transaction.transactionHash}`
173
+ );
174
+
175
+ const { data: txData } =
176
+ await this.sourceGnosisContract.populateTransaction.execTransaction(
177
+ gnosisTx.to,
178
+ gnosisTx.value,
179
+ gnosisTx.data,
180
+ gnosisTx.operation,
181
+ gnosisTx.safeTxGas,
182
+ gnosisTx.baseGas,
183
+ gnosisTx.gasPrice,
184
+ gnosisTx.gasToken,
185
+ gnosisTx.refundReceiver,
186
+ buildSignatureBytes(validSignatures)
187
+ );
188
+
189
+ const txSent = await this.sourceWallet.sendTransaction({
190
+ from: this.sourceWallet.address,
191
+ gasPrice: ethers.BigNumber.from(120 * 10 ** 9),
192
+ to: this.sourceGnosisContract.address,
193
+ data: txData,
194
+ });
195
+
196
+ console.log(txSent);
197
+
198
+ const receipt = await txSent.wait();
199
+
200
+ const parsedLogs: LogDescription[] = [];
201
+
202
+ receipt.logs.forEach((log) => {
203
+ try {
204
+ parsedLogs.push(this.sourceGnosisContract.interface.parseLog(log));
205
+ } catch (e) {}
206
+ });
207
+
208
+ if (parsedLogs.find((e) => e.name === "ExecutionSuccess")) {
209
+ console.log("ExecutionSuccess");
210
+ transaction.sourceStatus = "success";
211
+ if (txSent.blockNumber)
212
+ transaction.sourceBlockNumber = txSent.blockNumber;
213
+ transaction.sourceTransactionHash = txSent.hash;
214
+ transaction.sourceLogs = logs;
215
+ await transaction.save();
216
+ } else {
217
+ console.log("ExecutionFailure");
218
+ transaction.sourceStatus = "failed";
219
+ if (txSent.blockNumber)
220
+ transaction.sourceBlockNumber = txSent.blockNumber;
221
+ transaction.sourceTransactionHash = txSent.hash;
222
+ transaction.sourceTransactionHash = txSent.hash;
223
+ transaction.status = "failed";
224
+ await transaction.save();
225
+ }
226
+
227
+ protocol.sendTransaction(transaction);
228
+ }
229
+
230
+ async start(): Promise<void> {
231
+ this.blockConfirmationsCount = blockConfirmations[this.chainId] + 1;
232
+
233
+ this.sourceProvider = new ethers.providers.JsonRpcProvider(
234
+ getRpcProviderUrl(this.chainId)
235
+ );
236
+
237
+ this.sourceWallet = new ethers.Wallet(
238
+ config.privateKey!,
239
+ this.sourceProvider
240
+ );
241
+
242
+ this.sourceGnosisContract = getContract<GnosisSafe>(
243
+ addresses[this.chainId].gnosisSafe,
244
+ abi.gnosisSafe,
245
+ this.sourceWallet
246
+ );
247
+
248
+ await super.start();
249
+ }
250
+ }
251
+
252
+ export default ProcessSubmitSubmitEvents;