@instadapp/interop-x 0.0.0-dev.6d71015 → 0.0.0-dev.7283125

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 +21 -17
  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 +11 -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 +37 -15
  100. package/dist/src/gnosis/actions/aaveV2/index.js +11 -0
  101. package/dist/src/gnosis/actions/aaveV2/source.js +73 -0
  102. package/dist/src/gnosis/actions/aaveV2/target.js +85 -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 +75 -24
  106. package/dist/src/net/peer/index.js +2 -1
  107. package/dist/src/net/pool/index.js +18 -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 +51 -1
  111. package/dist/src/tasks/AutoUpdateTask.js +70 -0
  112. package/dist/src/tasks/BaseTask.js +11 -3
  113. package/dist/src/tasks/InteropX/ProcessSubmitSubmitEvents.js +179 -0
  114. package/dist/src/tasks/InteropX/ProcessValidateEvents.js +183 -0
  115. package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +87 -0
  116. package/dist/src/tasks/InteropX/SyncLogValidateEvents.js +105 -0
  117. package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +58 -0
  118. package/dist/src/tasks/index.js +20 -8
  119. package/dist/src/typechain/{InteropBridgeToken.js → InteropX.js} +0 -0
  120. package/dist/src/typechain/factories/InteropX__factory.js +1928 -0
  121. package/dist/src/typechain/factories/index.js +3 -5
  122. package/dist/src/typechain/index.js +3 -5
  123. package/dist/src/utils/index.js +111 -66
  124. package/package.json +21 -17
  125. package/src/abi/connectors/index.ts +14 -0
  126. package/src/abi/connectors/v1/aave.ts +147 -0
  127. package/src/abi/connectors/v1/aave_claim.ts +3 -0
  128. package/src/abi/connectors/v1/aave_migrate.ts +108 -0
  129. package/src/abi/connectors/v1/aave_polygon_migrate.ts +109 -0
  130. package/src/abi/connectors/v1/aave_stake.ts +3 -0
  131. package/src/abi/connectors/v1/aave_v1_import.ts +53 -0
  132. package/src/abi/connectors/v1/aave_v2.ts +229 -0
  133. package/src/abi/connectors/v1/aave_v2_import.ts +58 -0
  134. package/src/abi/connectors/v1/authority.ts +99 -0
  135. package/src/abi/connectors/v1/basic.ts +135 -0
  136. package/src/abi/connectors/v1/chi.ts +35 -0
  137. package/src/abi/connectors/v1/comp.ts +3 -0
  138. package/src/abi/connectors/v1/compound.ts +3 -0
  139. package/src/abi/connectors/v1/compoundImport.ts +68 -0
  140. package/src/abi/connectors/v1/compoundImport_v2.ts +3 -0
  141. package/src/abi/connectors/v1/compound_old.ts +447 -0
  142. package/src/abi/connectors/v1/curve.ts +139 -0
  143. package/src/abi/connectors/v1/curve_claim.ts +62 -0
  144. package/src/abi/connectors/v1/curve_gauge.ts +157 -0
  145. package/src/abi/connectors/v1/curve_sbtc.ts +139 -0
  146. package/src/abi/connectors/v1/curve_susd.ts +139 -0
  147. package/src/abi/connectors/v1/curve_three.ts +78 -0
  148. package/src/abi/connectors/v1/curve_y.ts +139 -0
  149. package/src/abi/connectors/v1/dsa_migrate_v1_to_v2.ts +3 -0
  150. package/src/abi/connectors/v1/dydx.ts +147 -0
  151. package/src/abi/connectors/v1/dydx_flash.ts +51 -0
  152. package/src/abi/connectors/v1/fee.ts +49 -0
  153. package/src/abi/connectors/v1/gelato.ts +1137 -0
  154. package/src/abi/connectors/v1/index.ts +42 -0
  155. package/src/abi/connectors/v1/instapool.ts +438 -0
  156. package/src/abi/connectors/v1/instapool_v2.ts +125 -0
  157. package/src/abi/connectors/v1/kyber.ts +116 -0
  158. package/src/abi/connectors/v1/maker.ts +479 -0
  159. package/src/abi/connectors/v1/maker_old.ts +299 -0
  160. package/src/abi/connectors/v1/math.ts +42 -0
  161. package/src/abi/connectors/v1/migrate.ts +45 -0
  162. package/src/abi/connectors/v1/oasis.ts +197 -0
  163. package/src/abi/connectors/v1/oneInch.ts +159 -0
  164. package/src/abi/connectors/v1/polygon_bridge.ts +3 -0
  165. package/src/abi/connectors/v1/refinance.ts +3 -0
  166. package/src/abi/connectors/v1/staking.ts +219 -0
  167. package/src/abi/connectors/v1/swerve.ts +178 -0
  168. package/src/abi/connectors/v1/uniswap.ts +297 -0
  169. package/src/abi/connectors/v2/1INCH-A.ts +3 -0
  170. package/src/abi/connectors/v2/1INCH-B.ts +3 -0
  171. package/src/abi/connectors/v2/AAVE-CLAIM-A.ts +3 -0
  172. package/src/abi/connectors/v2/AAVE-CLAIM-B.ts +165 -0
  173. package/src/abi/connectors/v2/AAVE-STAKE-A.ts +3 -0
  174. package/src/abi/connectors/v2/AAVE-V1-A.ts +130 -0
  175. package/src/abi/connectors/v2/AAVE-V1-IMPORT-A.ts +3 -0
  176. package/src/abi/connectors/v2/AAVE-V2-A.ts +229 -0
  177. package/src/abi/connectors/v2/AAVE-V2-IMPORT-A.ts +3 -0
  178. package/src/abi/connectors/v2/AAVE-V2-IMPORT-B.ts +224 -0
  179. package/src/abi/connectors/v2/AUTHORITY-A.ts +99 -0
  180. package/src/abi/connectors/v2/B-COMPOUND-A.ts +3 -0
  181. package/src/abi/connectors/v2/B-LIQUITY-A.ts +3 -0
  182. package/src/abi/connectors/v2/B-MAKERDAO-A.ts +3 -0
  183. package/src/abi/connectors/v2/BASIC-A.ts +135 -0
  184. package/src/abi/connectors/v2/BASIC-B.ts +3 -0
  185. package/src/abi/connectors/v2/BASIC-C.ts +3 -0
  186. package/src/abi/connectors/v2/COMP-A.ts +3 -0
  187. package/src/abi/connectors/v2/COMPOUND-A.ts +3 -0
  188. package/src/abi/connectors/v2/COMPOUND-IMPORT-A.ts +3 -0
  189. package/src/abi/connectors/v2/COMPOUND-IMPORT-B.ts +194 -0
  190. package/src/abi/connectors/v2/G-UNISWAP-A.ts +3 -0
  191. package/src/abi/connectors/v2/GELATO-AAVE-A.ts +3 -0
  192. package/src/abi/connectors/v2/INST-A.ts +3 -0
  193. package/src/abi/connectors/v2/INST-LM-A.ts +3 -0
  194. package/src/abi/connectors/v2/INST-STAKING-A.ts +3 -0
  195. package/src/abi/connectors/v2/INST-STAKING-B.ts +3 -0
  196. package/src/abi/connectors/v2/INSTAPOOL-A.ts +3 -0
  197. package/src/abi/connectors/v2/LIQUITY-A.ts +3 -0
  198. package/src/abi/connectors/v2/MAKERDAO-A.ts +3 -0
  199. package/src/abi/connectors/v2/MAKERDAO-CLAIM-A.ts +135 -0
  200. package/src/abi/connectors/v2/PARASWAP-A.ts +3 -0
  201. package/src/abi/connectors/v2/POLYGON-BRIDGE-A.ts +3 -0
  202. package/src/abi/connectors/v2/REFINANCE-A.ts +3 -0
  203. package/src/abi/connectors/v2/REFLEXER-A.ts +3 -0
  204. package/src/abi/connectors/v2/STAKE-ERC20-A.ts +3 -0
  205. package/src/abi/connectors/v2/UNISWAP-A.ts +297 -0
  206. package/src/abi/connectors/v2/UNISWAP-V2-A.ts +3 -0
  207. package/src/abi/connectors/v2/UNISWAP-V3-A.ts +3 -0
  208. package/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.ts +3 -0
  209. package/src/abi/connectors/v2/WETH-A.ts +3 -0
  210. package/src/abi/connectors/v2/YEARN-VAULT-A.ts +3 -0
  211. package/src/abi/connectors/v2/index.ts +87 -0
  212. package/src/abi/index.ts +7 -7
  213. package/src/abi/interopX.json +1436 -0
  214. package/src/alias.ts +6 -0
  215. package/src/api/index.ts +5 -2
  216. package/src/config/index.ts +11 -1
  217. package/src/constants/addresses.ts +5 -8
  218. package/src/constants/blockConfirmations.ts +5 -0
  219. package/src/constants/index.ts +1 -1
  220. package/src/constants/tokens.ts +63 -40
  221. package/src/db/models/transaction.ts +138 -65
  222. package/src/gnosis/actions/aaveV2/index.ts +9 -0
  223. package/src/gnosis/actions/aaveV2/source.ts +118 -0
  224. package/src/gnosis/actions/aaveV2/target.ts +132 -0
  225. package/src/gnosis/actions/index.ts +5 -0
  226. package/src/gnosis/index.ts +19 -0
  227. package/src/index.ts +96 -26
  228. package/src/net/peer/index.ts +2 -1
  229. package/src/net/pool/index.ts +25 -5
  230. package/src/net/protocol/dial/SignatureDialProtocol.ts +12 -13
  231. package/src/net/protocol/dial/TransactionStatusDialProtocol.ts +33 -0
  232. package/src/net/protocol/index.ts +67 -1
  233. package/src/tasks/AutoUpdateTask.ts +82 -0
  234. package/src/tasks/BaseTask.ts +13 -3
  235. package/src/tasks/InteropX/ProcessSubmitSubmitEvents.ts +269 -0
  236. package/src/tasks/InteropX/ProcessValidateEvents.ts +274 -0
  237. package/src/tasks/InteropX/SyncLogSubmitEvents.ts +139 -0
  238. package/src/tasks/InteropX/SyncLogValidateEvents.ts +152 -0
  239. package/src/tasks/Transactions/SyncTransactionStatusTask.ts +70 -0
  240. package/src/tasks/index.ts +28 -9
  241. package/src/typechain/InteropX.ts +1216 -0
  242. package/src/typechain/factories/InteropX__factory.ts +1932 -0
  243. package/src/typechain/factories/index.ts +1 -2
  244. package/src/typechain/index.ts +2 -4
  245. package/src/utils/index.ts +244 -117
  246. package/tsconfig.json +7 -2
  247. package/dist/src/abi/interopBridgeToken.json +0 -286
  248. package/dist/src/abi/interopXGateway.json +0 -184
  249. package/dist/src/constants/itokens.js +0 -13
  250. package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +0 -147
  251. package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +0 -75
  252. package/dist/src/typechain/InteropXGateway.js +0 -2
  253. package/dist/src/typechain/factories/InteropBridgeToken__factory.js +0 -459
  254. package/dist/src/typechain/factories/InteropXGateway__factory.js +0 -265
  255. package/src/abi/interopBridgeToken.json +0 -286
  256. package/src/abi/interopXGateway.json +0 -184
  257. package/src/constants/itokens.ts +0 -10
  258. package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +0 -241
  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/dist/src/index.js CHANGED
