@nosana/node 1.0.0-rc

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 (384) hide show
  1. package/README.md +92 -0
  2. package/dist/.env +7 -0
  3. package/dist/.env.dev +5 -0
  4. package/dist/.env.prd +4 -0
  5. package/dist/NodeManager/client/index.d.ts +4 -0
  6. package/dist/NodeManager/client/index.js +14 -0
  7. package/dist/NodeManager/configs/NodeConfigs.d.ts +14 -0
  8. package/dist/NodeManager/configs/NodeConfigs.js +32 -0
  9. package/dist/NodeManager/configs/__tests__/NodeConfigs.spec.d.ts +1 -0
  10. package/dist/NodeManager/configs/__tests__/NodeConfigs.spec.js +161 -0
  11. package/dist/NodeManager/configs/configs.d.ts +21 -0
  12. package/dist/NodeManager/configs/configs.js +23 -0
  13. package/dist/NodeManager/db/__tests__/index.spec.d.ts +1 -0
  14. package/dist/NodeManager/db/__tests__/index.spec.js +65 -0
  15. package/dist/NodeManager/db/index.d.ts +50 -0
  16. package/dist/NodeManager/db/index.js +64 -0
  17. package/dist/NodeManager/errors/NodeAlreadyActiveError.d.ts +3 -0
  18. package/dist/NodeManager/errors/NodeAlreadyActiveError.js +6 -0
  19. package/dist/NodeManager/index.d.ts +24 -0
  20. package/dist/NodeManager/index.js +317 -0
  21. package/dist/NodeManager/jobs/index.d.ts +6 -0
  22. package/dist/NodeManager/jobs/index.js +45 -0
  23. package/dist/NodeManager/monitoring/LogMonitoringRegistry.d.ts +9 -0
  24. package/dist/NodeManager/monitoring/LogMonitoringRegistry.js +23 -0
  25. package/dist/NodeManager/monitoring/log/NodeLog.d.ts +56 -0
  26. package/dist/NodeManager/monitoring/log/NodeLog.js +1357 -0
  27. package/dist/NodeManager/monitoring/log/console/ConsoleLogger.d.ts +20 -0
  28. package/dist/NodeManager/monitoring/log/console/ConsoleLogger.js +290 -0
  29. package/dist/NodeManager/monitoring/ping/PingHandler.d.ts +13 -0
  30. package/dist/NodeManager/monitoring/ping/PingHandler.js +68 -0
  31. package/dist/NodeManager/monitoring/proxy/loggingProxy.d.ts +15 -0
  32. package/dist/NodeManager/monitoring/proxy/loggingProxy.js +145 -0
  33. package/dist/NodeManager/monitoring/state/NodeState.d.ts +29 -0
  34. package/dist/NodeManager/monitoring/state/NodeState.js +680 -0
  35. package/dist/NodeManager/monitoring/state/classifyState.d.ts +14 -0
  36. package/dist/NodeManager/monitoring/state/classifyState.js +57 -0
  37. package/dist/NodeManager/monitoring/streaming/LogStreamer.d.ts +14 -0
  38. package/dist/NodeManager/monitoring/streaming/LogStreamer.js +58 -0
  39. package/dist/NodeManager/monitoring/streaming/StateStreamer.d.ts +15 -0
  40. package/dist/NodeManager/monitoring/streaming/StateStreamer.js +59 -0
  41. package/dist/NodeManager/node/Node.d.ts +44 -0
  42. package/dist/NodeManager/node/Node.js +321 -0
  43. package/dist/NodeManager/node/abort/NodeAbortController.d.ts +6 -0
  44. package/dist/NodeManager/node/abort/NodeAbortController.js +12 -0
  45. package/dist/NodeManager/node/abort/abortControllerSelector.d.ts +3 -0
  46. package/dist/NodeManager/node/abort/abortControllerSelector.js +13 -0
  47. package/dist/NodeManager/node/api/ApiEventEmitter.d.ts +8 -0
  48. package/dist/NodeManager/node/api/ApiEventEmitter.js +13 -0
  49. package/dist/NodeManager/node/api/ApiHandler.d.ts +28 -0
  50. package/dist/NodeManager/node/api/ApiHandler.js +193 -0
  51. package/dist/NodeManager/node/api/eventsource/index.d.ts +6 -0
  52. package/dist/NodeManager/node/api/eventsource/index.js +35 -0
  53. package/dist/NodeManager/node/api/middlewares/index.d.ts +5 -0
  54. package/dist/NodeManager/node/api/middlewares/index.js +7 -0
  55. package/dist/NodeManager/node/api/middlewares/rest/verifyBackendSignatureMiddleware.d.ts +3 -0
  56. package/dist/NodeManager/node/api/middlewares/rest/verifyBackendSignatureMiddleware.js +20 -0
  57. package/dist/NodeManager/node/api/middlewares/rest/verifyJobOwnerSignatureMiddleware.d.ts +5 -0
  58. package/dist/NodeManager/node/api/middlewares/rest/verifyJobOwnerSignatureMiddleware.js +28 -0
  59. package/dist/NodeManager/node/api/middlewares/ws/verifyWSJobOwnerSignatureMiddleware.d.ts +6 -0
  60. package/dist/NodeManager/node/api/middlewares/ws/verifyWSJobOwnerSignatureMiddleware.js +30 -0
  61. package/dist/NodeManager/node/api/middlewares/ws/verifyWSMiddleware.d.ts +6 -0
  62. package/dist/NodeManager/node/api/middlewares/ws/verifyWSMiddleware.js +20 -0
  63. package/dist/NodeManager/node/api/middlewares/ws/verifyWSNodeOrJobOwnerSignatureMiddleware.d.ts +6 -0
  64. package/dist/NodeManager/node/api/middlewares/ws/verifyWSNodeOrJobOwnerSignatureMiddleware.js +33 -0
  65. package/dist/NodeManager/node/api/routes/get/index.d.ts +6 -0
  66. package/dist/NodeManager/node/api/routes/get/index.js +6 -0
  67. package/dist/NodeManager/node/api/routes/get/job-definition.d.ts +5 -0
  68. package/dist/NodeManager/node/api/routes/get/job-definition.js +16 -0
  69. package/dist/NodeManager/node/api/routes/get/job-info/buildInfoObject.d.ts +17 -0
  70. package/dist/NodeManager/node/api/routes/get/job-info/buildInfoObject.js +15 -0
  71. package/dist/NodeManager/node/api/routes/get/job-info/job-info.d.ts +5 -0
  72. package/dist/NodeManager/node/api/routes/get/job-info/job-info.js +18 -0
  73. package/dist/NodeManager/node/api/routes/get/job-info/pollActiveJob.d.ts +6 -0
  74. package/dist/NodeManager/node/api/routes/get/job-info/pollActiveJob.js +42 -0
  75. package/dist/NodeManager/node/api/routes/get/job-operation-info.d.ts +28 -0
  76. package/dist/NodeManager/node/api/routes/get/job-operation-info.js +53 -0
  77. package/dist/NodeManager/node/api/routes/get/job-results.d.ts +5 -0
  78. package/dist/NodeManager/node/api/routes/get/job-results.js +15 -0
  79. package/dist/NodeManager/node/api/routes/get/node-info.d.ts +3 -0
  80. package/dist/NodeManager/node/api/routes/get/node-info.js +23 -0
  81. package/dist/NodeManager/node/api/routes/get/service-url.d.ts +5 -0
  82. package/dist/NodeManager/node/api/routes/get/service-url.js +27 -0
  83. package/dist/NodeManager/node/api/routes/index.d.ts +3 -0
  84. package/dist/NodeManager/node/api/routes/index.js +3 -0
  85. package/dist/NodeManager/node/api/routes/post/index.d.ts +4 -0
  86. package/dist/NodeManager/node/api/routes/post/index.js +4 -0
  87. package/dist/NodeManager/node/api/routes/post/job-definition.d.ts +6 -0
  88. package/dist/NodeManager/node/api/routes/post/job-definition.js +15 -0
  89. package/dist/NodeManager/node/api/routes/post/job-operation-actions.d.ts +24 -0
  90. package/dist/NodeManager/node/api/routes/post/job-operation-actions.js +79 -0
  91. package/dist/NodeManager/node/api/routes/post/node-validation.d.ts +4 -0
  92. package/dist/NodeManager/node/api/routes/post/node-validation.js +1783 -0
  93. package/dist/NodeManager/node/api/routes/post/service-stop.d.ts +5 -0
  94. package/dist/NodeManager/node/api/routes/post/service-stop.js +13 -0
  95. package/dist/NodeManager/node/api/routes/wss/index.d.ts +2 -0
  96. package/dist/NodeManager/node/api/routes/wss/index.js +2 -0
  97. package/dist/NodeManager/node/api/routes/wss/log.d.ts +14 -0
  98. package/dist/NodeManager/node/api/routes/wss/log.js +34 -0
  99. package/dist/NodeManager/node/api/routes/wss/status.d.ts +8 -0
  100. package/dist/NodeManager/node/api/routes/wss/status.js +11 -0
  101. package/dist/NodeManager/node/api/types/index.d.ts +12 -0
  102. package/dist/NodeManager/node/api/types/index.js +1 -0
  103. package/dist/NodeManager/node/balance/balanceHandler.d.ts +12 -0
  104. package/dist/NodeManager/node/balance/balanceHandler.js +52 -0
  105. package/dist/NodeManager/node/expiry/expiryHandler.d.ts +24 -0
  106. package/dist/NodeManager/node/expiry/expiryHandler.js +99 -0
  107. package/dist/NodeManager/node/grid/gridHandler.d.ts +19 -0
  108. package/dist/NodeManager/node/grid/gridHandler.js +168 -0
  109. package/dist/NodeManager/node/health/healthHandler.d.ts +16 -0
  110. package/dist/NodeManager/node/health/healthHandler.js +69 -0
  111. package/dist/NodeManager/node/job/JobRegistry.d.ts +14 -0
  112. package/dist/NodeManager/node/job/JobRegistry.js +48 -0
  113. package/dist/NodeManager/node/job/defination/JobDefinitionStrategy.d.ts +13 -0
  114. package/dist/NodeManager/node/job/defination/JobDefinitionStrategy.js +21 -0
  115. package/dist/NodeManager/node/job/defination/strategy/ApiJobDefinitionStrategy.d.ts +8 -0
  116. package/dist/NodeManager/node/job/defination/strategy/ApiJobDefinitionStrategy.js +40 -0
  117. package/dist/NodeManager/node/job/defination/strategy/ApiListenJobDefinitionStrategy.d.ts +9 -0
  118. package/dist/NodeManager/node/job/defination/strategy/ApiListenJobDefinitionStrategy.js +16 -0
  119. package/dist/NodeManager/node/job/defination/strategy/IpfsJobDefinitionStrategy.d.ts +7 -0
  120. package/dist/NodeManager/node/job/defination/strategy/IpfsJobDefinitionStrategy.js +13 -0
  121. package/dist/NodeManager/node/job/jobExternalUtil.d.ts +10 -0
  122. package/dist/NodeManager/node/job/jobExternalUtil.js +82 -0
  123. package/dist/NodeManager/node/job/jobHandler.d.ts +43 -0
  124. package/dist/NodeManager/node/job/jobHandler.js +193 -0
  125. package/dist/NodeManager/node/job/result/ResultReturnStrategy.d.ts +13 -0
  126. package/dist/NodeManager/node/job/result/ResultReturnStrategy.js +21 -0
  127. package/dist/NodeManager/node/job/result/startegy/ApiListenResultReturnStrategy.d.ts +8 -0
  128. package/dist/NodeManager/node/job/result/startegy/ApiListenResultReturnStrategy.js +22 -0
  129. package/dist/NodeManager/node/job/result/startegy/ApiResultReturnStrategy.d.ts +8 -0
  130. package/dist/NodeManager/node/job/result/startegy/ApiResultReturnStrategy.js +42 -0
  131. package/dist/NodeManager/node/key/keyHandler.d.ts +16 -0
  132. package/dist/NodeManager/node/key/keyHandler.js +74 -0
  133. package/dist/NodeManager/node/market/marketHandler.d.ts +30 -0
  134. package/dist/NodeManager/node/market/marketHandler.js +137 -0
  135. package/dist/NodeManager/node/register/index.d.ts +16 -0
  136. package/dist/NodeManager/node/register/index.js +88 -0
  137. package/dist/NodeManager/node/resource/definition/index.d.ts +2 -0
  138. package/dist/NodeManager/node/resource/definition/index.js +2 -0
  139. package/dist/NodeManager/node/resource/helpers/createHFArgs.d.ts +6 -0
  140. package/dist/NodeManager/node/resource/helpers/createHFArgs.js +26 -0
  141. package/dist/NodeManager/node/resource/helpers/createOllamaArgs.d.ts +2 -0
  142. package/dist/NodeManager/node/resource/helpers/createOllamaArgs.js +20 -0
  143. package/dist/NodeManager/node/resource/helpers/createResourceName.d.ts +2 -0
  144. package/dist/NodeManager/node/resource/helpers/createResourceName.js +18 -0
  145. package/dist/NodeManager/node/resource/helpers/createS3Args.d.ts +7 -0
  146. package/dist/NodeManager/node/resource/helpers/createS3Args.js +32 -0
  147. package/dist/NodeManager/node/resource/helpers/hasDockerVolume.d.ts +2 -0
  148. package/dist/NodeManager/node/resource/helpers/hasDockerVolume.js +3 -0
  149. package/dist/NodeManager/node/resource/helpers/hoursSunceDate.d.ts +1 -0
  150. package/dist/NodeManager/node/resource/helpers/hoursSunceDate.js +3 -0
  151. package/dist/NodeManager/node/resource/helpers/repoTagsContainsImage.d.ts +1 -0
  152. package/dist/NodeManager/node/resource/helpers/repoTagsContainsImage.js +13 -0
  153. package/dist/NodeManager/node/resource/image/imageManager.d.ts +13 -0
  154. package/dist/NodeManager/node/resource/image/imageManager.js +66 -0
  155. package/dist/NodeManager/node/resource/resourceManager.d.ts +21 -0
  156. package/dist/NodeManager/node/resource/resourceManager.js +57 -0
  157. package/dist/NodeManager/node/resource/volume/volumeManager.d.ts +20 -0
  158. package/dist/NodeManager/node/resource/volume/volumeManager.js +228 -0
  159. package/dist/NodeManager/node/run/runHandler.d.ts +18 -0
  160. package/dist/NodeManager/node/run/runHandler.js +139 -0
  161. package/dist/NodeManager/node/specs/specsHandler.d.ts +17 -0
  162. package/dist/NodeManager/node/specs/specsHandler.js +135 -0
  163. package/dist/NodeManager/node/specs/type.d.ts +15 -0
  164. package/dist/NodeManager/node/specs/type.js +1 -0
  165. package/dist/NodeManager/node/stake/StakeHandler.d.ts +22 -0
  166. package/dist/NodeManager/node/stake/StakeHandler.js +111 -0
  167. package/dist/NodeManager/node/task/TaskManager.d.ts +267 -0
  168. package/dist/NodeManager/node/task/TaskManager.js +480 -0
  169. package/dist/NodeManager/node/task/TaskManagerRegistry.d.ts +49 -0
  170. package/dist/NodeManager/node/task/TaskManagerRegistry.js +68 -0
  171. package/dist/NodeManager/node/task/executions/createDependencyMap.d.ts +18 -0
  172. package/dist/NodeManager/node/task/executions/createDependencyMap.js +32 -0
  173. package/dist/NodeManager/node/task/executions/createExecutionPlan.d.ts +14 -0
  174. package/dist/NodeManager/node/task/executions/createExecutionPlan.js +36 -0
  175. package/dist/NodeManager/node/task/executions/createOperationMap.d.ts +11 -0
  176. package/dist/NodeManager/node/task/executions/createOperationMap.js +34 -0
  177. package/dist/NodeManager/node/task/executions/validateExecutionPlan.d.ts +12 -0
  178. package/dist/NodeManager/node/task/executions/validateExecutionPlan.js +48 -0
  179. package/dist/NodeManager/node/task/globalStore/finalizeEnv.d.ts +2 -0
  180. package/dist/NodeManager/node/task/globalStore/finalizeEnv.js +30 -0
  181. package/dist/NodeManager/node/task/globalStore/getByPath.d.ts +2 -0
  182. package/dist/NodeManager/node/task/globalStore/getByPath.js +12 -0
  183. package/dist/NodeManager/node/task/globalStore/index.d.ts +9 -0
  184. package/dist/NodeManager/node/task/globalStore/index.js +9 -0
  185. package/dist/NodeManager/node/task/globalStore/interpolate.d.ts +2 -0
  186. package/dist/NodeManager/node/task/globalStore/interpolate.js +16 -0
  187. package/dist/NodeManager/node/task/globalStore/interpolateOperation.d.ts +3 -0
  188. package/dist/NodeManager/node/task/globalStore/interpolateOperation.js +221 -0
  189. package/dist/NodeManager/node/task/globalStore/resolveLiteralsInString.d.ts +2 -0
  190. package/dist/NodeManager/node/task/globalStore/resolveLiteralsInString.js +7 -0
  191. package/dist/NodeManager/node/task/globalStore/setDefaults.d.ts +4 -0
  192. package/dist/NodeManager/node/task/globalStore/setDefaults.js +65 -0
  193. package/dist/NodeManager/node/task/globalStore/setHost.d.ts +2 -0
  194. package/dist/NodeManager/node/task/globalStore/setHost.js +9 -0
  195. package/dist/NodeManager/node/task/globalStore/setResult.d.ts +2 -0
  196. package/dist/NodeManager/node/task/globalStore/setResult.js +10 -0
  197. package/dist/NodeManager/node/task/globalStore/setResults.d.ts +2 -0
  198. package/dist/NodeManager/node/task/globalStore/setResults.js +9 -0
  199. package/dist/NodeManager/node/task/globalStore/stanatizeArrays.d.ts +2 -0
  200. package/dist/NodeManager/node/task/globalStore/stanatizeArrays.js +14 -0
  201. package/dist/NodeManager/node/task/globalStore/transformCollections.d.ts +13 -0
  202. package/dist/NodeManager/node/task/globalStore/transformCollections.js +152 -0
  203. package/dist/NodeManager/node/task/helpers/createDefaultOpState.d.ts +2 -0
  204. package/dist/NodeManager/node/task/helpers/createDefaultOpState.js +20 -0
  205. package/dist/NodeManager/node/task/helpers/createInitialFlow.d.ts +8 -0
  206. package/dist/NodeManager/node/task/helpers/createInitialFlow.js +24 -0
  207. package/dist/NodeManager/node/task/loggers/logManager.d.ts +8 -0
  208. package/dist/NodeManager/node/task/loggers/logManager.js +54 -0
  209. package/dist/NodeManager/node/task/operations/getOperationsInfos.d.ts +6 -0
  210. package/dist/NodeManager/node/task/operations/getOperationsInfos.js +33 -0
  211. package/dist/NodeManager/node/task/operations/moveTaskManagerGroupOperation.d.ts +2 -0
  212. package/dist/NodeManager/node/task/operations/moveTaskManagerGroupOperation.js +65 -0
  213. package/dist/NodeManager/node/task/operations/restartTaskManagerGroupOperation.d.ts +10 -0
  214. package/dist/NodeManager/node/task/operations/restartTaskManagerGroupOperation.js +37 -0
  215. package/dist/NodeManager/node/task/operations/restartTaskManagerOperation.d.ts +14 -0
  216. package/dist/NodeManager/node/task/operations/restartTaskManagerOperation.js +117 -0
  217. package/dist/NodeManager/node/task/operations/runTaskManagerOperation.d.ts +21 -0
  218. package/dist/NodeManager/node/task/operations/runTaskManagerOperation.js +488 -0
  219. package/dist/NodeManager/node/task/operations/stopAllTaskManagerOperations.d.ts +21 -0
  220. package/dist/NodeManager/node/task/operations/stopAllTaskManagerOperations.js +54 -0
  221. package/dist/NodeManager/node/task/operations/stopTaskManagerGroupOperation.d.ts +10 -0
  222. package/dist/NodeManager/node/task/operations/stopTaskManagerGroupOperation.js +43 -0
  223. package/dist/NodeManager/node/task/operations/stopTaskManagerOperation.d.ts +14 -0
  224. package/dist/NodeManager/node/task/operations/stopTaskManagerOperation.js +137 -0
  225. package/dist/NodeManager/node/utils/convertFromBytes.d.ts +4 -0
  226. package/dist/NodeManager/node/utils/convertFromBytes.js +11 -0
  227. package/dist/NodeManager/node/utils/extractLogsAndResultsFromLogBuffer.d.ts +7 -0
  228. package/dist/NodeManager/node/utils/extractLogsAndResultsFromLogBuffer.js +34 -0
  229. package/dist/NodeManager/node/utils/extractResultsFromLogs.d.ts +18 -0
  230. package/dist/NodeManager/node/utils/extractResultsFromLogs.js +37 -0
  231. package/dist/NodeManager/node/utils/generateRandomId.d.ts +1 -0
  232. package/dist/NodeManager/node/utils/generateRandomId.js +3 -0
  233. package/dist/NodeManager/node/utils/multiProgressBarReporter.d.ts +16 -0
  234. package/dist/NodeManager/node/utils/multiProgressBarReporter.js +22 -0
  235. package/dist/NodeManager/node/utils/poll.d.ts +5 -0
  236. package/dist/NodeManager/node/utils/poll.js +25 -0
  237. package/dist/NodeManager/node/utils/progressBarReporter.d.ts +9 -0
  238. package/dist/NodeManager/node/utils/progressBarReporter.js +28 -0
  239. package/dist/NodeManager/provider/ContainerStateManager.d.ts +24 -0
  240. package/dist/NodeManager/provider/ContainerStateManager.js +122 -0
  241. package/dist/NodeManager/provider/ExposedPortHealthCheck.d.ts +29 -0
  242. package/dist/NodeManager/provider/ExposedPortHealthCheck.js +183 -0
  243. package/dist/NodeManager/provider/Provider.d.ts +70 -0
  244. package/dist/NodeManager/provider/Provider.js +457 -0
  245. package/dist/NodeManager/provider/__tests__/Provider.spec.d.ts +1 -0
  246. package/dist/NodeManager/provider/__tests__/Provider.spec.js +337 -0
  247. package/dist/NodeManager/provider/containerOrchestration/docker/dockerExtended/index.d.ts +6 -0
  248. package/dist/NodeManager/provider/containerOrchestration/docker/dockerExtended/index.js +45 -0
  249. package/dist/NodeManager/provider/containerOrchestration/docker/index.d.ts +43 -0
  250. package/dist/NodeManager/provider/containerOrchestration/docker/index.js +366 -0
  251. package/dist/NodeManager/provider/containerOrchestration/docker/utils/createServerObject.d.ts +5 -0
  252. package/dist/NodeManager/provider/containerOrchestration/docker/utils/createServerObject.js +15 -0
  253. package/dist/NodeManager/provider/containerOrchestration/docker/utils/deadline.d.ts +1 -0
  254. package/dist/NodeManager/provider/containerOrchestration/docker/utils/deadline.js +15 -0
  255. package/dist/NodeManager/provider/containerOrchestration/docker/utils/repoTagsContainsImage.d.ts +1 -0
  256. package/dist/NodeManager/provider/containerOrchestration/docker/utils/repoTagsContainsImage.js +13 -0
  257. package/dist/NodeManager/provider/containerOrchestration/interface.d.ts +53 -0
  258. package/dist/NodeManager/provider/containerOrchestration/interface.js +1 -0
  259. package/dist/NodeManager/provider/containerOrchestration/podman/index.d.ts +11 -0
  260. package/dist/NodeManager/provider/containerOrchestration/podman/index.js +69 -0
  261. package/dist/NodeManager/provider/containerOrchestration/podman/utils/createPodmanRunOptions.d.ts +103 -0
  262. package/dist/NodeManager/provider/containerOrchestration/podman/utils/createPodmanRunOptions.js +66 -0
  263. package/dist/NodeManager/provider/containerOrchestration/selectContainerOrchestration.d.ts +2 -0
  264. package/dist/NodeManager/provider/containerOrchestration/selectContainerOrchestration.js +11 -0
  265. package/dist/NodeManager/provider/types.d.ts +18 -0
  266. package/dist/NodeManager/provider/types.js +1 -0
  267. package/dist/NodeManager/provider/utils/parseBuffer.d.ts +4 -0
  268. package/dist/NodeManager/provider/utils/parseBuffer.js +19 -0
  269. package/dist/NodeManager/repository/NodeRepository.d.ts +53 -0
  270. package/dist/NodeManager/repository/NodeRepository.js +153 -0
  271. package/dist/NodeManager/sdk/index.d.ts +9 -0
  272. package/dist/NodeManager/sdk/index.js +146 -0
  273. package/dist/NodeManager/types/index.d.ts +27 -0
  274. package/dist/NodeManager/types/index.js +1 -0
  275. package/dist/NodeManager/utils/convertFromBytes.d.ts +4 -0
  276. package/dist/NodeManager/utils/convertFromBytes.js +11 -0
  277. package/dist/NodeManager/utils/expose-util.d.ts +14 -0
  278. package/dist/NodeManager/utils/expose-util.js +88 -0
  279. package/dist/NodeManager/utils/jobDefinitionParser.d.ts +12 -0
  280. package/dist/NodeManager/utils/jobDefinitionParser.js +31 -0
  281. package/dist/NodeManager/utils/ops-util.d.ts +3 -0
  282. package/dist/NodeManager/utils/ops-util.js +19 -0
  283. package/dist/NodeManager/utils/timeoutPromiseWrapper.d.ts +1 -0
  284. package/dist/NodeManager/utils/timeoutPromiseWrapper.js +27 -0
  285. package/dist/NodeManager/utils/utils.d.ts +39 -0
  286. package/dist/NodeManager/utils/utils.js +107 -0
  287. package/dist/NodeManager/utils/wslCheck.d.ts +14 -0
  288. package/dist/NodeManager/utils/wslCheck.js +54 -0
  289. package/dist/cli/address/__tests__/command.spec.d.ts +1 -0
  290. package/dist/cli/address/__tests__/command.spec.js +33 -0
  291. package/dist/cli/address/action.d.ts +4 -0
  292. package/dist/cli/address/action.js +4 -0
  293. package/dist/cli/address/command.d.ts +2 -0
  294. package/dist/cli/address/command.js +9 -0
  295. package/dist/cli/createNosanaCli.d.ts +2 -0
  296. package/dist/cli/createNosanaCli.js +32 -0
  297. package/dist/cli/index.d.ts +1 -0
  298. package/dist/cli/index.js +16 -0
  299. package/dist/cli/node/__tests__/index.spec.d.ts +1 -0
  300. package/dist/cli/node/__tests__/index.spec.js +10 -0
  301. package/dist/cli/node/index.d.ts +5 -0
  302. package/dist/cli/node/index.js +12 -0
  303. package/dist/cli/node/prune/action.d.ts +4 -0
  304. package/dist/cli/node/prune/action.js +18 -0
  305. package/dist/cli/node/prune/command.d.ts +2 -0
  306. package/dist/cli/node/prune/command.js +10 -0
  307. package/dist/cli/node/run/__tests__/command.spec.d.ts +1 -0
  308. package/dist/cli/node/run/__tests__/command.spec.js +38 -0
  309. package/dist/cli/node/run/action.d.ts +3 -0
  310. package/dist/cli/node/run/action.js +82 -0
  311. package/dist/cli/node/run/command.d.ts +3 -0
  312. package/dist/cli/node/run/command.js +17 -0
  313. package/dist/cli/node/run/generateDeploymentEndpointsTable.d.ts +2 -0
  314. package/dist/cli/node/run/generateDeploymentEndpointsTable.js +45 -0
  315. package/dist/cli/node/start/__tests__/command.spec.d.ts +1 -0
  316. package/dist/cli/node/start/__tests__/command.spec.js +39 -0
  317. package/dist/cli/node/start/action.d.ts +4 -0
  318. package/dist/cli/node/start/action.js +48 -0
  319. package/dist/cli/node/start/command.d.ts +3 -0
  320. package/dist/cli/node/start/command.js +19 -0
  321. package/dist/cli/sharedOptions/--api.d.ts +2 -0
  322. package/dist/cli/sharedOptions/--api.js +2 -0
  323. package/dist/cli/sharedOptions/--format.d.ts +2 -0
  324. package/dist/cli/sharedOptions/--format.js +4 -0
  325. package/dist/cli/sharedOptions/--gpu.d.ts +2 -0
  326. package/dist/cli/sharedOptions/--gpu.js +12 -0
  327. package/dist/cli/sharedOptions/--network.d.ts +2 -0
  328. package/dist/cli/sharedOptions/--network.js +4 -0
  329. package/dist/cli/sharedOptions/--port.d.ts +2 -0
  330. package/dist/cli/sharedOptions/--port.js +2 -0
  331. package/dist/cli/sharedOptions/--rpc.d.ts +2 -0
  332. package/dist/cli/sharedOptions/--rpc.js +2 -0
  333. package/dist/cli/sharedOptions/--timeout.d.ts +2 -0
  334. package/dist/cli/sharedOptions/--timeout.js +12 -0
  335. package/dist/cli/sharedOptions/--verbose.d.ts +2 -0
  336. package/dist/cli/sharedOptions/--verbose.js +2 -0
  337. package/dist/cli/sharedOptions/--wallet.d.ts +2 -0
  338. package/dist/cli/sharedOptions/--wallet.js +2 -0
  339. package/dist/cli/sharedOptions/index.d.ts +7 -0
  340. package/dist/cli/sharedOptions/index.js +8 -0
  341. package/dist/index.d.ts +3 -0
  342. package/dist/index.js +7 -0
  343. package/dist/output-formatter/OutputFormatter.d.ts +61 -0
  344. package/dist/output-formatter/OutputFormatter.js +58 -0
  345. package/dist/output-formatter/OutputFormatterFactory.d.ts +4 -0
  346. package/dist/output-formatter/OutputFormatterFactory.js +18 -0
  347. package/dist/output-formatter/__mocks__/outputEvents.mock.d.ts +42 -0
  348. package/dist/output-formatter/__mocks__/outputEvents.mock.js +45 -0
  349. package/dist/output-formatter/__mocks__/outputFormatter.mock.d.ts +0 -0
  350. package/dist/output-formatter/__mocks__/outputFormatter.mock.js +21 -0
  351. package/dist/output-formatter/__tests__/OutputFormatter.spec.d.ts +1 -0
  352. package/dist/output-formatter/__tests__/OutputFormatter.spec.js +34 -0
  353. package/dist/output-formatter/__tests__/OutputFormatterFactory.spec.d.ts +1 -0
  354. package/dist/output-formatter/__tests__/OutputFormatterFactory.spec.js +26 -0
  355. package/dist/output-formatter/__tests__/outputFormatSelector.spec.d.ts +1 -0
  356. package/dist/output-formatter/__tests__/outputFormatSelector.spec.js +21 -0
  357. package/dist/output-formatter/json/JsonOutputEventHandlers.d.ts +8 -0
  358. package/dist/output-formatter/json/JsonOutputEventHandlers.js +191 -0
  359. package/dist/output-formatter/json/JsonOutputFormatter.d.ts +47 -0
  360. package/dist/output-formatter/json/JsonOutputFormatter.js +12 -0
  361. package/dist/output-formatter/json/__tests__/JsonOutputFormatter.spec.d.ts +1 -0
  362. package/dist/output-formatter/json/__tests__/JsonOutputFormatter.spec.js +36 -0
  363. package/dist/output-formatter/outputEvents.d.ts +213 -0
  364. package/dist/output-formatter/outputEvents.js +63 -0
  365. package/dist/output-formatter/outputFormatArgumentParser.d.ts +1 -0
  366. package/dist/output-formatter/outputFormatArgumentParser.js +10 -0
  367. package/dist/output-formatter/outputFormatSelector.d.ts +15 -0
  368. package/dist/output-formatter/outputFormatSelector.js +23 -0
  369. package/dist/output-formatter/text/TextOutputEventHandlers.d.ts +7 -0
  370. package/dist/output-formatter/text/TextOutputEventHandlers.js +128 -0
  371. package/dist/output-formatter/text/TextOutputFormatter.d.ts +6 -0
  372. package/dist/output-formatter/text/TextOutputFormatter.js +7 -0
  373. package/dist/output-formatter/text/VerboseTextOutputEventHandlers.d.ts +7 -0
  374. package/dist/output-formatter/text/VerboseTextOutputEventHandlers.js +138 -0
  375. package/dist/output-formatter/text/VerboseTextOutputFormatter.d.ts +6 -0
  376. package/dist/output-formatter/text/VerboseTextOutputFormatter.js +7 -0
  377. package/dist/output-formatter/text/__tests__/TextOutputFormatter.spec.d.ts +1 -0
  378. package/dist/output-formatter/text/__tests__/TextOutputFormatter.spec.js +25 -0
  379. package/dist/static/index.d.ts +7 -0
  380. package/dist/static/index.js +12 -0
  381. package/dist/version/index.d.ts +1 -0
  382. package/dist/version/index.js +47 -0
  383. package/npm-shrinkwrap.json +9928 -0
  384. package/package.json +102 -0
