@instadapp/interop-x 0.0.0-dev.67e7c3a → 0.0.0-dev.6e9990f

Sign up to get free protection for your applications and to get access to all the features.
Files changed (263) hide show
  1. package/.github/workflows/ci.yml +19 -0
  2. package/dist/package.json +19 -15
  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 +6 -3
  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 +75 -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 +39 -23
  106. package/dist/src/net/peer/index.js +2 -1
  107. package/dist/src/net/pool/index.js +7 -2
  108. package/dist/src/net/protocol/dial/SignatureDialProtocol.js +9 -10
  109. package/dist/src/net/protocol/dial/TransactionStatusDialProtocol.js +30 -0
  110. package/dist/src/net/protocol/index.js +26 -5
  111. package/dist/src/tasks/AutoUpdateTask.js +42 -16
  112. package/dist/src/tasks/BaseTask.js +11 -3
  113. package/dist/src/tasks/InteropX/ProcessSubmitSubmitEvents.js +170 -0
  114. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +86 -0
  115. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +58 -0
  116. package/dist/src/tasks/index.js +12 -17
  117. package/dist/src/typechain/{InteropBridgeToken.js → InteropX.js} +0 -0
  118. package/dist/src/typechain/factories/InteropX__factory.js +1928 -0
  119. package/dist/src/typechain/factories/index.js +3 -5
  120. package/dist/src/typechain/index.js +3 -5
  121. package/dist/src/utils/index.js +107 -112
  122. package/package.json +19 -15
  123. package/src/abi/connectors/index.ts +14 -0
  124. package/src/abi/connectors/v1/aave.ts +147 -0
  125. package/src/abi/connectors/v1/aave_claim.ts +3 -0
  126. package/src/abi/connectors/v1/aave_migrate.ts +108 -0
  127. package/src/abi/connectors/v1/aave_polygon_migrate.ts +109 -0
  128. package/src/abi/connectors/v1/aave_stake.ts +3 -0
  129. package/src/abi/connectors/v1/aave_v1_import.ts +53 -0
  130. package/src/abi/connectors/v1/aave_v2.ts +229 -0
  131. package/src/abi/connectors/v1/aave_v2_import.ts +58 -0
  132. package/src/abi/connectors/v1/authority.ts +99 -0
  133. package/src/abi/connectors/v1/basic.ts +135 -0
  134. package/src/abi/connectors/v1/chi.ts +35 -0
  135. package/src/abi/connectors/v1/comp.ts +3 -0
  136. package/src/abi/connectors/v1/compound.ts +3 -0
  137. package/src/abi/connectors/v1/compoundImport.ts +68 -0
  138. package/src/abi/connectors/v1/compoundImport_v2.ts +3 -0
  139. package/src/abi/connectors/v1/compound_old.ts +447 -0
  140. package/src/abi/connectors/v1/curve.ts +139 -0
  141. package/src/abi/connectors/v1/curve_claim.ts +62 -0
  142. package/src/abi/connectors/v1/curve_gauge.ts +157 -0
  143. package/src/abi/connectors/v1/curve_sbtc.ts +139 -0
  144. package/src/abi/connectors/v1/curve_susd.ts +139 -0
  145. package/src/abi/connectors/v1/curve_three.ts +78 -0
  146. package/src/abi/connectors/v1/curve_y.ts +139 -0
  147. package/src/abi/connectors/v1/dsa_migrate_v1_to_v2.ts +3 -0
  148. package/src/abi/connectors/v1/dydx.ts +147 -0
  149. package/src/abi/connectors/v1/dydx_flash.ts +51 -0
  150. package/src/abi/connectors/v1/fee.ts +49 -0
  151. package/src/abi/connectors/v1/gelato.ts +1137 -0
  152. package/src/abi/connectors/v1/index.ts +42 -0
  153. package/src/abi/connectors/v1/instapool.ts +438 -0
  154. package/src/abi/connectors/v1/instapool_v2.ts +125 -0
  155. package/src/abi/connectors/v1/kyber.ts +116 -0
  156. package/src/abi/connectors/v1/maker.ts +479 -0
  157. package/src/abi/connectors/v1/maker_old.ts +299 -0
  158. package/src/abi/connectors/v1/math.ts +42 -0
  159. package/src/abi/connectors/v1/migrate.ts +45 -0
  160. package/src/abi/connectors/v1/oasis.ts +197 -0
  161. package/src/abi/connectors/v1/oneInch.ts +159 -0
  162. package/src/abi/connectors/v1/polygon_bridge.ts +3 -0
  163. package/src/abi/connectors/v1/refinance.ts +3 -0
  164. package/src/abi/connectors/v1/staking.ts +219 -0
  165. package/src/abi/connectors/v1/swerve.ts +178 -0
  166. package/src/abi/connectors/v1/uniswap.ts +297 -0
  167. package/src/abi/connectors/v2/1INCH-A.ts +3 -0
  168. package/src/abi/connectors/v2/1INCH-B.ts +3 -0
  169. package/src/abi/connectors/v2/AAVE-CLAIM-A.ts +3 -0
  170. package/src/abi/connectors/v2/AAVE-CLAIM-B.ts +165 -0
  171. package/src/abi/connectors/v2/AAVE-STAKE-A.ts +3 -0
  172. package/src/abi/connectors/v2/AAVE-V1-A.ts +130 -0
  173. package/src/abi/connectors/v2/AAVE-V1-IMPORT-A.ts +3 -0
  174. package/src/abi/connectors/v2/AAVE-V2-A.ts +229 -0
  175. package/src/abi/connectors/v2/AAVE-V2-IMPORT-A.ts +3 -0
  176. package/src/abi/connectors/v2/AAVE-V2-IMPORT-B.ts +224 -0
  177. package/src/abi/connectors/v2/AUTHORITY-A.ts +99 -0
  178. package/src/abi/connectors/v2/B-COMPOUND-A.ts +3 -0
  179. package/src/abi/connectors/v2/B-LIQUITY-A.ts +3 -0
  180. package/src/abi/connectors/v2/B-MAKERDAO-A.ts +3 -0
  181. package/src/abi/connectors/v2/BASIC-A.ts +135 -0
  182. package/src/abi/connectors/v2/BASIC-B.ts +3 -0
  183. package/src/abi/connectors/v2/BASIC-C.ts +3 -0
  184. package/src/abi/connectors/v2/COMP-A.ts +3 -0
  185. package/src/abi/connectors/v2/COMPOUND-A.ts +3 -0
  186. package/src/abi/connectors/v2/COMPOUND-IMPORT-A.ts +3 -0
  187. package/src/abi/connectors/v2/COMPOUND-IMPORT-B.ts +194 -0
  188. package/src/abi/connectors/v2/G-UNISWAP-A.ts +3 -0
  189. package/src/abi/connectors/v2/GELATO-AAVE-A.ts +3 -0
  190. package/src/abi/connectors/v2/INST-A.ts +3 -0
  191. package/src/abi/connectors/v2/INST-LM-A.ts +3 -0
  192. package/src/abi/connectors/v2/INST-STAKING-A.ts +3 -0
  193. package/src/abi/connectors/v2/INST-STAKING-B.ts +3 -0
  194. package/src/abi/connectors/v2/INSTAPOOL-A.ts +3 -0
  195. package/src/abi/connectors/v2/LIQUITY-A.ts +3 -0
  196. package/src/abi/connectors/v2/MAKERDAO-A.ts +3 -0
  197. package/src/abi/connectors/v2/MAKERDAO-CLAIM-A.ts +135 -0
  198. package/src/abi/connectors/v2/PARASWAP-A.ts +3 -0
  199. package/src/abi/connectors/v2/POLYGON-BRIDGE-A.ts +3 -0
  200. package/src/abi/connectors/v2/REFINANCE-A.ts +3 -0
  201. package/src/abi/connectors/v2/REFLEXER-A.ts +3 -0
  202. package/src/abi/connectors/v2/STAKE-ERC20-A.ts +3 -0
  203. package/src/abi/connectors/v2/UNISWAP-A.ts +297 -0
  204. package/src/abi/connectors/v2/UNISWAP-V2-A.ts +3 -0
  205. package/src/abi/connectors/v2/UNISWAP-V3-A.ts +3 -0
  206. package/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.ts +3 -0
  207. package/src/abi/connectors/v2/WETH-A.ts +3 -0
  208. package/src/abi/connectors/v2/YEARN-VAULT-A.ts +3 -0
  209. package/src/abi/connectors/v2/index.ts +87 -0
  210. package/src/abi/index.ts +7 -7
  211. package/src/abi/interopX.json +1436 -0
  212. package/src/alias.ts +6 -0
  213. package/src/api/index.ts +5 -2
  214. package/src/config/index.ts +9 -1
  215. package/src/constants/addresses.ts +5 -8
  216. package/src/constants/blockConfirmations.ts +5 -0
  217. package/src/constants/index.ts +1 -1
  218. package/src/constants/tokens.ts +63 -40
  219. package/src/db/models/transaction.ts +65 -25
  220. package/src/gnosis/actions/aaveV2/index.ts +9 -0
  221. package/src/gnosis/actions/aaveV2/source.ts +120 -0
  222. package/src/gnosis/actions/aaveV2/target.ts +13 -0
  223. package/src/gnosis/actions/index.ts +5 -0
  224. package/src/gnosis/index.ts +19 -0
  225. package/src/index.ts +52 -25
  226. package/src/net/peer/index.ts +2 -1
  227. package/src/net/pool/index.ts +7 -3
  228. package/src/net/protocol/dial/SignatureDialProtocol.ts +12 -13
  229. package/src/net/protocol/dial/TransactionStatusDialProtocol.ts +33 -0
  230. package/src/net/protocol/index.ts +28 -6
  231. package/src/tasks/AutoUpdateTask.ts +48 -20
  232. package/src/tasks/BaseTask.ts +13 -3
  233. package/src/tasks/InteropX/ProcessSubmitSubmitEvents.ts +259 -0
  234. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +138 -0
  235. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +70 -0
  236. package/src/tasks/index.ts +15 -19
  237. package/src/typechain/InteropX.ts +1216 -0
  238. package/src/typechain/factories/InteropX__factory.ts +1932 -0
  239. package/src/typechain/factories/index.ts +1 -2
  240. package/src/typechain/index.ts +2 -4
  241. package/src/utils/index.ts +240 -182
  242. package/tsconfig.json +7 -2
  243. package/dist/src/abi/interopBridgeToken.json +0 -286
  244. package/dist/src/abi/interopXGateway.json +0 -184
  245. package/dist/src/constants/itokens.js +0 -13
  246. package/dist/src/tasks/InteropBridge/ProcessWithdrawEvents.js +0 -147
  247. package/dist/src/tasks/InteropBridge/SyncWithdrawEvents.js +0 -70
  248. package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +0 -150
  249. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -75
  250. package/dist/src/typechain/InteropXGateway.js +0 -2
  251. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -459
  252. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  253. package/src/abi/interopBridgeToken.json +0 -286
  254. package/src/abi/interopXGateway.json +0 -184
  255. package/src/constants/itokens.ts +0 -10
  256. package/src/tasks/InteropBridge/ProcessWithdrawEvents.ts +0 -233
  257. package/src/tasks/InteropBridge/SyncWithdrawEvents.ts +0 -121
  258. package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +0 -245
  259. package/src/tasks/InteropXGateway/SyncDepositEvents.ts +0 -126
  260. package/src/typechain/InteropBridgeToken.ts +0 -686
  261. package/src/typechain/InteropXGateway.ts +0 -407
  262. package/src/typechain/factories/InteropBridgeToken__factory.ts +0 -466
  263. 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)