@@ -3,52 +3,103 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- const module_alias_1 = __importDefault(require("module-alias"));
7
- module_alias_1.default.addAliases({
8
- "@/": __dirname + "/",
9
- "@/logger": __dirname + "/logger",
10
- "@/tasks": __dirname + "/tasks",
11
- "@/utils": __dirname + "/utils",
12
- "@/api": __dirname + "/api",
13
- "@/net": __dirname + "/net",
14
- "@/db": __dirname + "/db",
15
- "@/config": __dirname + "/config",
16
- "@/types": __dirname + "/types",
17
- "@/abi": __dirname + "/abi",
18
- "@/constants": __dirname + "/constants",
19
- "@/typechain": __dirname + "/typechain"
20
- });
21
- (0, module_alias_1.default)();
22
- const assert_1 = __importDefault(require("assert"));
6
+ require("./alias");
7
+ const expand_home_dir_1 = __importDefault(require("expand-home-dir"));
8
+ const fs_extra_1 = __importDefault(require("fs-extra"));
23
9
  const dotenv_1 = __importDefault(require("dotenv"));
10
+ const chalk_1 = __importDefault(require("chalk"));
24
11
  const ethers_1 = require("ethers");
25
12
  const package_json_1 = __importDefault(require("../package.json"));
26
13
  dotenv_1.default.config();