@@ -0,0 +1,228 @@
1
+ import { Presets } from 'cli-progress';
2
+ import { extractLogsAndResultsFromLogBuffer } from '../../utils/extractLogsAndResultsFromLogBuffer.js';
3
+ import { applyLoggingProxyToClass } from '../../../monitoring/proxy/loggingProxy.js';
4
+ import { ProgressBarReporter } from '../../utils/progressBarReporter.js';
5
+ import { createResourceName } from '../helpers/createResourceName.js';
6
+ import { hasDockerVolume } from '../helpers/hasDockerVolume.js';
7
+ import { hoursSinceDate } from '../helpers/hoursSunceDate.js';
8
+ import { nosanaBucket, s3HelperImage } from '../definition/index.js';
9
+ import { convertFromBytes } from '../../utils/convertFromBytes.js';
10
+ import { createHFArgs } from '../helpers/createHFArgs.js';
11
+ import { createS3Args } from '../helpers/createS3Args.js';
12
+ import { createOllamaArgs } from '../helpers/createOllamaArgs.js';
13
+ export class VolumeManager {
14
+ constructor(containerOrchestration, repository) {
15
+ this.containerOrchestration = containerOrchestration;
16
+ this.repository = repository;
17
+ this.fetched = false;
18
+ this.market_required_volumes = [];
19
+ this.progressBarReporter = new ProgressBarReporter();
20
+ applyLoggingProxyToClass(this);
21
+ }
22
+ async pullMarketRequiredVolumes(remoteResources) {
23
+ this.fetched = true;
24
+ this.market_required_volumes = remoteResources;
25
+ const hasResourceManagerImage = await this.containerOrchestration.hasImage(s3HelperImage);
26
+ if (!hasResourceManagerImage) {
27
+ await this.containerOrchestration.pullImage(s3HelperImage);
28
+ }
29
+ const controller = new AbortController();
30
+ const savedVolumes = this.repository.getVolumesResources();
31
+ for (const resource of this.market_required_volumes) {
32
+ if (!savedVolumes[createResourceName(resource)]) {
33
+ await this.createRemoteVolume(resource, controller);
34
+ }
35
+ }
36
+ }
37
+ async createRemoteVolume(resource, controller) {
38
+ const resourceName = createResourceName(resource);
39
+ let volumeName = this.repository.getVolumeResource(resourceName)?.volume;
40
+ let sync = true;
41
+ if (!volumeName) {
42
+ sync = false;
43
+ const response = await this.containerOrchestration.createVolume();
44
+ // @ts-ignore **PODMAN returns name not Name**
45
+ if (response.name) {
46
+ // @ts-ignore **PODMAN returns name not Name**
47
+ volumeName = response.name;
48
+ }
49
+ else {
50
+ volumeName = response.Name;
51
+ }
52
+ }
53
+ switch (resource.type) {
54
+ case 'S3':
55
+ const s3Resource = resource;
56
+ try {
57
+ if (s3Resource.url) {
58
+ const args = createS3Args(volumeName, {
59
+ url: s3Resource.url,
60
+ files: s3Resource.files,
61
+ bucket: s3Resource.bucket,
62
+ }, s3Resource.IAM);
63
+ await this.runResourceManagerContainer(volumeName, resourceName, args, controller, sync);
64
+ }
65
+ else {
66
+ for (const bucket of s3Resource.buckets) {
67
+ const args = createS3Args(volumeName, { url: bucket.url, files: bucket.files }, s3Resource.IAM);
68
+ await this.runResourceManagerContainer(volumeName, resourceName, args, controller, sync);
69
+ }
70
+ }
71
+ this.setVolume(resourceName, volumeName);
72
+ }
73
+ catch (err) {
74
+ throw new Error(err.message);
75
+ }
76
+ break;
77
+ case 'HF':
78
+ try {
79
+ const { repo, revision, files: hfFiles, accessToken, } = resource;
80
+ const args = createHFArgs(volumeName, { repo, revision, files: hfFiles }, accessToken);
81
+ await this.runResourceManagerContainer(volumeName, resourceName, args, controller, sync);
82
+ this.setVolume(resourceName, volumeName);
83
+ }
84
+ catch (err) {
85
+ throw new Error(err.message);
86
+ }
87
+ break;
88
+ case 'Ollama':
89
+ try {
90
+ const { model } = resource;
91
+ const args = createOllamaArgs(volumeName, model);
92
+ await this.runResourceManagerContainer(volumeName, resourceName, args, controller, sync);
93
+ this.setVolume(resourceName, volumeName);
94
+ }
95
+ catch (err) {
96
+ throw new Error(err.message);
97
+ }
98
+ break;
99
+ }
100
+ return volumeName;
101
+ }
102
+ async runResourceManagerContainer(volume, name, args, controller, syncing = false) {
103
+ const container = await this.containerOrchestration.runContainer(args);
104
+ const logStream = await container.logs({
105
+ stdout: true,
106
+ stderr: false,
107
+ follow: true,
108
+ abortSignal: controller?.signal,
109
+ });
110
+ let start = false;
111
+ let formatSize = 'kb';
112
+ logStream.on('data', (logBuffer) => {
113
+ try {
114
+ const logString = logBuffer.toString('utf8');
115
+ const logJSON = JSON.parse(logString.slice(8, logString.length - 1));
116
+ if (!start && logJSON.event === 'status') {
117
+ start = true;
118
+ const { value, format } = convertFromBytes(logJSON.size.total);
119
+ formatSize = format;
120
+ this.progressBarReporter.start(`${syncing ? 'Syncing' : 'Downloading'} resource ${name}`, {
121
+ format: `{bar} {percentage}% | {value}/{total}${format} | {valueFiles}/{totalFiles} files`,
122
+ }, value, 0, {
123
+ valueFiles: 0,
124
+ totalFiles: logJSON.count.total,
125
+ }, Presets.shades_classic);
126
+ }
127
+ else if (logJSON.event === 'status') {
128
+ const { value } = convertFromBytes(logJSON.size.current, formatSize);
129
+ this.progressBarReporter.update(value, {
130
+ valueFiles: logJSON.count.current,
131
+ });
132
+ }
133
+ }
134
+ catch (error) { }
135
+ });
136
+ const { StatusCode } = await container.wait({
137
+ condition: 'not-running',
138
+ abortSignal: controller?.signal,
139
+ });
140
+ // If download failed, remove volume
141
+ if (StatusCode !== 0) {
142
+ this.progressBarReporter.stop(`${syncing ? 'Syncing' : 'Downloading'} resource ${name} stopped`);
143
+ const errrorBuffer = await container.logs({
144
+ follow: false,
145
+ stdout: false,
146
+ stderr: true,
147
+ tail: 24999,
148
+ timestamps: true,
149
+ });
150
+ const { logs } = extractLogsAndResultsFromLogBuffer(errrorBuffer, undefined);
151
+ await container.remove({ force: true });
152
+ await this.containerOrchestration.deleteVolume(volume);
153
+ const errorLog = logs.find(({ log }) => log?.startsWith('Error:'));
154
+ if (errorLog) {
155
+ throw new Error(errorLog.log?.replace('Error: ', ''));
156
+ }
157
+ }
158
+ this.progressBarReporter.stop(`${syncing ? 'Synced' : 'Downloaded'} resource ${name} completed`);
159
+ await this.containerOrchestration.stopAndDeleteContainer(container.id);
160
+ }
161
+ async setVolume(bucket, volume) {
162
+ const volumeObj = this.repository.getVolumeResource(bucket);
163
+ this.repository.updateVolumeResource(bucket, {
164
+ volume,
165
+ required: this.market_required_volumes.some((vol) => createResourceName(vol) === bucket),
166
+ lastUsed: new Date(),
167
+ usage: volumeObj?.usage + 1 || 1,
168
+ });
169
+ }
170
+ async hasVolume(resource) {
171
+ const volume = this.repository.getVolumeResource(createResourceName(resource))?.volume;
172
+ if (!volume) {
173
+ return false;
174
+ }
175
+ const dockerHasVolume = await this.containerOrchestration.hasVolume(volume);
176
+ if (!dockerHasVolume) {
177
+ this.repository.deleteVolumeResource(createResourceName(resource));
178
+ }
179
+ return dockerHasVolume;
180
+ }
181
+ async getVolume(resource) {
182
+ return this.repository.getVolumeResource(createResourceName(resource))
183
+ ?.volume;
184
+ }
185
+ async pruneVolumes() {
186
+ const cachedVolumes = await this.containerOrchestration.listVolumes();
187
+ const dbVolume = Object.entries(this.repository.getVolumesResources());
188
+ for (const { Name } of cachedVolumes) {
189
+ const dbEntry = dbVolume.find((vol) => vol[1].volume === Name);
190
+ if (dbEntry && dbEntry[1].required)
191
+ continue;
192
+ await this.containerOrchestration.deleteVolume(Name);
193
+ if (dbEntry) {
194
+ this.repository.deleteVolumeResource(dbEntry[0]);
195
+ }
196
+ }
197
+ }
198
+ async resyncResourcesDB() {
199
+ const savedVolumes = await this.containerOrchestration.listVolumes();
200
+ for (const [resource, value] of Object.entries(this.repository.getVolumesResources())) {
201
+ // RENAME NOSANA S3 BUCKETS TO CLOUDFRONT
202
+ if (resource.includes('s3://nos-ai-models-qllsn32u')) {
203
+ this.repository.updateVolumeResource(`${resource.replace('s3://nos-ai-models-qllsn32u', nosanaBucket)}`, value);
204
+ this.repository.deleteVolumeResource(resource);
205
+ }
206
+ }
207
+ for (const [resource, { volume, lastUsed, required }] of Object.entries(this.repository.getVolumesResources())) {
208
+ if (!hasDockerVolume(volume, savedVolumes)) {
209
+ this.repository.deleteVolumeResource(resource);
210
+ continue;
211
+ }
212
+ if ((!this.fetched && required) ||
213
+ this.market_required_volumes.some((vol) => createResourceName(vol) === resource)) {
214
+ continue;
215
+ }
216
+ const hoursSinceLastUsed = hoursSinceDate(new Date(lastUsed));
217
+ if (hoursSinceLastUsed > 24) {
218
+ try {
219
+ await this.containerOrchestration.deleteVolume(volume);
220
+ this.repository.deleteVolumeResource(volume);
221
+ }
222
+ catch (err) {
223
+ const message = err.json.message;
224
+ }
225
+ }
226
+ }
227
+ }
228
+ }
@@ -0,0 +1,18 @@
1
+ import { Run, Client as SDK } from '@nosana/sdk';
2
+ export declare class RunHandler {
3
+ private sdk;
4
+ private run;
5
+ private address;
6
+ private runSubscriptionId?;
7
+ private getRunsInterval?;
8
+ constructor(sdk: SDK);
9
+ getRun(): Run | undefined;
10
+ setRun(run: Run): void;
11
+ clearRun(): void;
12
+ stopRun(): Promise<boolean>;
13
+ checkRun(): Promise<Run | undefined>;
14
+ startRunMonitoring(callback: Function): Promise<Run>;
15
+ stopRunMonitoring(): void;
16
+ stop(): Promise<void>;
17
+ clean(): Promise<void>;
18
+ }
@@ -0,0 +1,139 @@
1
+ export class RunHandler {
2
+ constructor(sdk) {
3
+ this.sdk = sdk;
4
+ this.address = this.sdk.solana.provider.wallet.publicKey;
5
+ }
6
+ getRun() {
7
+ return this.run;
8
+ }
9
+ setRun(run) {
10
+ this.run = run;
11
+ }
12
+ clearRun() {
13
+ this.run = undefined;
14
+ }
15
+ async stopRun() {
16
+ if (this.run) {
17
+ try {
18
+ await this.sdk.jobs.quit(this.run);
19
+ }
20
+ catch (e) {
21
+ return false;
22
+ }
23
+ }
24
+ return true;
25
+ }
26
+ async checkRun() {
27
+ const runs = await this.sdk.jobs.getRuns([
28
+ {
29
+ memcmp: {
30
+ offset: 40,
31
+ bytes: this.address.toString(),
32
+ },
33
+ },
34
+ ]);
35
+ if (!runs?.length) {
36
+ this.clearRun();
37
+ return this.getRun();
38
+ }
39
+ this.setRun(runs[0]);
40
+ return this.getRun();
41
+ }
42
+ // Start monitoring run status
43
+ async startRunMonitoring(callback) {
44
+ /**
45
+ * we want to check if we have a pending run set
46
+ * (this would be set when checking pending using `@checkRun`)
47
+ * if their is a run, we would return that instead instead of listening
48
+ */
49
+ let run;
50
+ if ((run = this.getRun())) {
51
+ return run;
52
+ }
53
+ return new Promise(async (resolve, reject) => {
54
+ try {
55
+ await this.sdk.jobs.loadNosanaJobs();
56
+ const jobProgram = this.sdk.jobs.jobs;
57
+ const runAccountFilter = jobProgram.coder.accounts.memcmp(jobProgram.account.runAccount.idlAccount.name, undefined);
58
+ const coderFilters = [
59
+ {
60
+ memcmp: {
61
+ offset: runAccountFilter.offset,
62
+ bytes: runAccountFilter.bytes,
63
+ },
64
+ },
65
+ {
66
+ memcmp: {
67
+ offset: 40,
68
+ bytes: this.address.toBase58(), // Convert PublicKey to a string
69
+ },
70
+ },
71
+ ];
72
+ // Set up real-time listener for run status changes
73
+ this.runSubscriptionId =
74
+ this.sdk.jobs.connection.onProgramAccountChange(jobProgram.programId, async (event) => {
75
+ const runAccount = jobProgram.coder.accounts.decode(jobProgram.account.runAccount.idlAccount.name, event.accountInfo.data);
76
+ const run = {
77
+ account: runAccount,
78
+ publicKey: event.accountId,
79
+ };
80
+ this.setRun(run);
81
+ resolve(run);
82
+ }, 'confirmed', coderFilters);
83
+ // Set interval to check run status every 5 minutes
84
+ this.getRunsInterval = setInterval(async () => {
85
+ let run;
86
+ try {
87
+ const health = await callback();
88
+ if (!health) {
89
+ reject(new Error('HealthCheck failed'));
90
+ }
91
+ run = await this.checkRun();
92
+ if (run) {
93
+ resolve(run);
94
+ }
95
+ }
96
+ catch (error) {
97
+ reject(error);
98
+ }
99
+ }, 60000 * 5);
100
+ let run;
101
+ try {
102
+ run = await this.checkRun();
103
+ if (run) {
104
+ resolve(run);
105
+ }
106
+ }
107
+ catch (error) {
108
+ reject(error);
109
+ }
110
+ }
111
+ catch (error) {
112
+ reject(error);
113
+ }
114
+ });
115
+ }
116
+ // Stop monitoring run status
117
+ stopRunMonitoring() {
118
+ if (this.getRunsInterval) {
119
+ clearInterval(this.getRunsInterval);
120
+ this.getRunsInterval = undefined;
121
+ }
122
+ if (this.runSubscriptionId !== undefined) {
123
+ this.sdk.jobs.connection.removeProgramAccountChangeListener(this.runSubscriptionId);
124
+ this.runSubscriptionId = undefined;
125
+ }
126
+ }
127
+ async stop() {
128
+ this.stopRunMonitoring();
129
+ /**
130
+ * we don't want to stop the job/run under any circumstances
131
+ */
132
+ // await this.stopRun();
133
+ this.clearRun();
134
+ }
135
+ async clean() {
136
+ this.stopRunMonitoring();
137
+ this.clearRun();
138
+ }
139
+ }
@@ -0,0 +1,17 @@
1
+ import { Client } from '@nosana/sdk';
2
+ import { Provider } from '../../provider/Provider.js';
3
+ import { NodeRepository } from '../../repository/NodeRepository.js';
4
+ export declare class SpecsHandler {
5
+ private provider;
6
+ private repository;
7
+ private sdk;
8
+ constructor(provider: Provider, repository: NodeRepository, sdk: Client);
9
+ check(): Promise<boolean>;
10
+ private submitSystemSpecs;
11
+ private processSuccess;
12
+ private parseLogsIntoJSON;
13
+ private processFailure;
14
+ private processSystemInfoBenchmark;
15
+ private processNetworkInfoBenchmark;
16
+ private processGPUInfoBenchmark;
17
+ }
@@ -0,0 +1,135 @@
1
+ import { configs } from '../../configs/configs.js';
2
+ import { specsAndNetworkJob } from '../../../static/index.js';
3
+ import { applyLoggingProxyToClass } from '../../monitoring/proxy/loggingProxy.js';
4
+ import TaskManager from '../task/TaskManager.js';
5
+ import { generateRandomId } from '../utils/generateRandomId.js';
6
+ export class SpecsHandler {
7
+ constructor(provider, repository, sdk) {
8
+ this.provider = provider;
9
+ this.repository = repository;
10
+ this.sdk = sdk;
11
+ applyLoggingProxyToClass(this);
12
+ }
13
+ async check() {
14
+ const id = generateRandomId(32);
15
+ const task = new TaskManager(this.provider, this.repository, id, this.sdk.solana.wallet.publicKey.toString(), specsAndNetworkJob);
16
+ try {
17
+ task.bootstrap();
18
+ await task.start();
19
+ }
20
+ catch (error) {
21
+ throw error;
22
+ }
23
+ let result = this.repository.getFlow(id);
24
+ if (result) {
25
+ this.repository.deleteflow(result.id);
26
+ if (result && result.state.status === 'success') {
27
+ await this.processSuccess(result.state.opStates);
28
+ this.repository.updateNodeInfo({
29
+ protocol: this.provider.containerOrchestration.getProtocol(),
30
+ });
31
+ await this.submitSystemSpecs();
32
+ }
33
+ else if (result && result.state.status === 'failed') {
34
+ this.processFailure(result.state.opStates);
35
+ }
36
+ else {
37
+ throw new Error('Cannot find results');
38
+ }
39
+ return true;
40
+ }
41
+ return false;
42
+ }
43
+ async submitSystemSpecs() {
44
+ const nodeInfo = this.repository.getNodeInfo();
45
+ const headers = new Headers();
46
+ headers.append('Authorization', await this.sdk.authorization.generate(configs().signMessage));
47
+ headers.append('Content-Type', 'application/json');
48
+ await fetch(`${configs().backendUrl}/nodes/${this.sdk.solana.provider.wallet.publicKey.toString()}/submit-system-specs`, {
49
+ method: 'POST',
50
+ headers,
51
+ body: JSON.stringify(nodeInfo),
52
+ }).catch((error) => {
53
+ console.error(error);
54
+ });
55
+ }
56
+ processSuccess(opStates) {
57
+ if (!opStates) {
58
+ throw new Error('Missing operation states in result');
59
+ }
60
+ for (const { operationId, logs } of opStates) {
61
+ switch (operationId) {
62
+ case 'system-info':
63
+ this.processSystemInfoBenchmark(logs);
64
+ break;
65
+ case 'network-info':
66
+ this.processNetworkInfoBenchmark(logs);
67
+ break;
68
+ case 'gpu-info':
69
+ this.processGPUInfoBenchmark(logs);
70
+ break;
71
+ }
72
+ }
73
+ }
74
+ parseLogsIntoJSON(logs) {
75
+ return JSON.parse(logs.reduce((result, { log, type }) => type === 'stdout' ? result + log : result, ''));
76
+ }
77
+ processFailure(opStates) {
78
+ const errors = [];
79
+ if (opStates[0]) {
80
+ try {
81
+ const cudaCheckResults = JSON.parse(opStates[0].logs[0].log);
82
+ if (cudaCheckResults.error) {
83
+ errors.push('GPU benchmark failed. Ensure NVidia Cuda runtime drivers and NVidia Container Toolkit are correctly configured.');
84
+ }
85
+ }
86
+ catch (error) {
87
+ errors.push('GPU benchmark returned with no devices.');
88
+ }
89
+ }
90
+ if (opStates[1]) {
91
+ errors.push('Disk space check failed.');
92
+ }
93
+ if (errors.length > 0) {
94
+ throw new Error(errors.join(' '));
95
+ }
96
+ }
97
+ processSystemInfoBenchmark(logs) {
98
+ if (!logs[0])
99
+ throw new Error('Could not find system info logs');
100
+ const { system_environment, cpu_model: model, logical_cores, physical_cores, ram_mb, disk_gb, } = this.parseLogsIntoJSON(logs);
101
+ if (configs().minDiskSpace > disk_gb) {
102
+ throw new Error(`Node does not have enough disk space. Required: ${configs().minDiskSpace}GB, Available: ${disk_gb}GB`);
103
+ }
104
+ this.repository.updateNodeInfo({
105
+ system_environment,
106
+ cpu: {
107
+ model,
108
+ logical_cores,
109
+ physical_cores,
110
+ },
111
+ ram_mb,
112
+ disk_gb,
113
+ });
114
+ }
115
+ processNetworkInfoBenchmark(logs) {
116
+ if (!logs[0])
117
+ throw new Error('Could not find network info logs');
118
+ const { country, ip, ping_ms, download_mbps, upload_mbps } = this.parseLogsIntoJSON(logs);
119
+ this.repository.updateNodeInfo({
120
+ country,
121
+ network: {
122
+ ip,
123
+ ping_ms,
124
+ download_mbps,
125
+ upload_mbps,
126
+ },
127
+ });
128
+ }
129
+ processGPUInfoBenchmark(logs) {
130
+ if (!logs[0])
131
+ throw new Error('Could not find GPU info logs');
132
+ const results = this.parseLogsIntoJSON(logs);
133
+ this.repository.updateNodeInfo({ gpus: results });
134
+ }
135
+ }
@@ -0,0 +1,15 @@
1
+ export type SystemInfoResults = {
2
+ system_environment: string;
3
+ cpu_model: string;
4
+ ram_mb: number;
5
+ disk_gb: number;
6
+ physical_cores: number;
7
+ logical_cores: number;
8
+ };
9
+ export type NetworkInfoResults = {
10
+ ip: string;
11
+ country: string;
12
+ ping_ms: number;
13
+ download_mbps: number;
14
+ upload_mbps: number;
15
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,22 @@
1
+ import { Market, Client as SDK } from '@nosana/sdk';
2
+ import { TokenAmount } from '@solana/web3.js';
3
+ type Stake = {
4
+ amount: number;
5
+ duration: number;
6
+ };
7
+ export declare class StakeHandler {
8
+ private sdk;
9
+ private address;
10
+ private stake;
11
+ constructor(sdk: SDK);
12
+ createAta(): Promise<void>;
13
+ nodeHasStakingAccount(): Promise<boolean>;
14
+ createStakingAccount(): Promise<boolean>;
15
+ topUpStakingAccount(market: Market): Promise<boolean>;
16
+ failTopUpStakingAccount(): Promise<void>;
17
+ getStakeAccount(): Stake;
18
+ canProceedWithoutStake(market: Market, nosBalance: TokenAmount | undefined): boolean;
19
+ getStakeActionInfotext(market: Market): string;
20
+ getStakeActionQuerytext(market: Market): string;
21
+ }
22
+ export {};