@lidofinance/lsv-cli 1.0.0-alpha.5 → 1.0.0-alpha.51

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (586) hide show
  1. package/README.md +41 -20
  2. package/dist/abi/BlsHarness.d.ts +178 -0
  3. package/dist/abi/BlsHarness.js +232 -0
  4. package/dist/abi/BlsHarness.js.map +1 -0
  5. package/dist/abi/CLProofVerifier.d.ts +188 -0
  6. package/dist/abi/CLProofVerifier.js +247 -0
  7. package/dist/abi/CLProofVerifier.js.map +1 -0
  8. package/dist/abi/Dashboard.d.ts +1866 -0
  9. package/dist/abi/Dashboard.js +1924 -0
  10. package/dist/abi/Dashboard.js.map +1 -0
  11. package/dist/abi/LidoLocator.d.ts +330 -0
  12. package/dist/abi/LidoLocator.js +426 -0
  13. package/dist/abi/LidoLocator.js.map +1 -0
  14. package/dist/abi/OperatorGrid.d.ts +1075 -0
  15. package/dist/abi/OperatorGrid.js +1188 -0
  16. package/dist/abi/OperatorGrid.js.map +1 -0
  17. package/dist/abi/PredepositGuarantee.d.ts +1382 -0
  18. package/dist/abi/PredepositGuarantee.js +1789 -0
  19. package/dist/abi/PredepositGuarantee.js.map +1 -0
  20. package/dist/abi/ReportChecker.d.ts +83 -0
  21. package/dist/abi/ReportChecker.js +109 -0
  22. package/dist/abi/ReportChecker.js.map +1 -0
  23. package/dist/abi/StEth.d.ts +372 -0
  24. package/dist/abi/StEth.js +493 -0
  25. package/dist/abi/StEth.js.map +1 -0
  26. package/dist/abi/StakingVault.d.ts +1085 -0
  27. package/dist/abi/StakingVault.js +1115 -0
  28. package/dist/abi/StakingVault.js.map +1 -0
  29. package/dist/abi/TokenManager.d.ts +577 -0
  30. package/dist/abi/TokenManager.js +756 -0
  31. package/dist/abi/TokenManager.js.map +1 -0
  32. package/dist/abi/VaultFactory.d.ts +664 -0
  33. package/dist/abi/VaultFactory.js +213 -0
  34. package/dist/abi/VaultFactory.js.map +1 -0
  35. package/dist/abi/VaultHub.d.ts +1882 -0
  36. package/dist/abi/VaultHub.js +1259 -435
  37. package/dist/abi/VaultHub.js.map +1 -1
  38. package/dist/abi/VaultViewer.d.ts +223 -0
  39. package/dist/abi/VaultViewer.js +297 -0
  40. package/dist/abi/VaultViewer.js.map +1 -0
  41. package/dist/abi/Voting.d.ts +676 -0
  42. package/dist/abi/Voting.js +884 -0
  43. package/dist/abi/Voting.js.map +1 -0
  44. package/dist/abi/WstEth.d.ts +362 -0
  45. package/dist/abi/WstEth.js +478 -0
  46. package/dist/abi/WstEth.js.map +1 -0
  47. package/dist/abi/index.d.ts +15 -0
  48. package/dist/abi/index.js +17 -0
  49. package/dist/abi/index.js.map +1 -0
  50. package/dist/command/index.d.ts +2 -0
  51. package/dist/command/index.js +7 -5
  52. package/dist/command/index.js.map +1 -1
  53. package/dist/configs/constants.d.ts +34 -0
  54. package/dist/configs/constants.js +3 -0
  55. package/dist/configs/constants.js.map +1 -0
  56. package/dist/configs/deployed.d.ts +17 -0
  57. package/dist/configs/deployed.js +87 -52
  58. package/dist/configs/deployed.js.map +1 -1
  59. package/dist/configs/envs.d.ts +2 -0
  60. package/dist/configs/envs.js +13 -37
  61. package/dist/configs/envs.js.map +1 -1
  62. package/dist/configs/index.d.ts +3 -0
  63. package/dist/configs/index.js +3 -18
  64. package/dist/configs/index.js.map +1 -1
  65. package/dist/configs/utils.d.ts +4 -0
  66. package/dist/configs/utils.js +22 -0
  67. package/dist/configs/utils.js.map +1 -0
  68. package/dist/contracts/blsHarness.d.ts +947 -0
  69. package/dist/contracts/blsHarness.js +24 -0
  70. package/dist/contracts/blsHarness.js.map +1 -0
  71. package/dist/contracts/clProofVerifier.d.ts +2647 -0
  72. package/dist/contracts/clProofVerifier.js +23 -0
  73. package/dist/contracts/clProofVerifier.js.map +1 -0
  74. package/dist/contracts/dashboard.d.ts +4 -0
  75. package/dist/contracts/dashboard.js +11 -0
  76. package/dist/contracts/dashboard.js.map +1 -0
  77. package/dist/contracts/index.d.ts +15 -0
  78. package/dist/contracts/index.js +15 -17
  79. package/dist/contracts/index.js.map +1 -1
  80. package/dist/contracts/locator.d.ts +6935 -0
  81. package/dist/contracts/locator.js +16 -0
  82. package/dist/contracts/locator.js.map +1 -0
  83. package/dist/contracts/operator-grid.d.ts +3 -0
  84. package/dist/contracts/operator-grid.js +17 -0
  85. package/dist/contracts/operator-grid.js.map +1 -0
  86. package/dist/contracts/pdg.d.ts +3 -0
  87. package/dist/contracts/pdg.js +17 -0
  88. package/dist/contracts/pdg.js.map +1 -0
  89. package/dist/contracts/reportChecker.d.ts +758 -0
  90. package/dist/contracts/reportChecker.js +23 -0
  91. package/dist/contracts/reportChecker.js.map +1 -0
  92. package/dist/contracts/steth.d.ts +27706 -0
  93. package/dist/contracts/steth.js +18 -0
  94. package/dist/contracts/steth.js.map +1 -0
  95. package/dist/contracts/token-manager.d.ts +3 -0
  96. package/dist/contracts/token-manager.js +13 -0
  97. package/dist/contracts/token-manager.js.map +1 -0
  98. package/dist/contracts/vault-factory.d.ts +10742 -0
  99. package/dist/contracts/vault-factory.js +14 -0
  100. package/dist/contracts/vault-factory.js.map +1 -0
  101. package/dist/contracts/vault-hub.d.ts +3 -0
  102. package/dist/contracts/vault-hub.js +14 -16
  103. package/dist/contracts/vault-hub.js.map +1 -1
  104. package/dist/contracts/vault-viewer.d.ts +2681 -0
  105. package/dist/contracts/vault-viewer.js +23 -0
  106. package/dist/contracts/vault-viewer.js.map +1 -0
  107. package/dist/contracts/vault.d.ts +3 -0
  108. package/dist/contracts/vault.js +11 -0
  109. package/dist/contracts/vault.js.map +1 -0
  110. package/dist/contracts/voting.d.ts +6 -0
  111. package/dist/contracts/voting.js +19 -0
  112. package/dist/contracts/voting.js.map +1 -0
  113. package/dist/contracts/wsteth.d.ts +24690 -0
  114. package/dist/contracts/wsteth.js +18 -0
  115. package/dist/contracts/wsteth.js.map +1 -0
  116. package/dist/features/dashboard.d.ts +5 -0
  117. package/dist/features/dashboard.js +259 -0
  118. package/dist/features/dashboard.js.map +1 -0
  119. package/dist/features/index.d.ts +6 -0
  120. package/dist/features/index.js +7 -0
  121. package/dist/features/index.js.map +1 -0
  122. package/dist/features/operator-grid.d.ts +2 -0
  123. package/dist/features/operator-grid.js +64 -0
  124. package/dist/features/operator-grid.js.map +1 -0
  125. package/dist/features/pdg.d.ts +4 -0
  126. package/dist/features/pdg.js +116 -0
  127. package/dist/features/pdg.js.map +1 -0
  128. package/dist/features/token-manager.d.ts +1 -0
  129. package/dist/features/token-manager.js +7 -0
  130. package/dist/features/token-manager.js.map +1 -0
  131. package/dist/features/vault-factory.d.ts +13 -0
  132. package/dist/features/vault-factory.js +63 -0
  133. package/dist/features/vault-factory.js.map +1 -0
  134. package/dist/features/vault-hub.d.ts +2 -0
  135. package/dist/features/vault-hub.js +88 -0
  136. package/dist/features/vault-hub.js.map +1 -0
  137. package/dist/features/vault.d.ts +2 -0
  138. package/dist/features/vault.js +56 -0
  139. package/dist/features/vault.js.map +1 -0
  140. package/dist/index.d.ts +3 -0
  141. package/dist/index.js +8 -5
  142. package/dist/index.js.map +1 -1
  143. package/dist/programs/account/index.d.ts +3 -0
  144. package/dist/programs/account/index.js +4 -0
  145. package/dist/programs/account/index.js.map +1 -0
  146. package/dist/programs/account/main.d.ts +1 -0
  147. package/dist/programs/account/main.js +5 -0
  148. package/dist/programs/account/main.js.map +1 -0
  149. package/dist/programs/account/read.d.ts +1 -0
  150. package/dist/programs/account/read.js +109 -0
  151. package/dist/programs/account/read.js.map +1 -0
  152. package/dist/programs/account/write.d.ts +1 -0
  153. package/dist/programs/account/write.js +65 -0
  154. package/dist/programs/account/write.js.map +1 -0
  155. package/dist/programs/config.d.ts +1 -0
  156. package/dist/programs/config.js +31 -0
  157. package/dist/programs/config.js.map +1 -0
  158. package/dist/programs/dashboard/config.d.ts +2 -0
  159. package/dist/programs/dashboard/config.js +111 -0
  160. package/dist/programs/dashboard/config.js.map +1 -0
  161. package/dist/programs/dashboard/index.d.ts +3 -0
  162. package/dist/programs/dashboard/index.js +4 -0
  163. package/dist/programs/dashboard/index.js.map +1 -0
  164. package/dist/programs/dashboard/main.d.ts +1 -0
  165. package/dist/programs/dashboard/main.js +5 -0
  166. package/dist/programs/dashboard/main.js.map +1 -0
  167. package/dist/programs/dashboard/read.d.ts +1 -0
  168. package/dist/programs/dashboard/read.js +97 -0
  169. package/dist/programs/dashboard/read.js.map +1 -0
  170. package/dist/programs/dashboard/write.d.ts +1 -0
  171. package/dist/programs/dashboard/write.js +625 -0
  172. package/dist/programs/dashboard/write.js.map +1 -0
  173. package/dist/programs/hub/config.d.ts +2 -0
  174. package/dist/programs/hub/config.js +123 -0
  175. package/dist/programs/hub/config.js.map +1 -0
  176. package/dist/programs/hub/index.d.ts +3 -0
  177. package/dist/programs/hub/index.js +4 -0
  178. package/dist/programs/hub/index.js.map +1 -0
  179. package/dist/programs/hub/main.d.ts +1 -0
  180. package/dist/programs/hub/main.js +5 -0
  181. package/dist/programs/hub/main.js.map +1 -0
  182. package/dist/programs/hub/read.d.ts +1 -0
  183. package/dist/programs/hub/read.js +59 -0
  184. package/dist/programs/hub/read.js.map +1 -0
  185. package/dist/programs/hub/write.d.ts +1 -0
  186. package/dist/programs/hub/write.js +246 -0
  187. package/dist/programs/hub/write.js.map +1 -0
  188. package/dist/programs/index.d.ts +11 -0
  189. package/dist/programs/index.js +11 -17
  190. package/dist/programs/index.js.map +1 -1
  191. package/dist/programs/metrics/index.d.ts +2 -0
  192. package/dist/programs/metrics/index.js +3 -0
  193. package/dist/programs/metrics/index.js.map +1 -0
  194. package/dist/programs/metrics/main.d.ts +1 -0
  195. package/dist/programs/metrics/main.js +3 -0
  196. package/dist/programs/metrics/main.js.map +1 -0
  197. package/dist/programs/metrics/read.d.ts +1 -0
  198. package/dist/programs/metrics/read.js +110 -0
  199. package/dist/programs/metrics/read.js.map +1 -0
  200. package/dist/programs/operator-grid/config.d.ts +2 -0
  201. package/dist/programs/operator-grid/config.js +81 -0
  202. package/dist/programs/operator-grid/config.js.map +1 -0
  203. package/dist/programs/operator-grid/index.d.ts +3 -0
  204. package/dist/programs/operator-grid/index.js +4 -0
  205. package/dist/programs/operator-grid/index.js.map +1 -0
  206. package/dist/programs/operator-grid/main.d.ts +1 -0
  207. package/dist/programs/operator-grid/main.js +5 -0
  208. package/dist/programs/operator-grid/main.js.map +1 -0
  209. package/dist/programs/operator-grid/read.d.ts +1 -0
  210. package/dist/programs/operator-grid/read.js +30 -0
  211. package/dist/programs/operator-grid/read.js.map +1 -0
  212. package/dist/programs/operator-grid/write.d.ts +1 -0
  213. package/dist/programs/operator-grid/write.js +124 -0
  214. package/dist/programs/operator-grid/write.js.map +1 -0
  215. package/dist/programs/pdg/config.d.ts +2 -0
  216. package/dist/programs/pdg/config.js +134 -0
  217. package/dist/programs/pdg/config.js.map +1 -0
  218. package/dist/programs/pdg/index.d.ts +3 -0
  219. package/dist/programs/pdg/index.js +4 -0
  220. package/dist/programs/pdg/index.js.map +1 -0
  221. package/dist/programs/pdg/main.d.ts +1 -0
  222. package/dist/programs/pdg/main.js +5 -0
  223. package/dist/programs/pdg/main.js.map +1 -0
  224. package/dist/programs/pdg/read.d.ts +1 -0
  225. package/dist/programs/pdg/read.js +38 -0
  226. package/dist/programs/pdg/read.js.map +1 -0
  227. package/dist/programs/pdg/write.d.ts +1 -0
  228. package/dist/programs/pdg/write.js +370 -0
  229. package/dist/programs/pdg/write.js.map +1 -0
  230. package/dist/programs/pdg-helpers.d.ts +1 -0
  231. package/dist/programs/pdg-helpers.js +221 -0
  232. package/dist/programs/pdg-helpers.js.map +1 -0
  233. package/dist/programs/report/index.d.ts +3 -0
  234. package/dist/programs/report/index.js +4 -0
  235. package/dist/programs/report/index.js.map +1 -0
  236. package/dist/programs/report/main.d.ts +1 -0
  237. package/dist/programs/report/main.js +3 -0
  238. package/dist/programs/report/main.js.map +1 -0
  239. package/dist/programs/report/read.d.ts +1 -0
  240. package/dist/programs/report/read.js +93 -0
  241. package/dist/programs/report/read.js.map +1 -0
  242. package/dist/programs/report/write.d.ts +1 -0
  243. package/dist/programs/report/write.js +125 -0
  244. package/dist/programs/report/write.js.map +1 -0
  245. package/dist/programs/vault/config.d.ts +2 -0
  246. package/dist/programs/vault/config.js +70 -0
  247. package/dist/programs/vault/config.js.map +1 -0
  248. package/dist/programs/vault/index.d.ts +3 -0
  249. package/dist/programs/vault/index.js +4 -0
  250. package/dist/programs/vault/index.js.map +1 -0
  251. package/dist/programs/vault/main.d.ts +1 -0
  252. package/dist/programs/vault/main.js +3 -0
  253. package/dist/programs/vault/main.js.map +1 -0
  254. package/dist/programs/vault/read.d.ts +1 -0
  255. package/dist/programs/vault/read.js +25 -0
  256. package/dist/programs/vault/read.js.map +1 -0
  257. package/dist/programs/vault/write.d.ts +1 -0
  258. package/dist/programs/vault/write.js +247 -0
  259. package/dist/programs/vault/write.js.map +1 -0
  260. package/dist/programs/vault-factory/config.d.ts +2 -0
  261. package/dist/programs/vault-factory/config.js +2 -0
  262. package/dist/programs/vault-factory/config.js.map +1 -0
  263. package/dist/programs/vault-factory/index.d.ts +3 -0
  264. package/dist/programs/vault-factory/index.js +4 -0
  265. package/dist/programs/vault-factory/index.js.map +1 -0
  266. package/dist/programs/vault-factory/main.d.ts +1 -0
  267. package/dist/programs/vault-factory/main.js +5 -0
  268. package/dist/programs/vault-factory/main.js.map +1 -0
  269. package/dist/programs/vault-factory/read.d.ts +1 -0
  270. package/dist/programs/vault-factory/read.js +24 -0
  271. package/dist/programs/vault-factory/read.js.map +1 -0
  272. package/dist/programs/vault-factory/write.d.ts +1 -0
  273. package/dist/programs/vault-factory/write.js +86 -0
  274. package/dist/programs/vault-factory/write.js.map +1 -0
  275. package/dist/programs/vault-viewer/config.d.ts +2 -0
  276. package/dist/programs/vault-viewer/config.js +120 -0
  277. package/dist/programs/vault-viewer/config.js.map +1 -0
  278. package/dist/programs/vault-viewer/index.d.ts +2 -0
  279. package/dist/programs/vault-viewer/index.js +3 -0
  280. package/dist/programs/vault-viewer/index.js.map +1 -0
  281. package/dist/programs/vault-viewer/main.d.ts +1 -0
  282. package/dist/programs/vault-viewer/main.js +10 -0
  283. package/dist/programs/vault-viewer/main.js.map +1 -0
  284. package/dist/programs/vault-viewer/read.d.ts +1 -0
  285. package/dist/programs/vault-viewer/read.js +121 -0
  286. package/dist/programs/vault-viewer/read.js.map +1 -0
  287. package/dist/providers/index.d.ts +1 -0
  288. package/dist/providers/index.js +1 -17
  289. package/dist/providers/index.js.map +1 -1
  290. package/dist/providers/wallet.d.ts +6897 -0
  291. package/dist/providers/wallet.js +44 -28
  292. package/dist/providers/wallet.js.map +1 -1
  293. package/dist/tests/__mocks__/@lodestar/types.d.ts +1 -0
  294. package/dist/tests/__mocks__/@lodestar/types.js +6 -0
  295. package/dist/tests/__mocks__/@lodestar/types.js.map +1 -0
  296. package/dist/tests/utils/arguments.test.d.ts +1 -0
  297. package/dist/tests/utils/arguments.test.js +92 -0
  298. package/dist/tests/utils/arguments.test.js.map +1 -0
  299. package/dist/tests/utils/calculate-overview.test.d.ts +1 -0
  300. package/dist/tests/utils/calculate-overview.test.js +30 -0
  301. package/dist/tests/utils/calculate-overview.test.js.map +1 -0
  302. package/dist/tests/utils/data-validators.test.d.ts +1 -0
  303. package/dist/tests/utils/data-validators.test.js +56 -0
  304. package/dist/tests/utils/data-validators.test.js.map +1 -0
  305. package/dist/tests/utils/error-handler.test.d.ts +1 -0
  306. package/dist/tests/utils/error-handler.test.js +51 -0
  307. package/dist/tests/utils/error-handler.test.js.map +1 -0
  308. package/dist/tests/utils/fetchCL.test.d.ts +1 -0
  309. package/dist/tests/utils/fetchCL.test.js +57 -0
  310. package/dist/tests/utils/fetchCL.test.js.map +1 -0
  311. package/dist/tests/utils/get-commands.test.d.ts +1 -0
  312. package/dist/tests/utils/get-commands.test.js +19 -0
  313. package/dist/tests/utils/get-commands.test.js.map +1 -0
  314. package/dist/tests/utils/get-deposit-data-root.test.d.ts +1 -0
  315. package/dist/tests/utils/get-deposit-data-root.test.js +31 -0
  316. package/dist/tests/utils/get-deposit-data-root.test.js.map +1 -0
  317. package/dist/tests/utils/get-value.test.d.ts +1 -0
  318. package/dist/tests/utils/get-value.test.js +13 -0
  319. package/dist/tests/utils/get-value.test.js.map +1 -0
  320. package/dist/tests/utils/health.test.d.ts +1 -0
  321. package/dist/tests/utils/health.test.js +22 -0
  322. package/dist/tests/utils/health.test.js.map +1 -0
  323. package/dist/tests/utils/interrupt-handler.test.d.ts +1 -0
  324. package/dist/tests/utils/interrupt-handler.test.js +15 -0
  325. package/dist/tests/utils/interrupt-handler.test.js.map +1 -0
  326. package/dist/tests/utils/ipfs.test.d.ts +1 -0
  327. package/dist/tests/utils/ipfs.test.js +98 -0
  328. package/dist/tests/utils/ipfs.test.js.map +1 -0
  329. package/dist/tests/utils/logging.test.d.ts +1 -0
  330. package/dist/tests/utils/logging.test.js +23 -0
  331. package/dist/tests/utils/logging.test.js.map +1 -0
  332. package/dist/tests/utils/report-proof.test.d.ts +1 -0
  333. package/dist/tests/utils/report-proof.test.js +29 -0
  334. package/dist/tests/utils/report-proof.test.js.map +1 -0
  335. package/dist/tests/utils/report-statistic.test.d.ts +1 -0
  336. package/dist/tests/utils/report-statistic.test.js +247 -0
  337. package/dist/tests/utils/report-statistic.test.js.map +1 -0
  338. package/dist/tests/utils/required-lock.test.d.ts +1 -0
  339. package/dist/tests/utils/required-lock.test.js +26 -0
  340. package/dist/tests/utils/required-lock.test.js.map +1 -0
  341. package/dist/tests/utils/resove-path.test.d.ts +1 -0
  342. package/dist/tests/utils/resove-path.test.js +18 -0
  343. package/dist/tests/utils/resove-path.test.js.map +1 -0
  344. package/dist/tests/utils/sleep.test.d.ts +1 -0
  345. package/dist/tests/utils/sleep.test.js +14 -0
  346. package/dist/tests/utils/sleep.test.js.map +1 -0
  347. package/dist/types/common.d.ts +31 -0
  348. package/dist/types/common.js +2 -0
  349. package/dist/types/common.js.map +1 -0
  350. package/dist/types/config.d.ts +25 -0
  351. package/dist/types/config.js +2 -0
  352. package/dist/types/config.js.map +1 -0
  353. package/dist/types/index.d.ts +2 -0
  354. package/dist/types/index.js +3 -0
  355. package/dist/types/index.js.map +1 -0
  356. package/dist/utils/arguments.d.ts +14 -0
  357. package/dist/utils/arguments.js +70 -0
  358. package/dist/utils/arguments.js.map +1 -0
  359. package/dist/utils/bls.d.ts +21 -0
  360. package/dist/utils/bls.js +101 -0
  361. package/dist/utils/bls.js.map +1 -0
  362. package/dist/utils/cache.d.ts +18 -0
  363. package/dist/utils/cache.js +109 -0
  364. package/dist/utils/cache.js.map +1 -0
  365. package/dist/utils/calculate-overview-v2.d.ts +28 -0
  366. package/dist/utils/calculate-overview-v2.js +57 -0
  367. package/dist/utils/calculate-overview-v2.js.map +1 -0
  368. package/dist/utils/calculate-overview.d.ts +29 -0
  369. package/dist/utils/calculate-overview.js +59 -0
  370. package/dist/utils/calculate-overview.js.map +1 -0
  371. package/dist/utils/charts/blessed/charts-apr.d.ts +98 -0
  372. package/dist/utils/charts/blessed/charts-apr.js +118 -0
  373. package/dist/utils/charts/blessed/charts-apr.js.map +1 -0
  374. package/dist/utils/charts/blessed/charts-rewards.d.ts +74 -0
  375. package/dist/utils/charts/blessed/charts-rewards.js +106 -0
  376. package/dist/utils/charts/blessed/charts-rewards.js.map +1 -0
  377. package/dist/utils/charts/blessed/constants.d.ts +22 -0
  378. package/dist/utils/charts/blessed/constants.js +23 -0
  379. package/dist/utils/charts/blessed/constants.js.map +1 -0
  380. package/dist/utils/charts/blessed/datasets/bottom-line.d.ts +19 -0
  381. package/dist/utils/charts/blessed/datasets/bottom-line.js +34 -0
  382. package/dist/utils/charts/blessed/datasets/bottom-line.js.map +1 -0
  383. package/dist/utils/charts/blessed/datasets/efficiency.d.ts +18 -0
  384. package/dist/utils/charts/blessed/datasets/efficiency.js +33 -0
  385. package/dist/utils/charts/blessed/datasets/efficiency.js.map +1 -0
  386. package/dist/utils/charts/blessed/datasets/gross-staking-apr.d.ts +18 -0
  387. package/dist/utils/charts/blessed/datasets/gross-staking-apr.js +33 -0
  388. package/dist/utils/charts/blessed/datasets/gross-staking-apr.js.map +1 -0
  389. package/dist/utils/charts/blessed/datasets/gross-staking-rewards.d.ts +24 -0
  390. package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js +39 -0
  391. package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js.map +1 -0
  392. package/dist/utils/charts/blessed/datasets/index.d.ts +9 -0
  393. package/dist/utils/charts/blessed/datasets/index.js +10 -0
  394. package/dist/utils/charts/blessed/datasets/index.js.map +1 -0
  395. package/dist/utils/charts/blessed/datasets/lido-apr.d.ts +19 -0
  396. package/dist/utils/charts/blessed/datasets/lido-apr.js +34 -0
  397. package/dist/utils/charts/blessed/datasets/lido-apr.js.map +1 -0
  398. package/dist/utils/charts/blessed/datasets/net-staking-apr.d.ts +18 -0
  399. package/dist/utils/charts/blessed/datasets/net-staking-apr.js +33 -0
  400. package/dist/utils/charts/blessed/datasets/net-staking-apr.js.map +1 -0
  401. package/dist/utils/charts/blessed/datasets/net-staking-rewards.d.ts +18 -0
  402. package/dist/utils/charts/blessed/datasets/net-staking-rewards.js +33 -0
  403. package/dist/utils/charts/blessed/datasets/net-staking-rewards.js.map +1 -0
  404. package/dist/utils/charts/blessed/datasets/node-operator-rewards.d.ts +24 -0
  405. package/dist/utils/charts/blessed/datasets/node-operator-rewards.js +39 -0
  406. package/dist/utils/charts/blessed/datasets/node-operator-rewards.js.map +1 -0
  407. package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +33 -0
  408. package/dist/utils/charts/blessed/datasets/prepare-metrics.js +133 -0
  409. package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -0
  410. package/dist/utils/charts/blessed/datasets/types.d.ts +4 -0
  411. package/dist/utils/charts/blessed/datasets/types.js +2 -0
  412. package/dist/utils/charts/blessed/datasets/types.js.map +1 -0
  413. package/dist/utils/charts/blessed/index.d.ts +3 -0
  414. package/dist/utils/charts/blessed/index.js +4 -0
  415. package/dist/utils/charts/blessed/index.js.map +1 -0
  416. package/dist/utils/charts/blessed/net-vs-lido-apr.d.ts +13 -0
  417. package/dist/utils/charts/blessed/net-vs-lido-apr.js +19 -0
  418. package/dist/utils/charts/blessed/net-vs-lido-apr.js.map +1 -0
  419. package/dist/utils/charts/blessed/utils.d.ts +62 -0
  420. package/dist/utils/charts/blessed/utils.js +84 -0
  421. package/dist/utils/charts/blessed/utils.js.map +1 -0
  422. package/dist/utils/charts/index.d.ts +3 -0
  423. package/dist/utils/charts/index.js +4 -0
  424. package/dist/utils/charts/index.js.map +1 -0
  425. package/dist/utils/charts/metrics.d.ts +16 -0
  426. package/dist/utils/charts/metrics.js +160 -0
  427. package/dist/utils/charts/metrics.js.map +1 -0
  428. package/dist/utils/charts/overview.d.ts +10 -0
  429. package/dist/utils/charts/overview.js +89 -0
  430. package/dist/utils/charts/overview.js.map +1 -0
  431. package/dist/utils/charts/simple/index.d.ts +1 -0
  432. package/dist/utils/charts/simple/index.js +2 -0
  433. package/dist/utils/charts/simple/index.js.map +1 -0
  434. package/dist/utils/charts/simple/simple-charts.d.ts +2 -0
  435. package/dist/utils/charts/simple/simple-charts.js +81 -0
  436. package/dist/utils/charts/simple/simple-charts.js.map +1 -0
  437. package/dist/utils/commands/confirmations.d.ts +21 -0
  438. package/dist/utils/commands/confirmations.js +99 -0
  439. package/dist/utils/commands/confirmations.js.map +1 -0
  440. package/dist/utils/commands/dashboard.d.ts +6 -0
  441. package/dist/utils/commands/dashboard.js +145 -0
  442. package/dist/utils/commands/dashboard.js.map +1 -0
  443. package/dist/utils/commands/index.d.ts +4 -0
  444. package/dist/utils/commands/index.js +5 -0
  445. package/dist/utils/commands/index.js.map +1 -0
  446. package/dist/utils/commands/report.d.ts +7 -0
  447. package/dist/utils/commands/report.js +43 -0
  448. package/dist/utils/commands/report.js.map +1 -0
  449. package/dist/utils/commands/utils.d.ts +6 -0
  450. package/dist/utils/commands/utils.js +57 -0
  451. package/dist/utils/commands/utils.js.map +1 -0
  452. package/dist/utils/contract.d.ts +57 -0
  453. package/dist/utils/contract.js +212 -0
  454. package/dist/utils/contract.js.map +1 -0
  455. package/dist/utils/data-validators.d.ts +6 -0
  456. package/dist/utils/data-validators.js +54 -0
  457. package/dist/utils/data-validators.js.map +1 -0
  458. package/dist/utils/error-handler.d.ts +1 -0
  459. package/dist/utils/error-handler.js +13 -0
  460. package/dist/utils/error-handler.js.map +1 -0
  461. package/dist/utils/fetchCL.d.ts +14 -0
  462. package/dist/utils/fetchCL.js +57 -0
  463. package/dist/utils/fetchCL.js.map +1 -0
  464. package/dist/utils/get-commands.d.ts +2 -0
  465. package/dist/utils/get-commands.js +11 -0
  466. package/dist/utils/get-commands.js.map +1 -0
  467. package/dist/utils/get-deposit-data-root.d.ts +7 -0
  468. package/dist/utils/get-deposit-data-root.js +37 -0
  469. package/dist/utils/get-deposit-data-root.js.map +1 -0
  470. package/dist/utils/get-value.d.ts +1 -0
  471. package/dist/utils/get-value.js +5 -11
  472. package/dist/utils/get-value.js.map +1 -1
  473. package/dist/utils/health/calculate-health.d.ts +11 -0
  474. package/dist/utils/health/calculate-health.js +22 -0
  475. package/dist/utils/health/calculate-health.js.map +1 -0
  476. package/dist/utils/health/health-utils.d.ts +27743 -0
  477. package/dist/utils/health/health-utils.js +74 -0
  478. package/dist/utils/health/health-utils.js.map +1 -0
  479. package/dist/utils/health/index.d.ts +2 -0
  480. package/dist/utils/health/index.js +3 -0
  481. package/dist/utils/health/index.js.map +1 -0
  482. package/dist/utils/index.d.ts +30 -0
  483. package/dist/utils/index.js +30 -17
  484. package/dist/utils/index.js.map +1 -1
  485. package/dist/utils/interrupt-handler.d.ts +3 -0
  486. package/dist/utils/interrupt-handler.js +28 -0
  487. package/dist/utils/interrupt-handler.js.map +1 -0
  488. package/dist/utils/ipfs.d.ts +14 -0
  489. package/dist/utils/ipfs.js +94 -0
  490. package/dist/utils/ipfs.js.map +1 -0
  491. package/dist/utils/lido-apr.d.ts +2 -0
  492. package/dist/utils/lido-apr.js +8 -0
  493. package/dist/utils/lido-apr.js.map +1 -0
  494. package/dist/utils/logging/console.d.ts +15 -0
  495. package/dist/utils/logging/console.js +36 -0
  496. package/dist/utils/logging/console.js.map +1 -0
  497. package/dist/utils/logging/constants.d.ts +4 -0
  498. package/dist/utils/logging/constants.js +18 -0
  499. package/dist/utils/logging/constants.js.map +1 -0
  500. package/dist/utils/logging/index.d.ts +1 -0
  501. package/dist/utils/logging/index.js +2 -0
  502. package/dist/utils/logging/index.js.map +1 -0
  503. package/dist/utils/prompts/confirmations.d.ts +2 -0
  504. package/dist/utils/prompts/confirmations.js +18 -0
  505. package/dist/utils/prompts/confirmations.js.map +1 -0
  506. package/dist/utils/prompts/dashboard.d.ts +33 -0
  507. package/dist/utils/prompts/dashboard.js +45 -0
  508. package/dist/utils/prompts/dashboard.js.map +1 -0
  509. package/dist/utils/prompts/default.d.ts +4 -0
  510. package/dist/utils/prompts/default.js +20 -0
  511. package/dist/utils/prompts/default.js.map +1 -0
  512. package/dist/utils/prompts/index.d.ts +6 -0
  513. package/dist/utils/prompts/index.js +7 -0
  514. package/dist/utils/prompts/index.js.map +1 -0
  515. package/dist/utils/prompts/operations.d.ts +9 -0
  516. package/dist/utils/prompts/operations.js +45 -0
  517. package/dist/utils/prompts/operations.js.map +1 -0
  518. package/dist/utils/prompts/predeposit-guarantee.d.ts +3 -0
  519. package/dist/utils/prompts/predeposit-guarantee.js +22 -0
  520. package/dist/utils/prompts/predeposit-guarantee.js.map +1 -0
  521. package/dist/utils/prompts/vault.d.ts +2 -0
  522. package/dist/utils/prompts/vault.js +14 -0
  523. package/dist/utils/prompts/vault.js.map +1 -0
  524. package/dist/utils/proof/create-proof.d.ts +11 -0
  525. package/dist/utils/proof/create-proof.js +38 -0
  526. package/dist/utils/proof/create-proof.js.map +1 -0
  527. package/dist/utils/proof/first-validator-gindex.d.ts +1 -0
  528. package/dist/utils/proof/first-validator-gindex.js +32 -0
  529. package/dist/utils/proof/first-validator-gindex.js.map +1 -0
  530. package/dist/utils/proof/index.d.ts +4 -0
  531. package/dist/utils/proof/index.js +5 -0
  532. package/dist/utils/proof/index.js.map +1 -0
  533. package/dist/utils/proof/merkle-utils.d.ts +55 -0
  534. package/dist/utils/proof/merkle-utils.js +173 -0
  535. package/dist/utils/proof/merkle-utils.js.map +1 -0
  536. package/dist/utils/proof/proofs.d.ts +30 -0
  537. package/dist/utils/proof/proofs.js +52 -0
  538. package/dist/utils/proof/proofs.js.map +1 -0
  539. package/dist/utils/proof/report-proof.d.ts +5 -0
  540. package/dist/utils/proof/report-proof.js +26 -0
  541. package/dist/utils/proof/report-proof.js.map +1 -0
  542. package/dist/utils/read-programs-by-abi.d.ts +20 -0
  543. package/dist/utils/read-programs-by-abi.js +91 -0
  544. package/dist/utils/read-programs-by-abi.js.map +1 -0
  545. package/dist/utils/rebase-rewards.d.ts +8 -0
  546. package/dist/utils/rebase-rewards.js +6 -0
  547. package/dist/utils/rebase-rewards.js.map +1 -0
  548. package/dist/utils/report/index.d.ts +3 -0
  549. package/dist/utils/report/index.js +4 -0
  550. package/dist/utils/report/index.js.map +1 -0
  551. package/dist/utils/report/report-statistic.d.ts +52 -0
  552. package/dist/utils/report/report-statistic.js +128 -0
  553. package/dist/utils/report/report-statistic.js.map +1 -0
  554. package/dist/utils/report/report.d.ts +106 -0
  555. package/dist/utils/report/report.js +146 -0
  556. package/dist/utils/report/report.js.map +1 -0
  557. package/dist/utils/report/statistic-data.d.ts +32 -0
  558. package/dist/utils/report/statistic-data.js +29 -0
  559. package/dist/utils/report/statistic-data.js.map +1 -0
  560. package/dist/utils/required-lock.d.ts +5 -0
  561. package/dist/utils/required-lock.js +21 -0
  562. package/dist/utils/required-lock.js.map +1 -0
  563. package/dist/utils/resolve-path.d.ts +1 -0
  564. package/dist/utils/resolve-path.js +10 -0
  565. package/dist/utils/resolve-path.js.map +1 -0
  566. package/dist/utils/share-rate.d.ts +1 -0
  567. package/dist/utils/share-rate.js +16 -0
  568. package/dist/utils/share-rate.js.map +1 -0
  569. package/dist/utils/sleep.d.ts +1 -0
  570. package/dist/utils/sleep.js +4 -0
  571. package/dist/utils/sleep.js.map +1 -0
  572. package/dist/utils/spinner/constants.d.ts +6 -0
  573. package/dist/utils/spinner/constants.js +120 -0
  574. package/dist/utils/spinner/constants.js.map +1 -0
  575. package/dist/utils/spinner/index.d.ts +1 -0
  576. package/dist/utils/spinner/index.js +2 -0
  577. package/dist/utils/spinner/index.js.map +1 -0
  578. package/dist/utils/spinner/spinners.d.ts +7 -0
  579. package/dist/utils/spinner/spinners.js +16 -0
  580. package/dist/utils/spinner/spinners.js.map +1 -0
  581. package/dist/version/index.d.ts +1 -0
  582. package/dist/version/index.js +1 -0
  583. package/dist/version/index.js.map +1 -0
  584. package/package.json +76 -27
  585. package/dist/programs/vault-hub.js +0 -137
  586. package/dist/programs/vault-hub.js.map +0 -1