27
14
  const logger_1 = __importDefault(require("@/logger"));
28
15
  const logger = new logger_1.default('Process');
29
- if (process.argv.at(-1) === 'help') {
16
+ const GIT_SHORT_HASH = '7283125';
17
+ const printUsage = () => {
18
+ console.log();
19
+ console.log(`Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
20
+ console.log();
30
21
  console.log('Usage:');
31
- console.log(' PRIVATE_KEY=abcd1234 interop-x');
32
- console.log(' PRIVATE_KEY=abcd1234 STAGING=true 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
+ console.log();
25
+ console.log(' interop-x down Put the node into maintenance mode');
26
+ console.log(' interop-x up Take the node out of maintenance mode');
27
+ console.log();
28
+ console.log(' PRIVATE_KEY=abcd1234 interop-x Start the node with the given private key');
29
+ console.log(' PRIVATE_KEY=abcd1234 STAGING=true interop-x Start the node in staging mode');
30
+ console.log(' PRIVATE_KEY=abcd1234 AUTO_UPDATE=true interop-x Start the node in auto update mode');
31
+ 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');
32
+ console.log();
33
+ };
34
+ if (process.argv.at(-1) === 'help') {
35
+ printUsage();
36
+ process.exit(0);
37
+ }
38
+ const basePath = (0, expand_home_dir_1.default)(`~/.interop-x`);
39
+ if (process.argv.at(-1) === 'down') {
40
+ fs_extra_1.default.outputFileSync(basePath + '/maintenance', Date.now().toString());
41
+ console.log(chalk_1.default.red('Maintenance mode enabled'));
33
42
  process.exit(0);
34
43
  }
35
- (0, assert_1.default)(process.env.PRIVATE_KEY, "PRIVATE_KEY is not defined");
44
+ if (process.argv.at(-1) === 'up') {
45
+ fs_extra_1.default.removeSync(basePath + '/maintenance');
46
+ console.log(chalk_1.default.green('Maintenance mode disabled'));
47
+ process.exit(0);
48
+ }
49
+ if (process.argv.at(-1) === 'version') {
50
+ console.log(`Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
51
+ process.exit(0);
52
+ }
53
+ if (!process.env.PRIVATE_KEY) {
54
+ console.error(chalk_1.default.bgRed.white.bold('Please provide a private key\n'));
55
+ printUsage();
56
+ process.exit(1);
57
+ }
36
58
  try {
37
59
  new ethers_1.ethers.Wallet(process.env.PRIVATE_KEY);
38
60
  }
39
61
  catch (e) {
40
- logger.error('Invalid private key');
62
+ console.error(chalk_1.default.bgRed.white('Invalid private key\n'));
63
+ printUsage();
41
64
  process.exit(1);
42
65
  }
43
- logger.debug(`Starting Interop X Node (v${package_json_1.default.version} - rev.6d71015)`);
66
+ logger.debug(`Starting Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
44
67
  const tasks_1 = require("@/tasks");
45
68
  const net_1 = require("@/net");
46
69
  const api_1 = require("@/api");
70
+ const db_1 = require("./db");
71
+ const utils_1 = require("./utils");
47
72
  async function main() {
48
73
  (0, net_1.startPeer)({});
49
74
  const tasks = new tasks_1.Tasks();
50
- tasks.start();
75
+ setTimeout(() => {
76
+ tasks.start();
77
+ }, 10000);
51
78
  (0, api_1.startApiServer)();
79
+ net_1.protocol.on('TransactionStatus', async (payload) => {
80
+ if (!net_1.peerPool.isLeadNode(payload.peerId)) {
81
+ const peer = net_1.peerPool.getPeer(payload.peerId);
82
+ if (!peer) {
83
+ return;
84
+ }
85
+ logger.info(`ignored transaction status from ${payload.peerId} ${(0, utils_1.shortenHash)(peer.publicAddress)} `);
86
+ return;
87
+ }
88
+ const transaction = await db_1.Transaction.findOne({ where: { transactionHash: payload.data.transactionHash } });
89
+ if (!transaction) {
90
+ return;
91
+ }
92
+ transaction.sourceStatus = payload.data.sourceStatus;
93
+ transaction.sourceTransactionHash = payload.data.sourceTransactionHash;
94
+ transaction.sourceErrors = payload.data.sourceErrors;
95
+ transaction.sourceLogs = payload.data.sourceLogs;
96
+ transaction.targetStatus = payload.data.targetStatus;
97
+ transaction.targetTransactionHash = payload.data.targetTransactionHash;
98
+ transaction.targetErrors = payload.data.targetErrors;
99
+ transaction.targetLogs = payload.data.targetLogs;
100
+ transaction.status = payload.data.status;
101
+ await transaction.save();
102
+ });
52
103
  }
53
104
  main()
54
105
  .then(() => {
@@ -23,6 +23,7 @@ const libp2p_kad_dht_1 = __importDefault(require("libp2p-kad-dht"));
23
23
  const libp2p_pubsub_peer_discovery_1 = __importDefault(require("libp2p-pubsub-peer-discovery"));
24
24
  const net_1 = require("@/net");
25
25
  const config_1 = __importDefault(require("@/config"));
26
+ const chalk_1 = __importDefault(require("chalk"));
26
27
  const logger = new logger_1.default("Peer");
27
28
  let node;
28
29
  // Known peers addresses
@@ -77,7 +78,7 @@ const startPeer = async ({}) => {
77
78
  persistence: true,
78
79
  },
79
80
  });
80
- logger.info("Peer ID:", node.peerId.toB58String());
81
+ logger.info("Peer ID:", chalk_1.default.bold(node.peerId.toB58String()));
81
82
  await node.start();
82
83
  net_1.protocol.start({
83
84
  libp2p: node
@@ -7,6 +7,9 @@ exports.peerPool = exports.PeerPool = void 0;
7
7
  const types_1 = require("@/types");
8
8
  const config_1 = __importDefault(require("@/config"));
9
9
  const logger_1 = __importDefault(require("@/logger"));
10
+ const utils_1 = require("ethers/lib/utils");
11
+ const utils_2 = require("@/utils");
12
+ const chalk_1 = __importDefault(require("chalk"));
10
13
  const logger = new logger_1.default('PeerPool');
11
14
  class PeerPool {
12
15
  constructor() {
@@ -70,7 +73,7 @@ class PeerPool {
70
73
  peer.pooled = true;
71
74
  if (newPeer) {
72
75
  config_1.default.events.emit(types_1.Event.POOL_PEER_ADDED, peer);
73
- logger.info(`Peer ${peer.id} with address ${peer.publicAddress} added to pool`);
76
+ logger.info(`Peer ${chalk_1.default.bold((0, utils_2.shortenHash)(peer.id, 16))} with address ${chalk_1.default.bold((0, utils_2.shortenHash)(peer.publicAddress))} added to pool`);
74
77
  }
75
78
  }
76
79
  }
@@ -84,7 +87,7 @@ class PeerPool {
84
87
  if (this.pool.delete(peer.id)) {
85
88
  peer.pooled = false;
86
89
  config_1.default.events.emit(types_1.Event.POOL_PEER_REMOVED, peer);
87
- logger.info(`Peer ${peer.id} with address ${peer.publicAddress} removed from pool`);
90
+ logger.info(`Peer ${chalk_1.default.bold((0, utils_2.shortenHash)(peer.id, 16))} with address ${chalk_1.default.bold((0, utils_2.shortenHash)(peer.publicAddress))} removed from pool`);
88
91
  }
89
92
  }
90
93
  }
@@ -100,6 +103,19 @@ class PeerPool {
100
103
  get activePeerIds() {
101
104
  return this.activePeers.map((p) => p.id);
102
105
  }
106
+ getPeer(id) {
107
+ return this.pool.get(id);
108
+ }
109
+ isLeadNode(id) {
110
+ const peer = this.pool.get(id);
111
+ if (!peer) {
112
+ return false;
113
+ }
114
+ return (0, utils_1.getAddress)(peer.publicAddress) === (0, utils_1.getAddress)(config_1.default.leadNodeAddress);
115
+ }
116
+ getLeadPeer() {
117
+ return this.peers.find((p) => this.isLeadNode(p.id));
118
+ }
103
119
  cleanup() {
104
120
  // let compDate = Date.now() - this.PEERS_CLEANUP_TIME_LIMIT * 60
105
121
  // this.peers.forEach((peerInfo) => {
@@ -10,12 +10,17 @@ const config_1 = __importDefault(require("@/config"));
10
10
  const db_1 = require("@/db");
11
11
  const utils_1 = require("@/utils");
12
12
  const constants_1 = require("@/constants");
13
+ const gnosis_1 = require("@/gnosis");
13
14
  class SignatureDialProtocol extends BaseDialProtocol_1.BaseDialProtocol {
14
15
  constructor(libp2p) {
15
16
  super(libp2p, '/interop-x/signatures');
16
17
  this.timeout = 30000;
17
18
  }
18
19
  async response(data) {
20
+ console.log({
21
+ tag: 'SignatureDialProtocol',
22
+ data
23
+ });
19
24
  const signer = config_1.default.wallet;
20
25
  let transaction;
21
26
  let maxTimeout = 20000;
@@ -33,17 +38,11 @@ class SignatureDialProtocol extends BaseDialProtocol_1.BaseDialProtocol {
33
38
  error: 'Event not found'
34
39
  };
35
40
  }
36
- console.log("signing:", {
37
- to: constants_1.addresses[transaction.targetChainId].multisend,
38
- data: await (0, utils_1.buildDataForTransaction)(transaction, data.type),
39
- chainId: transaction.targetChainId,
40
- safeTxGas: data.safeTxGas,
41
- nonce: data.safeNonce,
42
- });
41
+ const { data: gnosisData } = await (0, gnosis_1.buildGnosisAction)(transaction, data.type);
43
42
  const signedData = await (0, utils_1.signGnosisSafeTx)({
44
- to: constants_1.addresses[transaction.targetChainId].multisend,
45
- data: await (0, utils_1.buildDataForTransaction)(transaction, data.type),
46
- chainId: transaction.targetChainId,
43
+ to: constants_1.addresses[data.chainId].multisend,
44
+ data: gnosisData,
45
+ chainId: data.chainId,
47
46
  safeTxGas: data.safeTxGas,
48
47
  nonce: data.safeNonce,
49
48
  }, { signer });
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TransactionStatusDialProtocol = void 0;
4
+ const BaseDialProtocol_1 = require("./BaseDialProtocol");
5
+ const db_1 = require("@/db");
6
+ class TransactionStatusDialProtocol extends BaseDialProtocol_1.BaseDialProtocol {
7
+ constructor(libp2p) {
8
+ super(libp2p, '/interop-x/transaction-status');
9
+ this.timeout = 30000;
10
+ }
11
+ async response(transactionHash) {
12
+ const transaction = await db_1.Transaction.findOne({ where: { transactionHash } });
13
+ if (!transaction) {
14
+ return null;
15
+ }
16
+ return {
17
+ transactionHash: transaction.transactionHash,
18
+ sourceStatus: transaction.sourceStatus,
19
+ sourceTransactionHash: transaction.sourceTransactionHash,
20
+ sourceErrors: transaction.sourceErrors,
21
+ sourceLogs: transaction.sourceLogs,
22
+ targetStatus: transaction.targetStatus,
23
+ targetTransactionHash: transaction.targetTransactionHash,
24
+ targetErrors: transaction.targetErrors,
25
+ targetLogs: transaction.targetLogs,
26
+ status: transaction.status,
27
+ };
28
+ }
29
+ }
30
+ exports.TransactionStatusDialProtocol = TransactionStatusDialProtocol;
@@ -10,13 +10,14 @@ const SignatureDialProtocol_1 = require("./dial/SignatureDialProtocol");
10
10
  const __1 = require("..");
11
11
  const config_1 = __importDefault(require("@/config"));
12
12
  const types_1 = require("@/types");
13
+ const TransactionStatusDialProtocol_1 = require("./dial/TransactionStatusDialProtocol");
13
14
  class Protocol extends stream_1.EventEmitter {
14
15
  constructor() {
15
16
  super(...arguments);
16
17
  this.protocolMessages = [
17
18
  {
18
19
  name: 'PeerInfo',
19
- code: 0x09,
20
+ code: 0x01,
20
21
  encode: (info) => [
21
22
  Buffer.from(info.publicAddress),
22
23
  ],
@@ -24,6 +25,40 @@ class Protocol extends stream_1.EventEmitter {
24
25
  publicAddress: publicAddress.toString(),
25
26
  }),
26
27
  },
28
+ {
29
+ name: 'TransactionStatus',
30
+ code: 0x02,
31
+ encode: (transaction) => [
32
+ Buffer.from(transaction.transactionHash),
33
+ Buffer.from(transaction.sourceStatus),
34
+ Buffer.from(transaction.sourceTransactionHash || ''),
35
+ transaction.sourceErrors ? transaction.sourceErrors.map((e) => Buffer.from(e)) : [],
36
+ transaction.sourceLogs ? transaction.sourceLogs.map((e) => [Buffer.from(e.type), Buffer.from(e.message)]) : [],
37
+ Buffer.from(transaction.targetStatus),
38
+ Buffer.from(transaction.targetTransactionHash || ''),
39
+ transaction.targetErrors ? transaction.targetErrors.map((e) => Buffer.from(e)) : [],
40
+ transaction.targetLogs ? transaction.targetLogs.map((e) => [Buffer.from(e.type), Buffer.from(e.message)]) : [],
41
+ Buffer.from(transaction.status),
42
+ ],
43
+ decode: ([transactionHash, sourceStatus, sourceTransactionHash, sourceErrors, sourceLogs, targetStatus, targetTransactionHash, targetErrors, targetLogs, status]) => ({
44
+ transactionHash: transactionHash.toString(),
45
+ sourceStatus: sourceStatus.toString(),
46
+ sourceTransactionHash: sourceTransactionHash.toString() || null,
47
+ sourceErrors: sourceErrors.map((e) => e.toString()),
48
+ sourceLogs: sourceLogs.map(e => ({
49
+ type: e[0].toString(),
50
+ message: e[1].toString(),
51
+ })),
52
+ targetStatus: targetStatus.toString(),
53
+ targetTransactionHash: targetTransactionHash.toString() || null,
54
+ targetErrors: targetErrors.map((e) => e.toString()),
55
+ targetLogs: targetLogs.map(e => ({
56
+ type: e[0].toString(),
57
+ message: e[1].toString(),
58
+ })),
59
+ status: status.toString(),
60
+ }),
61
+ },
27
62
  ];
28
63
  }
29
64
  start({ libp2p, topic = null, }) {
@@ -40,6 +75,7 @@ class Protocol extends stream_1.EventEmitter {
40
75
  });
41
76
  });
42
77
  this.signature = new SignatureDialProtocol_1.SignatureDialProtocol(this.libp2p);
78
+ this.transactionStatus = new TransactionStatusDialProtocol_1.TransactionStatusDialProtocol(this.libp2p);
43
79
  }
44
80
  init() {
45
81
  this.libp2p.pubsub.subscribe(this.topic);
@@ -75,6 +111,11 @@ class Protocol extends stream_1.EventEmitter {
75
111
  const encoded = ethereumjs_util_1.rlp.encode([message.code, message.encode(data)]);
76
112
  this.libp2p.pubsub.publish(this.topic, encoded);
77
113
  }
114
+ sendTransaction(transaction) {
115
+ const message = this.protocolMessages.find((m) => m.name === 'TransactionStatus');
116
+ const encoded = ethereumjs_util_1.rlp.encode([message.code, message.encode(transaction)]);
117
+ this.libp2p.pubsub.publish(this.topic, encoded);
118
+ }
78
119
  async requestSignatures(data, peerIds) {
79
120
  try {
80
121
  peerIds = peerIds || __1.peerPool.activePeerIds;
@@ -88,5 +129,14 @@ class Protocol extends stream_1.EventEmitter {
88
129
  return [];
89
130
  }
90
131
  }
132
+ async requestTransactionStatus(transactionHash, peerId) {
133
+ try {
134
+ return await this.transactionStatus.send(transactionHash, peerId);
135
+ }
136
+ catch (error) {
137
+ console.log(error);
138
+ return null;
139
+ }
140
+ }
91
141
  }
92
142
  exports.protocol = new Protocol();
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const BaseTask_1 = require("./BaseTask");
7
+ const logger_1 = __importDefault(require("@/logger"));
8
+ const await_spawn_1 = __importDefault(require("await-spawn"));
9
+ const child_process_1 = require("child_process");
10
+ const config_1 = __importDefault(require("@/config"));
11
+ const waait_1 = __importDefault(require("waait"));
12
+ const package_json_1 = __importDefault(require("../../package.json"));
13
+ const currentVersion = package_json_1.default.version;
14
+ const tag = config_1.default.staging ? 'dev' : 'latest';
15
+ class AutoUpdateTask extends BaseTask_1.BaseTask {
16
+ constructor() {
17
+ super({
18
+ logger: new logger_1.default("AutoUpdateTask"),
19
+ });
20
+ this.pollIntervalMs = 60 * 10 * 1000;
21
+ }
22
+ prePollHandler() {
23
+ return config_1.default.autoUpdate && !config_1.default.isLeadNode();
24
+ }
25
+ async getInstalledVersion() {
26
+ try {
27
+ const stdout = await (0, await_spawn_1.default)('npm', ['-g', 'ls', '--depth=0', '--json']);
28
+ return JSON.parse(stdout.toString()).dependencies[package_json_1.default.name].version;
29
+ }
30
+ catch (error) {
31
+ this.logger.error(error);
32
+ return currentVersion;
33
+ }
34
+ }
35
+ async getLatestVersion() {
36
+ try {
37
+ const stdout = await (0, await_spawn_1.default)('npm', ['view', `${package_json_1.default.name}@${tag}`, 'version']);
38
+ return stdout.toString().trim();
39
+ }
40
+ catch (error) {
41
+ this.logger.error(error);
42
+ return currentVersion;
43
+ }
44
+ }
45
+ async pollHandler() {
46
+ const version = await this.getLatestVersion();
47
+ if (version === currentVersion) {
48
+ return;
49
+ }
50
+ this.logger.warn(`New version ${version} available.`);
51
+ this.logger.info('Updating...');
52
+ await (0, await_spawn_1.default)('npm', ['-g', 'install', `@instadapp/interop-x@${tag}`, '-f']);
53
+ await (0, waait_1.default)(5000);
54
+ if (version !== await this.getInstalledVersion()) {
55
+ this.logger.warn(`failed to install ${version}, retrying in 5 minutes`);
56
+ return;
57
+ }
58
+ this.logger.warn(`Installed version ${version}`);
59
+ this.logger.warn(`Restarting...`);
60
+ // TODO: its restarting in the bg, but it should be in the fg
61
+ const subprocess = (0, child_process_1.spawn)(process.argv[0], process.argv.slice(1), {
62
+ cwd: process.cwd(),
63
+ stdio: "inherit",
64
+ // shell: process.env.SHELL,
65
+ });
66
+ subprocess.unref();
67
+ process.exit();
68
+ }
69
+ }
70
+ exports.default = AutoUpdateTask;
@@ -14,6 +14,7 @@ class BaseTask extends events_1.default {
14
14
  this.started = false;
15
15
  this.pollIntervalMs = 10 * 1000;
16
16
  this.leadNodeOnly = false;
17
+ this.exceptLeadNode = false;
17
18
  this.logger = logger !== null && logger !== void 0 ? logger : new logger_1.default('BaseTask');
18
19
  }
19
20
  async pollCheck() {
@@ -34,10 +35,17 @@ class BaseTask extends events_1.default {
34
35
  }
35
36
  }
36
37
  prePollHandler() {
37
- if (!this.leadNodeOnly) {
38
- return true;
38
+ if (config_1.default.isMaintenanceMode()) {
39
+ this.logger.warn('Maintenance mode is enabled. Skipping task.');
40
+ return false;
39
41
  }
40
- return config_1.default.isLeadNode();
42
+ if (this.exceptLeadNode) {
43
+ return !config_1.default.isLeadNode();
44
+ }
45
+ if (this.leadNodeOnly) {
46
+ return config_1.default.isLeadNode();
47
+ }
48
+ return true;
41
49
  }
42
50
  async pollHandler() {
43
51
  this.logger.warn('pollHandler not implemented');
@@ -0,0 +1,179 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const BaseTask_1 = require("../BaseTask");
7
+ const logger_1 = __importDefault(require("@/logger"));
8
+ const ethers_1 = require("ethers");
9
+ const abi_1 = __importDefault(require("@/abi"));
10
+ const db_1 = require("@/db");
11
+ const utils_1 = require("@/utils");
12
+ const constants_1 = require("@/constants");
13
+ const config_1 = __importDefault(require("@/config"));
14
+ const moment_1 = __importDefault(require("moment"));
15
+ const sequelize_1 = require("sequelize");
16
+ const gnosis_1 = require("@/gnosis");
17
+ const net_1 = require("@/net");
18
+ const waait_1 = __importDefault(require("waait"));
19
+ class ProcessSubmitSubmitEvents extends BaseTask_1.BaseTask {
20
+ constructor({ chainId }) {
21
+ super({
22
+ logger: new logger_1.default("InteropX::ProcessSubmitSubmitEvents"),
23
+ });
24
+ this.leadNodeOnly = true;
25
+ this.blockConfirmationsCount = 12;
26
+ this.chainId = chainId;
27
+ }
28
+ async pollHandler() {
29
+ var _a;
30
+ const currentBlockNumber = await this.sourceProvider.getBlockNumber();
31
+ const transaction = await db_1.Transaction.findOne({
32
+ where: {
33
+ status: "pending",
34
+ sourceStatus: "pending",
35
+ sourceChainId: this.chainId,
36
+ submitBlockNumber: {
37
+ [sequelize_1.Op.lt]: currentBlockNumber - this.blockConfirmationsCount,
38
+ },
39
+ sourceDelayUntil: {
40
+ [sequelize_1.Op.or]: {
41
+ [sequelize_1.Op.is]: null,
42
+ [sequelize_1.Op.lt]: new Date(),
43
+ },
44
+ },
45
+ submitEvent: { $ne: null },
46
+ createdAt: {
47
+ [sequelize_1.Op.gt]: (0, moment_1.default)().subtract({ hours: 12 }).toDate(),
48
+ },
49
+ },
50
+ });
51
+ if (!transaction) {
52
+ return;
53
+ }
54
+ this.logger.debug(`Processing transaction ${transaction.transactionHash}`);
55
+ transaction.sourceStatus = "proccessing";
56
+ await transaction.save();
57
+ const ownersThreshold = await this.sourceGnosisContract.getThreshold();
58
+ await (0, waait_1.default)(10000);
59
+ this.logger.debug(`Build gnosis action for ${transaction.transactionHash}`);
60
+ let data, logs = [];
61
+ try {
62
+ ({ data, logs } = await (0, gnosis_1.buildGnosisAction)(transaction, "source"));
63
+ }
64
+ catch (error) {
65
+ if (error instanceof utils_1.LiquidityError) {
66
+ await transaction.save();
67
+ transaction.sourceDelayUntil = new Date(Date.now() + 60 * 5 * 1000);
68
+ transaction.sourceStatus = "pending";
69
+ await transaction.save();
70
+ throw error;
71
+ return;
72
+ }
73
+ transaction.sourceStatus = "failed";
74
+ transaction.sourceErrors = [error.message];
75
+ transaction.targetStatus = "failed";
76
+ transaction.status = "failed";
77
+ await transaction.save();
78
+ net_1.protocol.sendTransaction(transaction);
79
+ return;
80
+ }
81
+ this.logger.debug(`Generating gnosis tx for ${transaction.transactionHash}`);
82
+ let gnosisTx = await (0, utils_1.generateGnosisTransaction)({
83
+ baseGas: "0",
84
+ data,
85
+ gasPrice: "0",
86
+ gasToken: "0x0000000000000000000000000000000000000000",
87
+ nonce: "0",
88
+ operation: "1",
89
+ refundReceiver: "0x0000000000000000000000000000000000000000",
90
+ safeAddress: this.sourceGnosisContract.address,
91
+ safeTxGas: "79668",
92
+ to: constants_1.addresses[transaction.sourceChainId].multisend,
93
+ value: "0",
94
+ }, this.sourceGnosisContract);
95
+ const owners = await this.sourceGnosisContract
96
+ .getOwners()
97
+ .then((owners) => owners.map((owner) => owner.toLowerCase()));
98
+ const ownerPeerIds = net_1.peerPool.activePeers
99
+ .filter((peer) => owners.includes(peer.publicAddress.toLowerCase()))
100
+ .map((peer) => peer.id);
101
+ console.log(`Collecting signatures for execution ${transaction.transactionHash}`);
102
+ console.log(ownerPeerIds);
103
+ const signatures = await net_1.protocol.requestSignatures({
104
+ type: "source",
105
+ transactionHash: transaction.transactionHash,
106
+ safeTxGas: gnosisTx.safeTxGas,
107
+ safeNonce: gnosisTx.nonce,
108
+ chainId: this.chainId,
109
+ }, ownerPeerIds);
110
+ const validSignatures = signatures.filter((s) => !!s.data && s.data !== "0x");
111
+ console.log({
112
+ signatures,
113
+ validSignatures,
114
+ ownersThreshold: ownersThreshold.toString(),
115
+ });
116
+ if (validSignatures.length === 0 ||
117
+ ownersThreshold.gt(validSignatures.length)) {
118
+ await transaction.save();
119
+ transaction.sourceDelayUntil = new Date(Date.now() + 30 * 1000);
120
+ transaction.sourceStatus = "pending";
121
+ await transaction.save();
122
+ const errorMessage = (_a = signatures.find((s) => !!s.error)) === null || _a === void 0 ? void 0 : _a.error;
123
+ throw new Error(`Not enough signatures` + (errorMessage ? `: ${errorMessage}` : ""));
124
+ }
125
+ console.log(`Executing transaction for execution ${transaction.transactionHash}`);
126
+ const { data: txData } = await this.sourceGnosisContract.populateTransaction.execTransaction(gnosisTx.to, gnosisTx.value, gnosisTx.data, gnosisTx.operation, gnosisTx.safeTxGas, gnosisTx.baseGas, gnosisTx.gasPrice, gnosisTx.gasToken, gnosisTx.refundReceiver, (0, utils_1.buildSignatureBytes)(validSignatures));
127
+ const [gasPrice, gasLimit] = await Promise.all([
128
+ this.sourceProvider.getGasPrice(),
129
+ this.sourceProvider.estimateGas({
130
+ from: this.sourceWallet.address,
131
+ to: this.sourceGnosisContract.address,
132
+ data: txData,
133
+ }),
134
+ ]);
135
+ const txSent = await this.sourceWallet.sendTransaction({
136
+ from: this.sourceWallet.address,
137
+ to: this.sourceGnosisContract.address,
138
+ gasPrice: gasPrice.mul(120).div(100),
139
+ gasLimit: 5000000,
140
+ data: txData,
141
+ });
142
+ console.log(txSent);
143
+ const receipt = await txSent.wait();
144
+ const parsedLogs = [];
145
+ receipt.logs.forEach((log) => {
146
+ try {
147
+ parsedLogs.push(this.sourceGnosisContract.interface.parseLog(log));
148
+ }
149
+ catch (e) { }
150
+ });
151
+ if (parsedLogs.find((e) => e.name === "ExecutionSuccess")) {
152
+ console.log("ExecutionSuccess");
153
+ transaction.sourceStatus = "success";
154
+ if (txSent.blockNumber)
155
+ transaction.sourceBlockNumber = txSent.blockNumber;
156
+ transaction.sourceTransactionHash = txSent.hash;
157
+ transaction.sourceLogs = logs;
158
+ await transaction.save();
159
+ }
160
+ else {
161
+ console.log("ExecutionFailure");
162
+ transaction.sourceStatus = "failed";
163
+ if (txSent.blockNumber)
164
+ transaction.sourceBlockNumber = txSent.blockNumber;
165
+ transaction.sourceTransactionHash = txSent.hash;
166
+ transaction.status = "failed";
167
+ await transaction.save();
168
+ }
169
+ net_1.protocol.sendTransaction(transaction);
170
+ }
171
+ async start() {
172
+ this.blockConfirmationsCount = constants_1.blockConfirmations[this.chainId] + 1;
173
+ this.sourceProvider = new ethers_1.ethers.providers.JsonRpcProvider((0, utils_1.getRpcProviderUrl)(this.chainId));
174
+ this.sourceWallet = new ethers_1.ethers.Wallet(config_1.default.privateKey, this.sourceProvider);
175
+ this.sourceGnosisContract = (0, utils_1.getContract)(constants_1.addresses[this.chainId].gnosisSafe, abi_1.default.gnosisSafe, this.sourceWallet);
176
+ await super.start();
177
+ }
178
+ }
179
+ exports.default = ProcessSubmitSubmitEvents;