@@ -64,6 +81,7 @@ import { Tasks } from "@/tasks";
64
81
  import { startPeer, protocol, peerPool } from "@/net";
65
82
  import { startApiServer } from '@/api';
66
83
  import { Transaction } from './db';
84
+ import { shortenHash } from './utils';
67
85
 
68
86
  async function main() {
69
87
 
@@ -71,14 +89,21 @@ async function main() {
71
89
 
72
90
  const tasks = new Tasks()
73
91
 
74
- tasks.start();
92
+ setTimeout(() => {
93
+ tasks.start();
94
+ }, 10000)
75
95
 
76
96
  startApiServer()
77
97
 
78
98
  protocol.on('TransactionStatus', async (payload) => {
79
99
  if (!peerPool.isLeadNode(payload.peerId)) {
80
100
  const peer = peerPool.getPeer(payload.peerId)
81
- logger.info(`ignored transaction status from ${payload.peerId} ${peer?.publicAddress} `)
101
+
102
+ if (!peer) {
103
+ return;
104
+ }
105
+
106
+ logger.info(`ignored transaction status from ${payload.peerId} ${shortenHash(peer.publicAddress)} `)
82
107
  return;
83
108
  }
84
109
 
@@ -91,10 +116,12 @@ async function main() {
91
116
  transaction.sourceStatus = payload.data.sourceStatus
92
117
  transaction.sourceTransactionHash = payload.data.sourceTransactionHash
93
118
  transaction.sourceErrors = payload.data.sourceErrors
119
+ transaction.sourceLogs = payload.data.sourceLogs
94
120
 
95
121
  transaction.targetStatus = payload.data.targetStatus
96
122
  transaction.targetTransactionHash = payload.data.targetTransactionHash
97
123
  transaction.targetErrors = payload.data.targetErrors
124
+ transaction.targetLogs = payload.data.targetLogs
98
125
 
99
126
  transaction.status = payload.data.status
100
127
 
@@ -17,6 +17,7 @@ import KadDHT from "libp2p-kad-dht";
17
17
  import PubsubPeerDiscovery from "libp2p-pubsub-peer-discovery";
18
18
  import { protocol } from "@/net";
19
19
  import config from "@/config";
20
+ import chalk from "chalk";
20
21
 
21
22
  const logger = new Logger("Peer");
22
23
 
@@ -80,7 +81,7 @@ export const startPeer = async ({ }: IPeerOptions) => {
80
81
  },
81
82
  });
82
83
 
83
- logger.info("Peer ID:", node.peerId.toB58String());
84
+ logger.info("Peer ID:", chalk.bold(node.peerId.toB58String()));
84
85
 
85
86
  await node.start();
86
87
 
@@ -2,6 +2,8 @@ import { Event } from "@/types";
2
2
  import config from "@/config";
3
3
  import Logger from "@/logger";
4
4
  import { getAddress } from "ethers/lib/utils";
5
+ import { shortenHash } from "@/utils";
6
+ import chalk from "chalk";
5
7
 
6
8
 
7
9
  const logger = new Logger('PeerPool')
@@ -87,7 +89,7 @@ export class PeerPool {
87
89
 
88
90
  if (newPeer) {
89
91
  config.events.emit(Event.POOL_PEER_ADDED, peer)
90
- logger.info(`Peer ${peer.id} with address ${peer.publicAddress} added to pool`)
92
+ logger.info(`Peer ${chalk.bold(shortenHash(peer.id, 16))} with address ${chalk.bold(shortenHash(peer.publicAddress))} added to pool`)
91
93
  }
92
94
  }
93
95
  }
@@ -102,7 +104,7 @@ export class PeerPool {
102
104
  if (this.pool.delete(peer.id)) {
103
105
  peer.pooled = false
104
106
  config.events.emit(Event.POOL_PEER_REMOVED, peer)
105
- logger.info(`Peer ${peer.id} with address ${peer.publicAddress} removed from pool`)
107
+ logger.info(`Peer ${chalk.bold(shortenHash(peer.id, 16))} with address ${chalk.bold(shortenHash(peer.publicAddress))} removed from pool`)
106
108
  }
107
109
  }
108
110
  }
@@ -123,7 +125,6 @@ export class PeerPool {
123
125
  return this.activePeers.map((p) => p.id)
124
126
  }
125
127
 
126
-
127
128
  getPeer(id: string){
128
129
  return this.pool.get(id);
129
130
  }
@@ -138,6 +139,9 @@ export class PeerPool {
138
139
  return getAddress(peer.publicAddress) === getAddress(config.leadNodeAddress)
139
140
  }
140
141
 
142
+ getLeadPeer() {
143
+ return this.peers.find((p) => this.isLeadNode(p.id))
144
+ }
141
145
 
142
146
  cleanup() {
143
147
  // let compDate = Date.now() - this.PEERS_CLEANUP_TIME_LIMIT * 60
@@ -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 });
@@ -0,0 +1,33 @@
1
+ import { BaseDialProtocol } from "./BaseDialProtocol";
2
+ import { Transaction } from "@/db";
3
+
4
+ export class TransactionStatusDialProtocol extends BaseDialProtocol<string, Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'sourceLogs' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'targetLogs' | 'status'> | null> {
5
+ protected timeout = 30000;
6
+
7
+ constructor(libp2p) {
8
+ super(libp2p, '/interop-x/transaction-status')
9
+ }
10
+
11
+ async response(transactionHash: string){
12
+ const transaction = await Transaction.findOne({ where: { transactionHash } })
13
+
14
+ if(! transaction){
15
+ return null
16
+ }
17
+ return {
18
+ transactionHash: transaction.transactionHash,
19
+
20
+ sourceStatus: transaction.sourceStatus,
21
+ sourceTransactionHash: transaction.sourceTransactionHash,
22
+ sourceErrors: transaction.sourceErrors,
23
+ sourceLogs: transaction.sourceLogs,
24
+
25
+ targetStatus: transaction.targetStatus,
26
+ targetTransactionHash: transaction.targetTransactionHash,
27
+ targetErrors: transaction.targetErrors,
28
+ targetLogs: transaction.targetLogs,
29
+
30
+ status: transaction.status,
31
+ }
32
+ }
33
+ }
@@ -6,6 +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/TransactionStatusDialProtocol";
9
10
 