@@ -0,0 +1,91 @@
1
+ import { callReadMethod, stringToAddress } from './index.js';
2
+ /**
3
+ * Generates a CLI command based on the provided ABI.
4
+ * Only functions with stateMutability === 'view' or 'pure' are taken.
5
+ * Allows adding custom descriptions.
6
+ */
7
+ // eslint-disable-next-line func-style
8
+ export function generateReadCommands(abi, createContractOrContract, command, commandConfig) {
9
+ // Filter only view/pure functions
10
+ const readOnlyFunctions = abi.filter((entry) => entry.type === 'function' &&
11
+ (entry.stateMutability === 'view' || entry.stateMutability === 'pure') &&
12
+ entry.name);
13
+ // Check if the contract is already created
14
+ const isNeedsAddress = createContractOrContract.length === 1;
15
+ const methods = [];
16
+ // Generate subcommands
17
+ readOnlyFunctions.forEach((fn) => {
18
+ const fnName = fn.name;
19
+ const inputs = fn.inputs || [];
20
+ // Search for a custom description for this function
21
+ const configForFn = commandConfig[fnName];
22
+ if (configForFn?.hidden)
23
+ return;
24
+ // Custom command name if specified
25
+ const commandName = methods.includes(fnName)
26
+ ? `${fnName}${inputs[0].name}`
27
+ : configForFn?.name || fnName;
28
+ // Command description
29
+ const commandDescription = configForFn?.description ||
30
+ `Calls the read-only function "${fnName}" on the contract.`;
31
+ const aliases = configForFn?.aliases || [];
32
+ // Create a subcommand by function name
33
+ const fnCommand = command
34
+ .command(commandName)
35
+ .aliases(aliases)
36
+ .description(commandDescription);
37
+ methods.push(fnName);
38
+ // If the contract needs an address, add the <address> argument
39
+ if (isNeedsAddress) {
40
+ fnCommand.argument('<address>', 'Contract address', stringToAddress);
41
+ }
42
+ // Add arguments for each function parameter
43
+ inputs.forEach((input, index) => {
44
+ const abiArgName = input.name || `param${index}`;
45
+ // Check if there is a custom description for this argument
46
+ const configArg = configForFn?.arguments?.[abiArgName];
47
+ // If a custom name is specified, use it as the name
48
+ const cliArgName = configArg?.name || abiArgName;
49
+ // If a custom description is specified, use it, otherwise use the default
50
+ const cliArgDesc = configArg?.description || `Parameter of type ${input.type}`;
51
+ const parseFn = typeof configArg?.modifier === 'function'
52
+ ? configArg.modifier
53
+ : undefined;
54
+ // Create an argument using the custom name and description
55
+ if (parseFn)
56
+ fnCommand.argument(`<${cliArgName}>`, cliArgDesc, parseFn);
57
+ else
58
+ fnCommand.argument(`<${cliArgName}>`, cliArgDesc);
59
+ });
60
+ fnCommand.action(async (...cliArgs) => {
61
+ try {
62
+ let contract;
63
+ let fnArgs;
64
+ if (isNeedsAddress) {
65
+ // The first argument is the contract address
66
+ const address = cliArgs[0];
67
+ // The rest are the function arguments
68
+ fnArgs = cliArgs.slice(1);
69
+ // Create the contract
70
+ contract = createContractOrContract(address);
71
+ }
72
+ else {
73
+ // Create the contract async
74
+ contract = await createContractOrContract();
75
+ fnArgs = cliArgs; // all the passed arguments are the function arguments
76
+ }
77
+ fnArgs = inputs.length > 0 ? fnArgs.slice(0, inputs.length) : undefined;
78
+ if (fnArgs)
79
+ await callReadMethod(contract, fnName, fnArgs);
80
+ else
81
+ await callReadMethod(contract, fnName);
82
+ }
83
+ catch (error) {
84
+ console.error(`Error calling function ${fnName}:`, error);
85
+ process.exit(1);
86
+ }
87
+ });
88
+ });
89
+ return command;
90
+ }
91
+ //# sourceMappingURL=read-programs-by-abi.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read-programs-by-abi.js","sourceRoot":"","sources":["../../utils/read-programs-by-abi.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAgB,eAAe,EAAE,MAAM,OAAO,CAAC;AA+BtE;;;;GAIG;AACH,sCAAsC;AACtC,MAAM,UAAU,oBAAoB,CAClC,GAAQ,EACR,wBAEiC,EACjC,OAAgB,EAChB,aAAuC;IAEvC,kCAAkC;IAClC,MAAM,iBAAiB,GAAG,GAAG,CAAC,MAAM,CAClC,CAAC,KAAU,EAAE,EAAE,CACb,KAAK,CAAC,IAAI,KAAK,UAAU;QACzB,CAAC,KAAK,CAAC,eAAe,KAAK,MAAM,IAAI,KAAK,CAAC,eAAe,KAAK,MAAM,CAAC;QACtE,KAAK,CAAC,IAAI,CACb,CAAC;IAEF,2CAA2C;IAC3C,MAAM,cAAc,GAEhB,wBAGD,CAAC,MAAM,KAAK,CAAC,CAAC;IAEjB,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,uBAAuB;IACvB,iBAAiB,CAAC,OAAO,CAAC,CAAC,EAAO,EAAE,EAAE;QACpC,MAAM,MAAM,GAAG,EAAE,CAAC,IAAI,CAAC;QACvB,MAAM,MAAM,GAAG,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC;QAE/B,oDAAoD;QACpD,MAAM,WAAW,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,WAAW,EAAE,MAAM;YAAE,OAAO;QAChC,mCAAmC;QACnC,MAAM,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC1C,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;YAC9B,CAAC,CAAC,WAAW,EAAE,IAAI,IAAI,MAAM,CAAC;QAChC,sBAAsB;QACtB,MAAM,kBAAkB,GACtB,WAAW,EAAE,WAAW;YACxB,iCAAiC,MAAM,oBAAoB,CAAC;QAE9D,MAAM,OAAO,GAAG,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC;QAE3C,uCAAuC;QACvC,MAAM,SAAS,GAAG,OAAO;aACtB,OAAO,CAAC,WAAW,CAAC;aACpB,OAAO,CAAC,OAAO,CAAC;aAChB,WAAW,CAAC,kBAAkB,CAAC,CAAC;QACnC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAErB,+DAA+D;QAC/D,IAAI,cAAc,EAAE,CAAC;YACnB,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,kBAAkB,EAAE,eAAe,CAAC,CAAC;QACvE,CAAC;QAED,4CAA4C;QAC5C,MAAM,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,KAAa,EAAE,EAAE;YAC3C,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,IAAI,QAAQ,KAAK,EAAE,CAAC;YACjD,2DAA2D;YAC3D,MAAM,SAAS,GAAG,WAAW,EAAE,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC;YACvD,oDAAoD;YACpD,MAAM,UAAU,GAAG,SAAS,EAAE,IAAI,IAAI,UAAU,CAAC;YACjD,0EAA0E;YAC1E,MAAM,UAAU,GACd,SAAS,EAAE,WAAW,IAAI,qBAAqB,KAAK,CAAC,IAAI,EAAE,CAAC;YAE9D,MAAM,OAAO,GACX,OAAO,SAAS,EAAE,QAAQ,KAAK,UAAU;gBACvC,CAAC,CAAC,SAAS,CAAC,QAAQ;gBACpB,CAAC,CAAC,SAAS,CAAC;YAEhB,2DAA2D;YAE3D,IAAI,OAAO;gBAAE,SAAS,CAAC,QAAQ,CAAC,IAAI,UAAU,GAAG,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;;gBACnE,SAAS,CAAC,QAAQ,CAAC,IAAI,UAAU,GAAG,EAAE,UAAU,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,OAAc,EAAE,EAAE;YAC3C,IAAI,CAAC;gBACH,IAAI,QAAsB,CAAC;gBAC3B,IAAI,MAAyB,CAAC;gBAE9B,IAAI,cAAc,EAAE,CAAC;oBACnB,6CAA6C;oBAC7C,MAAM,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;oBAC3B,sCAAsC;oBACtC,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBAC1B,sBAAsB;oBACtB,QAAQ,GAAI,wBAAyD,CACnE,OAAO,CACR,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,4BAA4B;oBAC5B,QAAQ,GAAG,MACT,wBACD,EAAE,CAAC;oBACJ,MAAM,GAAG,OAAO,CAAC,CAAC,sDAAsD;gBAC1E,CAAC;gBAED,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;gBAExE,IAAI,MAAM;oBAAE,MAAM,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;;oBACtD,MAAM,cAAc,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC9C,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,0BAA0B,MAAM,GAAG,EAAE,KAAK,CAAC,CAAC;gBAC1D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,8 @@
1
+ type CalculateRebaseRewardArgs = {
2
+ shareRatePrev: bigint;
3
+ shareRateCurr: bigint;
4
+ sharesPrev: bigint;
5
+ sharesCurr: bigint;
6
+ };
7
+ export declare const calculateRebaseReward: (args: CalculateRebaseRewardArgs) => bigint;
8
+ export {};
@@ -0,0 +1,6 @@
1
+ export const calculateRebaseReward = (args) => {
2
+ const { shareRatePrev, shareRateCurr, sharesPrev, sharesCurr } = args;
3
+ const reward = (shareRateCurr * sharesCurr - shareRatePrev * sharesPrev) / 10n ** 27n;
4
+ return reward;
5
+ };
6
+ //# sourceMappingURL=rebase-rewards.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rebase-rewards.js","sourceRoot":"","sources":["../../utils/rebase-rewards.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACnC,IAA+B,EACvB,EAAE;IACV,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;IAEtE,MAAM,MAAM,GACV,CAAC,aAAa,GAAG,UAAU,GAAG,aAAa,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,GAAG,CAAC;IAEzE,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from './report.js';
2
+ export * from './report-statistic.js';
3
+ export * from './statistic-data.js';
@@ -0,0 +1,4 @@
1
+ export * from './report.js';
2
+ export * from './report-statistic.js';
3
+ export * from './statistic-data.js';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../utils/report/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { VaultReport } from '../index.js';
2
+ export declare const getGrossStakingRewards: (current: VaultReport, previous: VaultReport) => bigint;
3
+ export declare const getNodeOperatorRewards: (current: VaultReport, previous: VaultReport, nodeOperatorFeeBP: bigint) => bigint;
4
+ export declare const getDailyLidoFees: () => bigint;
5
+ export declare const getNetStakingRewards: (current: VaultReport, previous: VaultReport, nodeOperatorFeeBP: bigint) => bigint;
6
+ export declare const getGrossStakingAPR: (current: VaultReport, previous: VaultReport) => {
7
+ apr: bigint;
8
+ apr_bps: number;
9
+ apr_percent: number;
10
+ };
11
+ export declare const getNetStakingAPR: (current: VaultReport, previous: VaultReport, nodeOperatorFeeBP: bigint) => {
12
+ apr: bigint;
13
+ apr_bps: number;
14
+ apr_percent: number;
15
+ };
16
+ export declare const getBottomLine: (current: VaultReport, previous: VaultReport, nodeOperatorFeeBP: bigint, stEthLiabilityRebaseRewards: bigint) => bigint;
17
+ export declare const getEfficiency: (current: VaultReport, previous: VaultReport, nodeOperatorFeeBP: bigint, stEthLiabilityRebaseRewards: bigint) => {
18
+ apr: bigint;
19
+ apr_bps: number;
20
+ apr_percent: number;
21
+ };
22
+ type ReportMetricsArgs = {
23
+ reports: {
24
+ current: VaultReport;
25
+ previous: VaultReport;
26
+ };
27
+ nodeOperatorFeeBP: bigint;
28
+ stEthLiabilityRebaseRewards: bigint;
29
+ };
30
+ export declare const reportMetrics: (args: ReportMetricsArgs) => {
31
+ grossStakingRewards: bigint;
32
+ nodeOperatorRewards: bigint;
33
+ dailyLidoFees: bigint;
34
+ netStakingRewards: bigint;
35
+ grossStakingAPR: {
36
+ apr: bigint;
37
+ apr_bps: number;
38
+ apr_percent: number;
39
+ };
40
+ netStakingAPR: {
41
+ apr: bigint;
42
+ apr_bps: number;
43
+ apr_percent: number;
44
+ };
45
+ bottomLine: bigint;
46
+ efficiency: {
47
+ apr: bigint;
48
+ apr_bps: number;
49
+ apr_percent: number;
50
+ };
51
+ };
52
+ export {};
@@ -0,0 +1,128 @@
1
+ import { BASIS_POINTS_DENOMINATOR } from '../index.js';
2
+ const SCALE = 1000000000n; // 1e9 for 9 decimal places precision
3
+ export const getGrossStakingRewards = (current, previous) => {
4
+ const grossStakingRewards = BigInt(current.data.total_value_wei) -
5
+ BigInt(previous.data.total_value_wei) -
6
+ (BigInt(current.data.in_out_delta) - BigInt(previous.data.in_out_delta));
7
+ return grossStakingRewards;
8
+ };
9
+ export const getNodeOperatorRewards = (current, previous, nodeOperatorFeeBP) => {
10
+ const grossStakingRewards = getGrossStakingRewards(current, previous);
11
+ return (grossStakingRewards * nodeOperatorFeeBP) / BASIS_POINTS_DENOMINATOR;
12
+ };
13
+ // TODO: get Lido Fees from the contract
14
+ export const getDailyLidoFees = () => {
15
+ const prev_cumulativeLidoFees = 0n;
16
+ const current_cumulativeLidoFees = 0n;
17
+ return current_cumulativeLidoFees - prev_cumulativeLidoFees;
18
+ };
19
+ export const getNetStakingRewards = (current, previous, nodeOperatorFeeBP) => {
20
+ const grossStakingRewards = getGrossStakingRewards(current, previous);
21
+ const nodeOperatorRewards = getNodeOperatorRewards(current, previous, nodeOperatorFeeBP);
22
+ const dailyLidoFees = getDailyLidoFees();
23
+ return grossStakingRewards - nodeOperatorRewards - dailyLidoFees;
24
+ };
25
+ // The APR metrics (Gross Staking APR, Net Staking APR, Efficiency) are calculated using the following general formula:
26
+ //
27
+ // APR = (Numerator * 100 * SecondsInYear) / (AverageTotalValue * PeriodSeconds)
28
+ //
29
+ // where:
30
+ // Numerator — the specific rewards or value for the metric:
31
+ // - For Gross Staking APR: grossStakingRewards
32
+ // - For Net Staking APR: netStakingRewards
33
+ // - For Efficiency: bottomLine
34
+ // AverageTotalValue — arithmetic mean of TVL at the start and end of the period
35
+ // PeriodSeconds — difference between end and start timestamps (in seconds)
36
+ // SecondsInYear = 31536000
37
+ //
38
+ // Calculation steps:
39
+ // 1. Calculate the numerator for the metric (see above)
40
+ // 2. Divide by the average TVL
41
+ // 3. Multiply by 100 and the number of seconds in a year (31536000)
42
+ // 4. Divide by the period duration in seconds
43
+ //
44
+ // Example for Gross Staking APR:
45
+ // grossStakingAPR = (grossStakingRewards * 100 * 31536000) / (averageTotalValue * periodSeconds)
46
+ const getAverageTotalValue = (current, previous) => {
47
+ return ((BigInt(current.data.total_value_wei) +
48
+ BigInt(previous.data.total_value_wei)) /
49
+ 2n);
50
+ };
51
+ const getPeriodSeconds = (current, previous) => {
52
+ return current.timestamp - previous.timestamp;
53
+ };
54
+ export const getGrossStakingAPR = (current, previous) => {
55
+ const grossStakingRewards = getGrossStakingRewards(current, previous);
56
+ const averageTotalValue = getAverageTotalValue(current, previous);
57
+ const periodSeconds = getPeriodSeconds(current, previous);
58
+ const apr_bigint = (grossStakingRewards * 10000n * 31536000n * SCALE) /
59
+ (averageTotalValue * BigInt(periodSeconds));
60
+ const apr = (grossStakingRewards * 100n * 31536000n) /
61
+ (averageTotalValue * BigInt(periodSeconds));
62
+ const apr_bps = Number(apr_bigint) / Number(SCALE);
63
+ const apr_percent = apr_bps / 100;
64
+ return {
65
+ apr,
66
+ apr_bps,
67
+ apr_percent,
68
+ };
69
+ };
70
+ export const getNetStakingAPR = (current, previous, nodeOperatorFeeBP) => {
71
+ const averageTotalValue = getAverageTotalValue(current, previous);
72
+ const periodSeconds = getPeriodSeconds(current, previous);
73
+ const netStakingRewards = getNetStakingRewards(current, previous, nodeOperatorFeeBP);
74
+ const apr_bigint = (netStakingRewards * 10000n * 31536000n * SCALE) /
75
+ (averageTotalValue * BigInt(periodSeconds));
76
+ const apr = (netStakingRewards * 100n * 31536000n) /
77
+ (averageTotalValue * BigInt(periodSeconds));
78
+ const apr_bps = Number(apr_bigint) / Number(SCALE);
79
+ const apr_percent = apr_bps / 100;
80
+ return {
81
+ apr,
82
+ apr_bps,
83
+ apr_percent,
84
+ };
85
+ };
86
+ export const getBottomLine = (current, previous, nodeOperatorFeeBP, stEthLiabilityRebaseRewards) => {
87
+ const netStakingRewards = getNetStakingRewards(current, previous, nodeOperatorFeeBP);
88
+ return netStakingRewards - stEthLiabilityRebaseRewards;
89
+ };
90
+ export const getEfficiency = (current, previous, nodeOperatorFeeBP, stEthLiabilityRebaseRewards) => {
91
+ const averageTotalValue = getAverageTotalValue(current, previous);
92
+ const periodSeconds = getPeriodSeconds(current, previous);
93
+ const bottomLine = getBottomLine(current, previous, nodeOperatorFeeBP, stEthLiabilityRebaseRewards);
94
+ const apr_bigint = (bottomLine * 10000n * 31536000n * SCALE) /
95
+ (averageTotalValue * BigInt(periodSeconds));
96
+ const apr = (bottomLine * 100n * 31536000n) /
97
+ (averageTotalValue * BigInt(periodSeconds));
98
+ const apr_bps = Number(apr_bigint) / Number(SCALE);
99
+ const apr_percent = apr_bps / 100;
100
+ return {
101
+ apr,
102
+ apr_bps,
103
+ apr_percent,
104
+ };
105
+ };
106
+ export const reportMetrics = (args) => {
107
+ const { reports, nodeOperatorFeeBP, stEthLiabilityRebaseRewards } = args;
108
+ const { current, previous } = reports;
109
+ const grossStakingRewards = getGrossStakingRewards(current, previous);
110
+ const nodeOperatorRewards = getNodeOperatorRewards(current, previous, nodeOperatorFeeBP);
111
+ const dailyLidoFees = getDailyLidoFees();
112
+ const netStakingRewards = getNetStakingRewards(current, previous, nodeOperatorFeeBP);
113
+ const grossStakingAPR = getGrossStakingAPR(current, previous);
114
+ const netStakingAPR = getNetStakingAPR(current, previous, nodeOperatorFeeBP);
115
+ const bottomLine = getBottomLine(current, previous, nodeOperatorFeeBP, stEthLiabilityRebaseRewards);
116
+ const efficiency = getEfficiency(current, previous, nodeOperatorFeeBP, stEthLiabilityRebaseRewards);
117
+ return {
118
+ grossStakingRewards,
119
+ nodeOperatorRewards,
120
+ dailyLidoFees,
121
+ netStakingRewards,
122
+ grossStakingAPR,
123
+ netStakingAPR,
124
+ bottomLine,
125
+ efficiency,
126
+ };
127
+ };
128
+ //# sourceMappingURL=report-statistic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"report-statistic.js","sourceRoot":"","sources":["../../../utils/report/report-statistic.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,106 @@
1
+ import { Address } from 'viem';
2
+ import { BigNumberType } from '../index.js';
3
+ export type LeafDataFields = {
4
+ vault_address: string;
5
+ total_value_wei: string;
6
+ in_out_delta: string;
7
+ fee: string;
8
+ liability_shares: string;
9
+ };
10
+ export type Report = {
11
+ format: string;
12
+ leafEncoding: string[];
13
+ tree: string[];
14
+ values: {
15
+ value: string[];
16
+ treeIndex: number;
17
+ }[];
18
+ merkleTreeRoot: string;
19
+ refSlot: number;
20
+ timestamp: number;
21
+ blockNumber: number;
22
+ proofsCID: string;
23
+ prevTreeCID: string;
24
+ leafIndexToData: {
25
+ [key: string]: keyof LeafDataFields;
26
+ };
27
+ };
28
+ export type VaultReport = {
29
+ data: LeafDataFields;
30
+ leaf: string;
31
+ refSlot: number;
32
+ blockNumber: number;
33
+ timestamp: number;
34
+ proofsCID: string;
35
+ prevTreeCID: string;
36
+ merkleTreeRoot: string;
37
+ };
38
+ export type ReportProof = {
39
+ merkleTreeRoot: string;
40
+ refSlot: number;
41
+ proofs: {
42
+ [key: string]: {
43
+ id: number;
44
+ totalValueWei: bigint;
45
+ inOutDelta: bigint;
46
+ fee: bigint;
47
+ liabilityShares: bigint;
48
+ leaf: string;
49
+ proof: string[];
50
+ };
51
+ };
52
+ block_number: number;
53
+ timestamp: number;
54
+ prevTreeCID: string;
55
+ };
56
+ export type VaultReportArgs = {
57
+ vault: Address;
58
+ cid: string;
59
+ gateway?: string;
60
+ bigNumberType?: BigNumberType;
61
+ };
62
+ export declare const getVaultReport: (args: VaultReportArgs, cache?: boolean) => Promise<VaultReport>;
63
+ export declare const getVaultPreviousReport: (args: VaultReportArgs, cache?: boolean) => Promise<VaultReport>;
64
+ export declare const getVaultReportProof: (args: VaultReportArgs, cache?: boolean) => Promise<{
65
+ id: number;
66
+ totalValueWei: bigint;
67
+ inOutDelta: bigint;
68
+ fee: bigint;
69
+ liabilityShares: bigint;
70
+ leaf: string;
71
+ proof: string[];
72
+ }>;
73
+ export declare const getVaultReportProofByCid: (args: VaultReportArgs, cache?: boolean) => Promise<{
74
+ id: number;
75
+ totalValueWei: bigint;
76
+ inOutDelta: bigint;
77
+ fee: bigint;
78
+ liabilityShares: bigint;
79
+ leaf: string;
80
+ proof: string[];
81
+ }>;
82
+ export declare const getAllVaultsReportProofs: (args: Omit<VaultReportArgs, "vault">, cache?: boolean) => Promise<{
83
+ [key: string]: {
84
+ id: number;
85
+ totalValueWei: bigint;
86
+ inOutDelta: bigint;
87
+ fee: bigint;
88
+ liabilityShares: bigint;
89
+ leaf: string;
90
+ proof: string[];
91
+ };
92
+ }>;
93
+ export declare const getAllVaultsReports: (args: Omit<VaultReportArgs, "vault">, cache?: boolean) => Promise<{
94
+ vaultReports: LeafDataFields[];
95
+ proofsCID: string;
96
+ prevTreeCID: string;
97
+ }>;
98
+ /**
99
+ * Retrieves a chain of historical VaultReport entries using prevTreeCID, starting from the specified CID.
100
+ * @param args { vault, cid, gateway, bigNumberType, limit, direction }
101
+ * @returns Promise<VaultReport[]> — array from newest to oldest (default) or oldest to newest (if direction === 'asc')
102
+ */
103
+ export declare const getVaultReportHistory: (args: VaultReportArgs & {
104
+ limit?: number;
105
+ direction?: "asc" | "desc";
106
+ }, cache?: boolean) => Promise<VaultReport[]>;
@@ -0,0 +1,146 @@
1
+ import { fetchIPFS, IPFS_GATEWAY, logInfo } from '../index.js';
2
+ export const getVaultReport = async (args, cache = true) => {
3
+ const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
4
+ const report = await fetchIPFS({
5
+ cid,
6
+ gateway,
7
+ bigNumberType,
8
+ }, cache);
9
+ const vaultData = getVaultData(report, vault);
10
+ return vaultData;
11
+ };
12
+ export const getVaultPreviousReport = async (args, cache = true) => {
13
+ const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
14
+ const report = await fetchIPFS({
15
+ cid,
16
+ gateway,
17
+ bigNumberType,
18
+ }, cache);
19
+ const previousReportCID = report.prevTreeCID;
20
+ const previousReport = await fetchIPFS({
21
+ cid: previousReportCID,
22
+ gateway,
23
+ bigNumberType,
24
+ });
25
+ const vaultData = getVaultData(previousReport, vault);
26
+ return vaultData;
27
+ };
28
+ const getVaultData = (report, vault) => {
29
+ const match = report.values.find((entry) => entry.value[0]?.toLowerCase() === vault.toLowerCase());
30
+ if (!match)
31
+ throw new Error('Vault not found');
32
+ const leaf = report.tree[match.treeIndex];
33
+ if (!leaf)
34
+ throw new Error('Leaf not found');
35
+ const data = {
36
+ vault_address: '',
37
+ in_out_delta: '',
38
+ fee: '',
39
+ total_value_wei: '',
40
+ liability_shares: '',
41
+ };
42
+ for (const [index, fieldName] of Object.entries(report.leafIndexToData)) {
43
+ const value = match.value[Number(index)];
44
+ if (value === undefined) {
45
+ throw new Error(`Missing value at index ${index} for field "${fieldName}"`);
46
+ }
47
+ data[fieldName] = value.toString();
48
+ }
49
+ return {
50
+ data,
51
+ leaf,
52
+ refSlot: report.refSlot,
53
+ blockNumber: report.blockNumber,
54
+ timestamp: report.timestamp,
55
+ proofsCID: report.proofsCID,
56
+ merkleTreeRoot: report.merkleTreeRoot,
57
+ prevTreeCID: report.prevTreeCID,
58
+ };
59
+ };
60
+ export const getVaultReportProof = async (args, cache = true) => {
61
+ const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
62
+ const report = await fetchIPFS({
63
+ cid,
64
+ gateway,
65
+ bigNumberType,
66
+ }, cache);
67
+ const proofCID = report.proofsCID;
68
+ const data = await fetchIPFS({
69
+ cid: proofCID,
70
+ gateway,
71
+ bigNumberType,
72
+ }, cache);
73
+ const proofByVault = data.proofs[vault];
74
+ if (!proofByVault)
75
+ throw new Error('Proof not found');
76
+ return proofByVault;
77
+ };
78
+ export const getVaultReportProofByCid = async (args, cache = true) => {
79
+ const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
80
+ const proof = await fetchIPFS({
81
+ cid,
82
+ gateway,
83
+ bigNumberType,
84
+ }, cache);
85
+ const proofByVault = proof.proofs[vault];
86
+ if (!proofByVault)
87
+ throw new Error('Proof not found');
88
+ return proofByVault;
89
+ };
90
+ export const getAllVaultsReportProofs = async (args, cache = true) => {
91
+ const { cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
92
+ const proof = await fetchIPFS({
93
+ cid,
94
+ gateway,
95
+ bigNumberType,
96
+ }, cache);
97
+ return proof.proofs;
98
+ };
99
+ export const getAllVaultsReports = async (args, cache = true) => {
100
+ const { cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
101
+ const report = await fetchIPFS({
102
+ cid,
103
+ gateway,
104
+ bigNumberType,
105
+ }, cache);
106
+ const vaultReports = report.values.map((value) => getVaultData(report, value.value[0]).data);
107
+ return {
108
+ vaultReports,
109
+ proofsCID: report.proofsCID,
110
+ prevTreeCID: report.prevTreeCID,
111
+ };
112
+ };
113
+ /**
114
+ * Retrieves a chain of historical VaultReport entries using prevTreeCID, starting from the specified CID.
115
+ * @param args { vault, cid, gateway, bigNumberType, limit, direction }
116
+ * @returns Promise<VaultReport[]> — array from newest to oldest (default) or oldest to newest (if direction === 'asc')
117
+ */
118
+ export const getVaultReportHistory = async (args, cache = true) => {
119
+ const { vault, gateway = IPFS_GATEWAY, bigNumberType = 'string', direction = 'desc', } = args;
120
+ let cid = args.cid;
121
+ const limit = args.limit ?? 20;
122
+ const history = [];
123
+ for (let i = 0; i < limit; i++) {
124
+ try {
125
+ const report = await getVaultReport({
126
+ vault,
127
+ cid,
128
+ gateway,
129
+ bigNumberType,
130
+ }, cache);
131
+ history.push(report);
132
+ if (!report.prevTreeCID || report.prevTreeCID === cid)
133
+ break;
134
+ cid = report.prevTreeCID;
135
+ }
136
+ catch (e) {
137
+ break;
138
+ }
139
+ }
140
+ logInfo('Report hostory cached', history.length);
141
+ if (direction === 'asc') {
142
+ return history.reverse();
143
+ }
144
+ return history;
145
+ };
146
+ //# sourceMappingURL=report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/report/report.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import { Address } from 'viem';
2
+ import { VaultReport } from './report.js';
3
+ type StatisticDataArgs = {
4
+ dashboard: Address;
5
+ reports: {
6
+ current: VaultReport;
7
+ previous: VaultReport;
8
+ };
9
+ };
10
+ export declare const getReportStatisticData: (args: StatisticDataArgs) => Promise<{
11
+ grossStakingRewards: bigint;
12
+ nodeOperatorRewards: bigint;
13
+ dailyLidoFees: bigint;
14
+ netStakingRewards: bigint;
15
+ grossStakingAPR: {
16
+ apr: bigint;
17
+ apr_bps: number;
18
+ apr_percent: number;
19
+ };
20
+ netStakingAPR: {
21
+ apr: bigint;
22
+ apr_bps: number;
23
+ apr_percent: number;
24
+ };
25
+ bottomLine: bigint;
26
+ efficiency: {
27
+ apr: bigint;
28
+ apr_bps: number;
29
+ apr_percent: number;
30
+ };
31
+ }>;
32
+ export {};
@@ -0,0 +1,29 @@
1
+ import { getDashboardContract } from '../../contracts/index.js';
2
+ import { calculateRebaseReward, callReadMethodSilent, calculateShareRate, } from '../index.js';
3
+ import { reportMetrics } from './report-statistic.js';
4
+ export const getReportStatisticData = async (args) => {
5
+ const { dashboard, reports } = args;
6
+ const dashboardContract = getDashboardContract(dashboard);
7
+ const reportRefBlockNumber = reports.current.blockNumber;
8
+ const reportPrevBlockNumber = reports.previous.blockNumber;
9
+ const nodeOperatorFeeBP = await callReadMethodSilent(dashboardContract, 'nodeOperatorFeeBP', {
10
+ blockNumber: BigInt(reportRefBlockNumber),
11
+ });
12
+ const [shareRatePrev, shareRateCurr] = await Promise.all([
13
+ calculateShareRate(reportPrevBlockNumber),
14
+ calculateShareRate(reportRefBlockNumber),
15
+ ]);
16
+ const stEthLiabilityRebaseRewards = calculateRebaseReward({
17
+ shareRatePrev,
18
+ shareRateCurr,
19
+ sharesPrev: BigInt(reports.previous.data.liability_shares),
20
+ sharesCurr: BigInt(reports.current.data.liability_shares),
21
+ });
22
+ const metrics = reportMetrics({
23
+ reports: { current: reports.current, previous: reports.previous },
24
+ nodeOperatorFeeBP,
25
+ stEthLiabilityRebaseRewards,
26
+ });
27
+ return metrics;
28
+ };
29
+ //# sourceMappingURL=statistic-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statistic-data.js","sourceRoot":"","sources":["../../../utils/report/statistic-data.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,OAAO,CAAC;AAGf,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAOtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EAAE,IAAuB,EAAE,EAAE;IACtE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACpC,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC1D,MAAM,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC;IACzD,MAAM,qBAAqB,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IAE3D,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAClD,iBAAiB,EACjB,mBAAmB,EACnB;QACE,WAAW,EAAE,MAAM,CAAC,oBAAoB,CAAC;KAC1C,CACF,CAAC;IACF,MAAM,CAAC,aAAa,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACvD,kBAAkB,CAAC,qBAAqB,CAAC;QACzC,kBAAkB,CAAC,oBAAoB,CAAC;KACzC,CAAC,CAAC;IAEH,MAAM,2BAA2B,GAAG,qBAAqB,CAAC;QACxD,aAAa;QACb,aAAa;QACb,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC;QAC1D,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC;KAC1D,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,aAAa,CAAC;QAC5B,OAAO,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE;QACjE,iBAAiB;QACjB,2BAA2B;KAC5B,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { Address } from 'viem';
2
+ export declare const getRequiredLockByShares: (address: Address, newShares: string) => Promise<{
3
+ requiredLock: bigint;
4
+ currentLock: bigint;
5
+ }>;