@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,337 @@
1
+ import { describe, expect, it, vi, beforeEach } from 'vitest';
2
+ import { Provider } from '../Provider.js';
3
+ import { isOpExposed, getExposePorts } from '@nosana/sdk';
4
+ import { generateProxies } from '../../utils/expose-util.js';
5
+ import EventEmitter from 'events';
6
+ const TEST_SERVER_ADDRESS = 'test.frp.server.com';
7
+ const TEST_SERVER_PORT = 7000;
8
+ const TEST_FRPC_IMAGE = 'test-frpc-image:latest';
9
+ vi.mock('../../configs/configs.js', () => ({
10
+ configs: () => ({
11
+ frp: {
12
+ serverAddr: TEST_SERVER_ADDRESS,
13
+ serverPort: TEST_SERVER_PORT,
14
+ containerImage: TEST_FRPC_IMAGE,
15
+ },
16
+ }),
17
+ }));
18
+ vi.mock('../../configs/NodeConfigs.js', () => ({
19
+ NodeConfigsSingleton: {
20
+ getInstance: vi.fn().mockReturnValue({ options: { isNodeRun: false } }),
21
+ },
22
+ }));
23
+ vi.mock('../../monitoring/proxy/loggingProxy.js', () => ({
24
+ applyLoggingProxyToClass: vi.fn(),
25
+ }));
26
+ vi.mock('@nosana/sdk', async () => {
27
+ const actual = await vi.importActual('@nosana/sdk');
28
+ return {
29
+ ...actual,
30
+ isOpExposed: vi.fn(),
31
+ getExposePorts: vi.fn().mockReturnValue([]),
32
+ };
33
+ });
34
+ vi.mock('../../utils/expose-util.js', () => ({
35
+ generateProxies: vi.fn().mockReturnValue({ proxies: [], idMap: new Map() }),
36
+ generateUrlSecretObject: vi.fn().mockReturnValue({}),
37
+ }));
38
+ vi.mock('../../utils/timeoutPromiseWrapper.js', () => ({
39
+ promiseTimeoutWrapper: vi.fn((promise) => promise),
40
+ }));
41
+ const TEST_CONTAINER_ID = 'container-id';
42
+ const TEST_CONTAINER_NAME = 'container-name';
43
+ const TEST_FRPC_CONTAINER_NAME = `frpc-${TEST_CONTAINER_NAME}`;
44
+ const TEST_FLOW_ID = 'flow-123';
45
+ const TEST_DEPLOYMENT_HASH = 'deployment-hash-456';
46
+ const TEST_DEPLOYMENT_ID = 'my-deployment-id';
47
+ const TEST_PROXY_NAME_1 = 'proxy-1';
48
+ const TEST_CONTAINER_NAME_1 = 'container-1';
49
+ const TEST_CONTAINER_PORT_1 = '8080';
50
+ const TEST_CUSTOM_DOMAIN_1 = 'test1.domain.com';
51
+ const TEST_PROXY_NAME_2 = 'proxy-2';
52
+ const TEST_CONTAINER_NAME_2 = 'container-2';
53
+ const TEST_CONTAINER_PORT_2 = '3000';
54
+ const TEST_CUSTOM_DOMAIN_2 = 'test2.domain.com';
55
+ const TEST_CUSTOM_FLOW_ID = 'custom-flow-id-789';
56
+ const TEST_API_PORT = '12345';
57
+ const TEST_ADDRESS = 'test-address';
58
+ const TEST_JOB_DEFINITION_TYPE = 'container';
59
+ const TEST_JOB_DEFINITION_VERSION = '0.1';
60
+ const TEST_PROJECT = 'test-project';
61
+ const TEST_STATE_RUNNING = 'running';
62
+ const TEST_NOW = Date.now();
63
+ const TEST_OP_ID = 'op-1';
64
+ const TEST_OP_TYPE = 'container/run';
65
+ const TEST_OP_CONTAINER_IMAGE = 'test-image:latest';
66
+ describe('Provider', () => {
67
+ let provider;
68
+ let mockContainerOrchestration;
69
+ let mockRepository;
70
+ let mockResourceManager;
71
+ beforeEach(() => {
72
+ vi.clearAllMocks();
73
+ mockContainerOrchestration = {
74
+ pullImage: vi.fn().mockResolvedValue(undefined),
75
+ runFlowContainer: vi.fn().mockResolvedValue({
76
+ id: TEST_CONTAINER_ID,
77
+ logs: vi.fn().mockResolvedValue({
78
+ on: vi.fn(),
79
+ removeAllListeners: vi.fn(),
80
+ }),
81
+ wait: vi.fn().mockResolvedValue(undefined),
82
+ inspect: vi.fn().mockResolvedValue({ State: { ExitCode: 0 } }),
83
+ }),
84
+ doesContainerExist: vi.fn().mockResolvedValue(false),
85
+ isContainerExited: vi.fn().mockResolvedValue(false),
86
+ stopAndDeleteContainer: vi.fn().mockResolvedValue(undefined),
87
+ createNetwork: vi.fn().mockResolvedValue(undefined),
88
+ deleteNetwork: vi.fn().mockResolvedValue(undefined),
89
+ hasNetwork: vi.fn().mockResolvedValue(false),
90
+ getContainer: vi.fn().mockReturnValue({
91
+ id: TEST_CONTAINER_ID,
92
+ logs: vi.fn().mockResolvedValue({
93
+ on: vi.fn(),
94
+ removeAllListeners: vi.fn(),
95
+ }),
96
+ wait: vi.fn().mockResolvedValue(undefined),
97
+ inspect: vi.fn().mockResolvedValue({ State: { ExitCode: 0 } }),
98
+ }),
99
+ getContainersByName: vi.fn().mockResolvedValue([]),
100
+ };
101
+ mockRepository = {
102
+ updateflowStateSecret: vi.fn(),
103
+ getFlowSecret: vi.fn().mockReturnValue({}),
104
+ };
105
+ mockResourceManager = {
106
+ images: {
107
+ setImage: vi.fn(),
108
+ },
109
+ getResourceVolumes: vi.fn().mockResolvedValue([]),
110
+ };
111
+ provider = new Provider(mockContainerOrchestration, mockRepository, mockResourceManager);
112
+ });
113
+ describe('generateFrpcContainerConfig', () => {
114
+ const baseFlow = {
115
+ id: TEST_FLOW_ID,
116
+ jobDefinition: {
117
+ version: TEST_JOB_DEFINITION_VERSION,
118
+ type: TEST_JOB_DEFINITION_TYPE,
119
+ ops: [],
120
+ },
121
+ project: TEST_PROJECT,
122
+ state: {
123
+ status: TEST_STATE_RUNNING,
124
+ startTime: TEST_NOW,
125
+ endTime: null,
126
+ opStates: [],
127
+ },
128
+ };
129
+ const baseNetworks = { 'network-1': {} };
130
+ const baseProxies = [
131
+ {
132
+ name: TEST_PROXY_NAME_1,
133
+ localIp: TEST_CONTAINER_NAME_1,
134
+ localPorts: TEST_CONTAINER_PORT_1,
135
+ customDomain: TEST_CUSTOM_DOMAIN_1,
136
+ },
137
+ ];
138
+ it('should generate basic config without load balancing', () => {
139
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, baseProxies, false, undefined);
140
+ expect(result).toStrictEqual({
141
+ name: TEST_FRPC_CONTAINER_NAME,
142
+ cmd: ['/entrypoint.sh'],
143
+ networks: baseNetworks,
144
+ requires_network_mode: true,
145
+ env: {
146
+ FRP_SERVER_ADDR: TEST_SERVER_ADDRESS,
147
+ FRP_SERVER_PORT: TEST_SERVER_PORT.toString(),
148
+ NOSANA_ID: TEST_FLOW_ID,
149
+ FRP_PROXIES: JSON.stringify(baseProxies),
150
+ DEPLOYMENT_ID: '',
151
+ JOB_ID: TEST_FLOW_ID,
152
+ },
153
+ });
154
+ });
155
+ it('should not include FRP_LB_GROUP_KEY when load balancing is disabled', () => {
156
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, baseProxies, false, undefined);
157
+ expect(result.env).not.toHaveProperty('FRP_LB_GROUP_KEY');
158
+ });
159
+ it('should include FRP_LB_GROUP_KEY when load balancing is enabled', () => {
160
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, baseProxies, true, TEST_DEPLOYMENT_HASH);
161
+ expect(result.env.FRP_LB_GROUP_KEY).toBe(TEST_DEPLOYMENT_HASH);
162
+ });
163
+ it('should set DEPLOYMENT_ID from flow.jobDefinition.deployment_id when present', () => {
164
+ const flowWithDeployment = {
165
+ ...baseFlow,
166
+ jobDefinition: {
167
+ ...baseFlow.jobDefinition,
168
+ deployment_id: TEST_DEPLOYMENT_ID,
169
+ },
170
+ };
171
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, flowWithDeployment, baseProxies, false, undefined);
172
+ expect(result.env.DEPLOYMENT_ID).toBe(TEST_DEPLOYMENT_ID);
173
+ });
174
+ it('should set DEPLOYMENT_ID to empty string when deployment_id is not present', () => {
175
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, baseProxies, false, undefined);
176
+ expect(result.env.DEPLOYMENT_ID).toBe('');
177
+ });
178
+ it('should serialize proxies array to JSON string', () => {
179
+ const multipleProxies = [
180
+ {
181
+ name: TEST_PROXY_NAME_1,
182
+ localIp: TEST_CONTAINER_NAME_1,
183
+ localPorts: TEST_CONTAINER_PORT_1,
184
+ customDomain: TEST_CUSTOM_DOMAIN_1,
185
+ },
186
+ {
187
+ name: TEST_PROXY_NAME_2,
188
+ localIp: TEST_CONTAINER_NAME_2,
189
+ localPorts: TEST_CONTAINER_PORT_2,
190
+ customDomain: TEST_CUSTOM_DOMAIN_2,
191
+ },
192
+ ];
193
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, multipleProxies, false, undefined);
194
+ expect(result.env.FRP_PROXIES).toBe(JSON.stringify(multipleProxies));
195
+ expect(JSON.parse(result.env.FRP_PROXIES)).toStrictEqual(multipleProxies);
196
+ });
197
+ it('should use flow.id for both NOSANA_ID and JOB_ID', () => {
198
+ const flowWithCustomId = {
199
+ ...baseFlow,
200
+ id: TEST_CUSTOM_FLOW_ID,
201
+ };
202
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, flowWithCustomId, baseProxies, false, undefined);
203
+ expect(result.env.NOSANA_ID).toBe(TEST_CUSTOM_FLOW_ID);
204
+ expect(result.env.JOB_ID).toBe(TEST_CUSTOM_FLOW_ID);
205
+ });
206
+ it('should prefix container name with frpc-', () => {
207
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, baseNetworks, baseFlow, baseProxies, false, undefined);
208
+ expect(result.name).toBe(TEST_FRPC_CONTAINER_NAME);
209
+ });
210
+ it('should pass networks through unchanged', () => {
211
+ const customNetworks = {
212
+ 'network-a': {},
213
+ 'network-b': {},
214
+ };
215
+ const result = provider.generateFrpcContainerConfig(TEST_CONTAINER_NAME, customNetworks, baseFlow, baseProxies, false, undefined);
216
+ expect(result.networks).toBe(customNetworks);
217
+ });
218
+ });
219
+ describe('setUpReverseProxyApi', () => {
220
+ const testAddress = TEST_ADDRESS;
221
+ it('should pull the frpcImage', async () => {
222
+ await provider.setUpReverseProxyApi(testAddress, TEST_API_PORT);
223
+ expect(mockContainerOrchestration.pullImage).toHaveBeenCalledWith(TEST_FRPC_IMAGE, undefined, expect.any(AbortController));
224
+ });
225
+ it('should register frpcImage with resource manager', async () => {
226
+ await provider.setUpReverseProxyApi(testAddress, TEST_API_PORT);
227
+ expect(mockResourceManager.images.setImage).toHaveBeenCalledWith(TEST_FRPC_IMAGE);
228
+ });
229
+ it('should run frpc container with frpcImage when container does not exist', async () => {
230
+ mockContainerOrchestration.doesContainerExist.mockResolvedValue(false);
231
+ await provider.setUpReverseProxyApi(testAddress, TEST_API_PORT);
232
+ const runFlowContainerCalls = mockContainerOrchestration.runFlowContainer.mock.calls;
233
+ const frpcContainerCall = runFlowContainerCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
234
+ expect(frpcContainerCall).toBeDefined();
235
+ expect(frpcContainerCall[0]).toBe(TEST_FRPC_IMAGE);
236
+ });
237
+ it('should run frpc container with frpcImage when container has exited', async () => {
238
+ mockContainerOrchestration.doesContainerExist.mockResolvedValueOnce(true); // frpc check
239
+ mockContainerOrchestration.isContainerExited.mockResolvedValue(true);
240
+ await provider.setUpReverseProxyApi(testAddress, TEST_API_PORT);
241
+ const runFlowContainerCalls = mockContainerOrchestration.runFlowContainer.mock.calls;
242
+ const frpcContainerCall = runFlowContainerCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
243
+ expect(frpcContainerCall).toBeDefined();
244
+ expect(frpcContainerCall[0]).toBe(TEST_FRPC_IMAGE);
245
+ });
246
+ });
247
+ describe('taskManagerContainerRunOperation', () => {
248
+ const baseFlow = {
249
+ id: TEST_FLOW_ID,
250
+ jobDefinition: {
251
+ version: TEST_JOB_DEFINITION_VERSION,
252
+ type: TEST_JOB_DEFINITION_TYPE,
253
+ ops: [
254
+ {
255
+ id: TEST_OP_ID,
256
+ type: TEST_OP_TYPE,
257
+ args: {
258
+ image: TEST_OP_CONTAINER_IMAGE,
259
+ },
260
+ },
261
+ ],
262
+ },
263
+ project: TEST_PROJECT,
264
+ state: {
265
+ status: TEST_STATE_RUNNING,
266
+ startTime: TEST_NOW,
267
+ endTime: null,
268
+ opStates: [],
269
+ },
270
+ };
271
+ const baseOp = {
272
+ id: TEST_OP_ID,
273
+ type: TEST_OP_TYPE,
274
+ args: {
275
+ image: TEST_OP_CONTAINER_IMAGE,
276
+ },
277
+ };
278
+ describe('when operation is exposed', () => {
279
+ beforeEach(() => {
280
+ isOpExposed.mockReturnValue(true);
281
+ getExposePorts.mockReturnValue([
282
+ // @ts-ignore
283
+ { port: parseInt(TEST_CONTAINER_PORT_1), type: 'http' },
284
+ ]);
285
+ generateProxies.mockReturnValue({
286
+ proxies: [],
287
+ idMap: new Map(),
288
+ });
289
+ });
290
+ it('should pull the frpcImage', async () => {
291
+ const emitter = new EventEmitter();
292
+ const controller = new AbortController();
293
+ const operationPromise = provider.taskManagerContainerRunOperation(baseFlow, baseOp, controller, emitter);
294
+ await operationPromise;
295
+ expect(mockContainerOrchestration.pullImage).toHaveBeenCalledWith(TEST_FRPC_IMAGE, undefined, controller);
296
+ });
297
+ it('should register frpcImage with resource manager', async () => {
298
+ const emitter = new EventEmitter();
299
+ const controller = new AbortController();
300
+ const operationPromise = provider.taskManagerContainerRunOperation(baseFlow, baseOp, controller, emitter);
301
+ await operationPromise;
302
+ expect(mockResourceManager.images.setImage).toHaveBeenCalledWith(TEST_FRPC_IMAGE);
303
+ });
304
+ it('should run frpc container with frpcImage', async () => {
305
+ const emitter = new EventEmitter();
306
+ const controller = new AbortController();
307
+ const operationPromise = provider.taskManagerContainerRunOperation(baseFlow, baseOp, controller, emitter);
308
+ await operationPromise;
309
+ const runFlowContainerCalls = mockContainerOrchestration.runFlowContainer.mock.calls;
310
+ const frpcContainerCall = runFlowContainerCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
311
+ expect(frpcContainerCall).toBeDefined();
312
+ expect(frpcContainerCall[0]).toBe(TEST_FRPC_IMAGE);
313
+ });
314
+ });
315
+ describe('when operation is NOT exposed', () => {
316
+ beforeEach(() => {
317
+ isOpExposed.mockReturnValue(false);
318
+ getExposePorts.mockReturnValue([]);
319
+ });
320
+ it('should NOT pull or use frpcImage', async () => {
321
+ const emitter = new EventEmitter();
322
+ const controller = new AbortController();
323
+ const operationPromise = provider.taskManagerContainerRunOperation(baseFlow, baseOp, controller, emitter);
324
+ await operationPromise;
325
+ const pullImageCalls = mockContainerOrchestration.pullImage.mock.calls;
326
+ const frpcPullCall = pullImageCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
327
+ expect(frpcPullCall).toBeUndefined();
328
+ const setImageCalls = mockResourceManager.images.setImage.mock.calls;
329
+ const frpcSetImageCall = setImageCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
330
+ expect(frpcSetImageCall).toBeUndefined();
331
+ const runFlowContainerCalls = mockContainerOrchestration.runFlowContainer.mock.calls;
332
+ const frpcContainerCall = runFlowContainerCalls.find((call) => call[0] === TEST_FRPC_IMAGE);
333
+ expect(frpcContainerCall).toBeUndefined();
334
+ });
335
+ });
336
+ });
337
+ });
@@ -0,0 +1,6 @@
1
+ import Dockerode from 'dockerode';
2
+ import { DockerAuth } from '@nosana/sdk';
3
+ export declare class DockerExtended extends Dockerode {
4
+ promisePull(image: string, controller: AbortController, authorisation?: DockerAuth): Promise<unknown>;
5
+ hasImage(image: string): Promise<boolean>;
6
+ }
@@ -0,0 +1,45 @@
1
+ import Dockerode from 'dockerode';
2
+ import { repoTagsContainsImage } from '../utils/repoTagsContainsImage.js';
3
+ import { createLoggingProxy } from '../../../..//monitoring/proxy/loggingProxy.js';
4
+ import { abortControllerSelector } from '../../../../node/abort/abortControllerSelector.js';
5
+ import { MultiProgressBarReporter } from '../../../../node/utils/multiProgressBarReporter.js';
6
+ export class DockerExtended extends Dockerode {
7
+ async promisePull(image, controller, authorisation) {
8
+ const multiProgressBarReporter = createLoggingProxy(new MultiProgressBarReporter());
9
+ return await new Promise((resolve, reject) => this.pull(image, {}, (err, stream) => {
10
+ const destroy = () => {
11
+ stream.destroy();
12
+ reject(new Error(`Pulling image aborted due to ${abortControllerSelector().signal.reason}`));
13
+ };
14
+ if (controller.signal.aborted) {
15
+ destroy();
16
+ }
17
+ if (err) {
18
+ reject(err);
19
+ return;
20
+ }
21
+ multiProgressBarReporter.start(`Pulling image ${image}`, {
22
+ format: '{status} | {bar} | {layerId} | {value}{format}/{total}{format}',
23
+ });
24
+ const onProgress = (event) => {
25
+ multiProgressBarReporter.update(event);
26
+ };
27
+ controller.signal.addEventListener('abort', destroy);
28
+ const onFinished = (err, _) => {
29
+ multiProgressBarReporter.stop(`Done pulling image ${image}`);
30
+ controller.signal.removeEventListener('abort', destroy);
31
+ if (!err) {
32
+ resolve(true);
33
+ return;
34
+ }
35
+ reject(err);
36
+ return;
37
+ };
38
+ this.modem.followProgress(stream, (err, output) => onFinished(err, output), onProgress);
39
+ }, authorisation));
40
+ }
41
+ async hasImage(image) {
42
+ const savedImages = await this.listImages();
43
+ return savedImages.some(({ RepoTags }) => repoTagsContainsImage(image, RepoTags));
44
+ }
45
+ }
@@ -0,0 +1,43 @@
1
+ import { Container, ContainerCreateOptions, ImageInfo, Image, Volume, VolumeCreateResponse, VolumeInspectInfo, ContainerInspectInfo } from 'dockerode';
2
+ import { DockerAuth } from '@nosana/sdk';
3
+ import { DockerExtended } from './dockerExtended/index.js';
4
+ import { ContainerOrchestrationInterface, RunContainerArgs } from '../interface.js';
5
+ import { ReturnedStatus } from '../../types.js';
6
+ export declare class DockerContainerOrchestration implements ContainerOrchestrationInterface {
7
+ docker: DockerExtended;
8
+ host: string;
9
+ port: string;
10
+ protocol: 'https' | 'http' | 'ssh' | 'socket';
11
+ name: string;
12
+ gpu: string;
13
+ listeners: Map<string, (() => Promise<void>)[]>;
14
+ constructor(server: string, gpu: string);
15
+ getContainerByName(name: string): Promise<Container | undefined>;
16
+ getContainersByName(names: string[]): Promise<Container[]>;
17
+ getConnection(): DockerExtended;
18
+ pullImage(image: string, authorisation?: DockerAuth, controller?: AbortController): Promise<void>;
19
+ hasImage(image: string): Promise<boolean>;
20
+ getImage(image: string): Promise<Image>;
21
+ listImages(): Promise<ImageInfo[]>;
22
+ deleteImage(image: string, controller?: AbortController): Promise<void>;
23
+ createNetwork(name: string, controller?: AbortController): Promise<void>;
24
+ hasNetwork(name: string): Promise<boolean>;
25
+ deleteNetwork(name: string, controller?: AbortController): Promise<void>;
26
+ createVolume(name?: string, controller?: AbortController): Promise<VolumeCreateResponse>;
27
+ hasVolume(name: string): Promise<boolean>;
28
+ listVolumes(): Promise<VolumeInspectInfo[]>;
29
+ getVolume(name: string): Promise<Volume>;
30
+ getRawVolume(name: string): Promise<Volume>;
31
+ deleteVolume(name: string, controller?: AbortController): Promise<void>;
32
+ healthy(): Promise<ReturnedStatus>;
33
+ getContainer(id: string): Promise<Container>;
34
+ getProtocol(): string;
35
+ setupContainerAbortListener(containerId: string, controller: AbortController): void;
36
+ runContainer(args: ContainerCreateOptions, controller?: AbortController): Promise<Container>;
37
+ runFlowContainer(image: string, args: RunContainerArgs, controller?: AbortController): Promise<Container>;
38
+ stopContainer(id: string, controller?: AbortController): Promise<void>;
39
+ stopAndDeleteContainer(id: string, controller?: AbortController): Promise<ContainerInspectInfo | undefined>;
40
+ isContainerExited(id: string): Promise<boolean>;
41
+ doesContainerExist(id: string): Promise<boolean>;
42
+ check(): Promise<string>;
43
+ }