10
11
  export interface ProtocolOptions {
11
12
  /* Handshake timeout in ms (default: 8000) */
@@ -35,7 +36,7 @@ interface PeerInfoEvent extends BaseMessageEvent {
35
36
  }
36
37
 
37
38
  interface TransactionStatusEvent extends BaseMessageEvent {
38
- 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'>
39
40
  }
40
41
 
41
42
  declare interface Protocol {
@@ -65,31 +66,42 @@ class Protocol extends EventEmitter {
65
66
  Buffer.from(transaction.transactionHash),
66
67
 
67
68
  Buffer.from(transaction.sourceStatus),
68
- Buffer.from(transaction.sourceTransactionHash),
69
+ Buffer.from(transaction.sourceTransactionHash || ''),
69
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)]) : [],
70
72
 
71
73
  Buffer.from(transaction.targetStatus),
72
- Buffer.from(transaction.targetTransactionHash),
74
+ Buffer.from(transaction.targetTransactionHash || ''),
73
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)]) : [],
74
77
 
75
78
  Buffer.from(transaction.status),
76
79
  ],
77
- 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]) => ({
78
81
  transactionHash: transactionHash.toString(),
79
82
 
80
83
  sourceStatus: sourceStatus.toString(),
81
- sourceTransactionHash: sourceTransactionHash.toString(),
84
+ sourceTransactionHash: sourceTransactionHash.toString() || null,
82
85
  sourceErrors: sourceErrors.map((e) => e.toString()),
86
+ sourceLogs: sourceLogs.map(e => ({
87
+ type: e[0].toString(),
88
+ message: e[1].toString(),
89
+ })),
83
90
 
84
91
  targetStatus: targetStatus.toString(),
85
- targetTransactionHash: targetTransactionHash.toString(),
92
+ targetTransactionHash: targetTransactionHash.toString() || null,
86
93
  targetErrors: targetErrors.map((e) => e.toString()),
94
+ targetLogs: targetLogs.map(e => ({
95
+ type: e[0].toString(),
96
+ message: e[1].toString(),
97
+ })),
87
98
 
88
99
  status: status.toString(),
89
100
  }),
90
101
  },
91
102
  ];
92
103
  private signature: SignatureDialProtocol;
104
+ private transactionStatus: TransactionStatusDialProtocol;
93
105
 
94
106
 
95
107
  start({ libp2p, topic = null, }) {
@@ -109,6 +121,7 @@ class Protocol extends EventEmitter {
109
121
  })
110
122
 
111
123
  this.signature = new SignatureDialProtocol(this.libp2p);
124
+ this.transactionStatus = new TransactionStatusDialProtocol(this.libp2p);
112
125
  }
113
126
 
114
127
 
@@ -177,6 +190,15 @@ class Protocol extends EventEmitter {
177
190
  return []
178
191
  }
179
192
  }
193
+
194
+ async requestTransactionStatus(transactionHash: string, peerId: string) {
195
+ try {
196
+ return await this.transactionStatus.send(transactionHash, peerId);
197
+ } catch (error) {
198
+ console.log(error);
199
+ return null
200
+ }
201
+ }
180
202
  }
181
203
 
182
204
  export const protocol = new Protocol();
@@ -1,13 +1,16 @@
1
1
  import { BaseTask } from "./BaseTask";
2
2
  import Logger from '@/logger';
3
- import packageJson from '../../package.json'
4
- import { http } from "@/utils";
5
- import { spawn } from 'child_process';
3
+ import spawnAsync from 'await-spawn';
4
+ import { spawn } from 'child_process'
6
5
  import config from "@/config";
6
+ import wait from "waait";
7
+ import packageJson from "../../package.json";
8
+
7
9
  const currentVersion = packageJson.version;
10
+ const tag = config.staging ? 'dev' : 'latest';
8
11
 
9
12
  class AutoUpdateTask extends BaseTask {
10
- pollIntervalMs: number = 60 * 1000
13
+ pollIntervalMs: number = 60 * 10 * 1000
11
14
 
12
15
  constructor() {
13
16
  super({
@@ -15,16 +18,32 @@ class AutoUpdateTask extends BaseTask {
15
18
  })
16
19
  }
17
20
 
18
-
19
21
  prePollHandler(): boolean {
20
22
  return config.autoUpdate && !config.isLeadNode();
21
23
  }
22
24
 
23
- async pollHandler() {
25
+ async getInstalledVersion() {
26
+ try {
27
+ const stdout = await spawnAsync('npm', ['-g', 'ls', '--depth=0', '--json'])
28
+ return JSON.parse(stdout.toString()).dependencies[packageJson.name].version
29
+ } catch (error) {
30
+ this.logger.error(error)
31
+ return currentVersion
32
+ }
33
+ }
24
34
 
25
- const { data } = await http.get('https://registry.npmjs.org/@instadapp/interop-x')
35
+ async getLatestVersion() {
36
+ try {
37
+ const stdout = await spawnAsync('npm', ['view', `${packageJson.name}@${tag}`, 'version'])
38
+ return stdout.toString().trim()
39
+ } catch (error) {
40
+ this.logger.error(error)
41
+ return currentVersion
42
+ }
43
+ }
26
44
 
27
- const version = data['dist-tags'].latest
45
+ async pollHandler() {
46
+ const version = await this.getLatestVersion()
28
47
 
29
48
  if (version === currentVersion) {
30
49
  return;
@@ -32,22 +51,31 @@ class AutoUpdateTask extends BaseTask {
32
51
 
33
52
  this.logger.warn(`New version ${version} available.`)
34
53
 
54
+ this.logger.info('Updating...')
35
55
 
36
- const update = spawn('npm', ['-g', 'install', '@instadapp/interop-x']);
56
+ await spawnAsync('npm', ['-g', 'install', `@instadapp/interop-x@${tag}`, '-f']);
37
57
 
38
- update.on("close", () => {
39
- this.logger.warn(`Installed version ${version}`)
40
- this.logger.warn(`Restarting...`)
58
+ await wait(5000)
41
59
 
42
- spawn(process.argv[0], process.argv.slice(1), {
43
- cwd: process.cwd(),
44
- env: Object.create(process.env),
45
- detached: true,
46
- stdio: "inherit"
47
- });
60
+ if (version !== await this.getInstalledVersion()) {
61
+ this.logger.warn(`failed to install ${version}, retrying in 5 minutes`)
62
+ return;
63
+ }
48
64
 
49
- process.exit()
50
- })
65
+ this.logger.warn(`Installed version ${version}`)
66
+ this.logger.warn(`Restarting...`)
67
+
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
+ cwd: process.cwd(),
72
+ stdio: "inherit",
73
+ // shell: process.env.SHELL,
74
+ });
75
+
76
+ subprocess.unref();
77
+
78
+ process.exit()
51
79
  }
52
80
  }
53
81
 
@@ -19,6 +19,7 @@ export class BaseTask extends EventEmitter implements IBaseTask {
19
19
  started: boolean = false
20
20
  pollIntervalMs: number = 10 * 1000
21
21
  leadNodeOnly: boolean = false
22
+ exceptLeadNode: boolean = false
22
23
 
23
24
  public constructor({ logger }: { logger?: Logger }) {
24
25
  super()
@@ -45,11 +46,20 @@ export class BaseTask extends EventEmitter implements IBaseTask {
45
46
  }
46
47
 
47
48
  prePollHandler(): boolean {
48
- if (!this.leadNodeOnly) {
49
- return true
49
+ if(config.isMaintenanceMode()){
50
+ this.logger.warn('Maintenance mode is enabled. Skipping task.')
51
+ return false
50
52
  }
51
53
 
52
- return config.isLeadNode()
54
+ if (this.exceptLeadNode) {
55
+ return !config.isLeadNode();
56
+ }
57
+
58
+ if (this.leadNodeOnly) {
59
+ return config.isLeadNode()
60
+ }
61
+
62
+ return true
53
63
  }
54
64
 
55
65
  async pollHandler() {