skypilot-nightly 1.0.0.dev20250905__py3-none-any.whl → 1.0.0.dev20251203__py3-none-any.whl

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 (397) hide show
  1. sky/__init__.py +10 -2
  2. sky/adaptors/aws.py +81 -16
  3. sky/adaptors/common.py +25 -2
  4. sky/adaptors/coreweave.py +278 -0
  5. sky/adaptors/do.py +8 -2
  6. sky/adaptors/gcp.py +11 -0
  7. sky/adaptors/ibm.py +5 -2
  8. sky/adaptors/kubernetes.py +64 -0
  9. sky/adaptors/nebius.py +3 -1
  10. sky/adaptors/primeintellect.py +1 -0
  11. sky/adaptors/seeweb.py +183 -0
  12. sky/adaptors/shadeform.py +89 -0
  13. sky/admin_policy.py +20 -0
  14. sky/authentication.py +157 -263
  15. sky/backends/__init__.py +3 -2
  16. sky/backends/backend.py +11 -3
  17. sky/backends/backend_utils.py +588 -184
  18. sky/backends/cloud_vm_ray_backend.py +1088 -904
  19. sky/backends/local_docker_backend.py +9 -5
  20. sky/backends/task_codegen.py +633 -0
  21. sky/backends/wheel_utils.py +18 -0
  22. sky/catalog/__init__.py +8 -0
  23. sky/catalog/aws_catalog.py +4 -0
  24. sky/catalog/common.py +19 -1
  25. sky/catalog/data_fetchers/fetch_aws.py +102 -80
  26. sky/catalog/data_fetchers/fetch_gcp.py +30 -3
  27. sky/catalog/data_fetchers/fetch_nebius.py +9 -6
  28. sky/catalog/data_fetchers/fetch_runpod.py +698 -0
  29. sky/catalog/data_fetchers/fetch_seeweb.py +329 -0
  30. sky/catalog/data_fetchers/fetch_shadeform.py +142 -0
  31. sky/catalog/kubernetes_catalog.py +24 -28
  32. sky/catalog/primeintellect_catalog.py +95 -0
  33. sky/catalog/runpod_catalog.py +5 -1
  34. sky/catalog/seeweb_catalog.py +184 -0
  35. sky/catalog/shadeform_catalog.py +165 -0
  36. sky/check.py +73 -43
  37. sky/client/cli/command.py +675 -412
  38. sky/client/cli/flags.py +4 -2
  39. sky/{volumes/utils.py → client/cli/table_utils.py} +111 -13
  40. sky/client/cli/utils.py +79 -0
  41. sky/client/common.py +12 -2
  42. sky/client/sdk.py +132 -63
  43. sky/client/sdk_async.py +34 -33
  44. sky/cloud_stores.py +82 -3
  45. sky/clouds/__init__.py +6 -0
  46. sky/clouds/aws.py +337 -129
  47. sky/clouds/azure.py +24 -18
  48. sky/clouds/cloud.py +40 -13
  49. sky/clouds/cudo.py +16 -13
  50. sky/clouds/do.py +9 -7
  51. sky/clouds/fluidstack.py +12 -5
  52. sky/clouds/gcp.py +14 -7
  53. sky/clouds/hyperbolic.py +12 -5
  54. sky/clouds/ibm.py +12 -5
  55. sky/clouds/kubernetes.py +80 -45
  56. sky/clouds/lambda_cloud.py +12 -5
  57. sky/clouds/nebius.py +23 -9
  58. sky/clouds/oci.py +19 -12
  59. sky/clouds/paperspace.py +4 -1
  60. sky/clouds/primeintellect.py +317 -0
  61. sky/clouds/runpod.py +85 -24
  62. sky/clouds/scp.py +12 -8
  63. sky/clouds/seeweb.py +477 -0
  64. sky/clouds/shadeform.py +400 -0
  65. sky/clouds/ssh.py +4 -2
  66. sky/clouds/utils/scp_utils.py +61 -50
  67. sky/clouds/vast.py +33 -27
  68. sky/clouds/vsphere.py +14 -16
  69. sky/core.py +174 -165
  70. sky/dashboard/out/404.html +1 -1
  71. sky/dashboard/out/_next/static/96_E2yl3QAiIJGOYCkSpB/_buildManifest.js +1 -0
  72. sky/dashboard/out/_next/static/chunks/1141-e6aa9ab418717c59.js +11 -0
  73. sky/dashboard/out/_next/static/chunks/1871-7e202677c42f43fe.js +6 -0
  74. sky/dashboard/out/_next/static/chunks/2260-7703229c33c5ebd5.js +1 -0
  75. sky/dashboard/out/_next/static/chunks/2369.fc20f0c2c8ed9fe7.js +15 -0
  76. sky/dashboard/out/_next/static/chunks/2755.edd818326d489a1d.js +26 -0
  77. sky/dashboard/out/_next/static/chunks/3294.20a8540fe697d5ee.js +1 -0
  78. sky/dashboard/out/_next/static/chunks/3785.7e245f318f9d1121.js +1 -0
  79. sky/dashboard/out/_next/static/chunks/{6601-06114c982db410b6.js → 3800-7b45f9fbb6308557.js} +1 -1
  80. sky/dashboard/out/_next/static/chunks/4725.172ede95d1b21022.js +1 -0
  81. sky/dashboard/out/_next/static/chunks/4937.a2baa2df5572a276.js +15 -0
  82. sky/dashboard/out/_next/static/chunks/6212-7bd06f60ba693125.js +13 -0
  83. sky/dashboard/out/_next/static/chunks/6856-8f27d1c10c98def8.js +1 -0
  84. sky/dashboard/out/_next/static/chunks/6990-9146207c4567fdfd.js +1 -0
  85. sky/dashboard/out/_next/static/chunks/7359-c8d04e06886000b3.js +30 -0
  86. sky/dashboard/out/_next/static/chunks/7615-019513abc55b3b47.js +1 -0
  87. sky/dashboard/out/_next/static/chunks/8640.5b9475a2d18c5416.js +16 -0
  88. sky/dashboard/out/_next/static/chunks/8969-452f9d5cbdd2dc73.js +1 -0
  89. sky/dashboard/out/_next/static/chunks/9025.fa408f3242e9028d.js +6 -0
  90. sky/dashboard/out/_next/static/chunks/9353-cff34f7e773b2e2b.js +1 -0
  91. sky/dashboard/out/_next/static/chunks/9360.a536cf6b1fa42355.js +31 -0
  92. sky/dashboard/out/_next/static/chunks/9847.3aaca6bb33455140.js +30 -0
  93. sky/dashboard/out/_next/static/chunks/pages/{_app-ce361c6959bc2001.js → _app-bde01e4a2beec258.js} +1 -1
  94. sky/dashboard/out/_next/static/chunks/pages/clusters/[cluster]/[job]-792db96d918c98c9.js +16 -0
  95. sky/dashboard/out/_next/static/chunks/pages/clusters/[cluster]-abfcac9c137aa543.js +1 -0
  96. sky/dashboard/out/_next/static/chunks/pages/clusters-ee39056f9851a3ff.js +1 -0
  97. sky/dashboard/out/_next/static/chunks/pages/infra/{[context]-6563820e094f68ca.js → [context]-c0b5935149902e6f.js} +1 -1
  98. sky/dashboard/out/_next/static/chunks/pages/{infra-aabba60d57826e0f.js → infra-aed0ea19df7cf961.js} +1 -1
  99. sky/dashboard/out/_next/static/chunks/pages/jobs/[job]-d66997e2bfc837cf.js +16 -0
  100. sky/dashboard/out/_next/static/chunks/pages/jobs/pools/[pool]-9faf940b253e3e06.js +21 -0
  101. sky/dashboard/out/_next/static/chunks/pages/jobs-2072b48b617989c9.js +1 -0
  102. sky/dashboard/out/_next/static/chunks/pages/users-f42674164aa73423.js +1 -0
  103. sky/dashboard/out/_next/static/chunks/pages/volumes-b84b948ff357c43e.js +1 -0
  104. sky/dashboard/out/_next/static/chunks/pages/workspaces/{[name]-af76bb06dbb3954f.js → [name]-84a40f8c7c627fe4.js} +1 -1
  105. sky/dashboard/out/_next/static/chunks/pages/{workspaces-7598c33a746cdc91.js → workspaces-531b2f8c4bf89f82.js} +1 -1
  106. sky/dashboard/out/_next/static/chunks/webpack-64e05f17bf2cf8ce.js +1 -0
  107. sky/dashboard/out/_next/static/css/0748ce22df867032.css +3 -0
  108. sky/dashboard/out/clusters/[cluster]/[job].html +1 -1
  109. sky/dashboard/out/clusters/[cluster].html +1 -1
  110. sky/dashboard/out/clusters.html +1 -1
  111. sky/dashboard/out/config.html +1 -1
  112. sky/dashboard/out/index.html +1 -1
  113. sky/dashboard/out/infra/[context].html +1 -1
  114. sky/dashboard/out/infra.html +1 -1
  115. sky/dashboard/out/jobs/[job].html +1 -1
  116. sky/dashboard/out/jobs/pools/[pool].html +1 -1
  117. sky/dashboard/out/jobs.html +1 -1
  118. sky/dashboard/out/users.html +1 -1
  119. sky/dashboard/out/volumes.html +1 -1
  120. sky/dashboard/out/workspace/new.html +1 -1
  121. sky/dashboard/out/workspaces/[name].html +1 -1
  122. sky/dashboard/out/workspaces.html +1 -1
  123. sky/data/data_utils.py +92 -1
  124. sky/data/mounting_utils.py +162 -29
  125. sky/data/storage.py +200 -19
  126. sky/data/storage_utils.py +10 -45
  127. sky/exceptions.py +18 -7
  128. sky/execution.py +74 -31
  129. sky/global_user_state.py +605 -191
  130. sky/jobs/__init__.py +2 -0
  131. sky/jobs/client/sdk.py +101 -4
  132. sky/jobs/client/sdk_async.py +31 -5
  133. sky/jobs/constants.py +15 -8
  134. sky/jobs/controller.py +726 -284
  135. sky/jobs/file_content_utils.py +128 -0
  136. sky/jobs/log_gc.py +193 -0
  137. sky/jobs/recovery_strategy.py +250 -100
  138. sky/jobs/scheduler.py +271 -173
  139. sky/jobs/server/core.py +367 -114
  140. sky/jobs/server/server.py +81 -35
  141. sky/jobs/server/utils.py +89 -35
  142. sky/jobs/state.py +1498 -620
  143. sky/jobs/utils.py +771 -306
  144. sky/logs/agent.py +40 -5
  145. sky/logs/aws.py +9 -19
  146. sky/metrics/utils.py +282 -39
  147. sky/optimizer.py +1 -1
  148. sky/provision/__init__.py +37 -1
  149. sky/provision/aws/config.py +34 -13
  150. sky/provision/aws/instance.py +5 -2
  151. sky/provision/azure/instance.py +5 -3
  152. sky/provision/common.py +2 -0
  153. sky/provision/cudo/instance.py +4 -3
  154. sky/provision/do/instance.py +4 -3
  155. sky/provision/docker_utils.py +97 -26
  156. sky/provision/fluidstack/instance.py +6 -5
  157. sky/provision/gcp/config.py +6 -1
  158. sky/provision/gcp/instance.py +4 -2
  159. sky/provision/hyperbolic/instance.py +4 -2
  160. sky/provision/instance_setup.py +66 -20
  161. sky/provision/kubernetes/__init__.py +2 -0
  162. sky/provision/kubernetes/config.py +7 -44
  163. sky/provision/kubernetes/constants.py +0 -1
  164. sky/provision/kubernetes/instance.py +609 -213
  165. sky/provision/kubernetes/manifests/fusermount-server-daemonset.yaml +1 -2
  166. sky/provision/kubernetes/network.py +12 -8
  167. sky/provision/kubernetes/network_utils.py +8 -25
  168. sky/provision/kubernetes/utils.py +382 -418
  169. sky/provision/kubernetes/volume.py +150 -18
  170. sky/provision/lambda_cloud/instance.py +16 -13
  171. sky/provision/nebius/instance.py +6 -2
  172. sky/provision/nebius/utils.py +103 -86
  173. sky/provision/oci/instance.py +4 -2
  174. sky/provision/paperspace/instance.py +4 -3
  175. sky/provision/primeintellect/__init__.py +10 -0
  176. sky/provision/primeintellect/config.py +11 -0
  177. sky/provision/primeintellect/instance.py +454 -0
  178. sky/provision/primeintellect/utils.py +398 -0
  179. sky/provision/provisioner.py +30 -9
  180. sky/provision/runpod/__init__.py +2 -0
  181. sky/provision/runpod/instance.py +4 -3
  182. sky/provision/runpod/volume.py +69 -13
  183. sky/provision/scp/instance.py +307 -130
  184. sky/provision/seeweb/__init__.py +11 -0
  185. sky/provision/seeweb/config.py +13 -0
  186. sky/provision/seeweb/instance.py +812 -0
  187. sky/provision/shadeform/__init__.py +11 -0
  188. sky/provision/shadeform/config.py +12 -0
  189. sky/provision/shadeform/instance.py +351 -0
  190. sky/provision/shadeform/shadeform_utils.py +83 -0
  191. sky/provision/vast/instance.py +5 -3
  192. sky/provision/volume.py +164 -0
  193. sky/provision/vsphere/common/ssl_helper.py +1 -1
  194. sky/provision/vsphere/common/vapiconnect.py +2 -1
  195. sky/provision/vsphere/common/vim_utils.py +3 -2
  196. sky/provision/vsphere/instance.py +8 -6
  197. sky/provision/vsphere/vsphere_utils.py +8 -1
  198. sky/resources.py +11 -3
  199. sky/schemas/api/responses.py +107 -6
  200. sky/schemas/db/global_user_state/008_skylet_ssh_tunnel_metadata.py +34 -0
  201. sky/schemas/db/global_user_state/009_last_activity_and_launched_at.py +89 -0
  202. sky/schemas/db/global_user_state/010_save_ssh_key.py +66 -0
  203. sky/schemas/db/global_user_state/011_is_ephemeral.py +34 -0
  204. sky/schemas/db/kv_cache/001_initial_schema.py +29 -0
  205. sky/schemas/db/serve_state/002_yaml_content.py +34 -0
  206. sky/schemas/db/skypilot_config/001_initial_schema.py +30 -0
  207. sky/schemas/db/spot_jobs/002_cluster_pool.py +3 -3
  208. sky/schemas/db/spot_jobs/004_job_file_contents.py +42 -0
  209. sky/schemas/db/spot_jobs/005_logs_gc.py +38 -0
  210. sky/schemas/db/spot_jobs/006_controller_pid_started_at.py +34 -0
  211. sky/schemas/db/spot_jobs/007_config_file_content.py +34 -0
  212. sky/schemas/generated/jobsv1_pb2.py +86 -0
  213. sky/schemas/generated/jobsv1_pb2.pyi +254 -0
  214. sky/schemas/generated/jobsv1_pb2_grpc.py +542 -0
  215. sky/schemas/generated/managed_jobsv1_pb2.py +76 -0
  216. sky/schemas/generated/managed_jobsv1_pb2.pyi +278 -0
  217. sky/schemas/generated/managed_jobsv1_pb2_grpc.py +278 -0
  218. sky/schemas/generated/servev1_pb2.py +58 -0
  219. sky/schemas/generated/servev1_pb2.pyi +115 -0
  220. sky/schemas/generated/servev1_pb2_grpc.py +322 -0
  221. sky/serve/autoscalers.py +2 -0
  222. sky/serve/client/impl.py +55 -21
  223. sky/serve/constants.py +4 -3
  224. sky/serve/controller.py +17 -11
  225. sky/serve/load_balancing_policies.py +1 -1
  226. sky/serve/replica_managers.py +219 -142
  227. sky/serve/serve_rpc_utils.py +179 -0
  228. sky/serve/serve_state.py +63 -54
  229. sky/serve/serve_utils.py +145 -109
  230. sky/serve/server/core.py +46 -25
  231. sky/serve/server/impl.py +311 -162
  232. sky/serve/server/server.py +21 -19
  233. sky/serve/service.py +84 -68
  234. sky/serve/service_spec.py +45 -7
  235. sky/server/auth/loopback.py +38 -0
  236. sky/server/auth/oauth2_proxy.py +12 -7
  237. sky/server/common.py +47 -24
  238. sky/server/config.py +62 -28
  239. sky/server/constants.py +9 -1
  240. sky/server/daemons.py +109 -38
  241. sky/server/metrics.py +76 -96
  242. sky/server/middleware_utils.py +166 -0
  243. sky/server/requests/executor.py +381 -145
  244. sky/server/requests/payloads.py +71 -18
  245. sky/server/requests/preconditions.py +15 -13
  246. sky/server/requests/request_names.py +121 -0
  247. sky/server/requests/requests.py +507 -157
  248. sky/server/requests/serializers/decoders.py +48 -17
  249. sky/server/requests/serializers/encoders.py +85 -20
  250. sky/server/requests/threads.py +117 -0
  251. sky/server/rest.py +116 -24
  252. sky/server/server.py +420 -172
  253. sky/server/stream_utils.py +219 -45
  254. sky/server/uvicorn.py +30 -19
  255. sky/setup_files/MANIFEST.in +6 -1
  256. sky/setup_files/alembic.ini +8 -0
  257. sky/setup_files/dependencies.py +62 -19
  258. sky/setup_files/setup.py +44 -44
  259. sky/sky_logging.py +13 -5
  260. sky/skylet/attempt_skylet.py +106 -24
  261. sky/skylet/configs.py +3 -1
  262. sky/skylet/constants.py +111 -26
  263. sky/skylet/events.py +64 -10
  264. sky/skylet/job_lib.py +141 -104
  265. sky/skylet/log_lib.py +233 -5
  266. sky/skylet/log_lib.pyi +40 -2
  267. sky/skylet/providers/ibm/node_provider.py +12 -8
  268. sky/skylet/providers/ibm/vpc_provider.py +13 -12
  269. sky/skylet/runtime_utils.py +21 -0
  270. sky/skylet/services.py +524 -0
  271. sky/skylet/skylet.py +22 -1
  272. sky/skylet/subprocess_daemon.py +104 -29
  273. sky/skypilot_config.py +99 -79
  274. sky/ssh_node_pools/server.py +9 -8
  275. sky/task.py +221 -104
  276. sky/templates/aws-ray.yml.j2 +1 -0
  277. sky/templates/azure-ray.yml.j2 +1 -0
  278. sky/templates/cudo-ray.yml.j2 +1 -0
  279. sky/templates/do-ray.yml.j2 +1 -0
  280. sky/templates/fluidstack-ray.yml.j2 +1 -0
  281. sky/templates/gcp-ray.yml.j2 +1 -0
  282. sky/templates/hyperbolic-ray.yml.j2 +1 -0
  283. sky/templates/ibm-ray.yml.j2 +2 -1
  284. sky/templates/jobs-controller.yaml.j2 +3 -0
  285. sky/templates/kubernetes-ray.yml.j2 +196 -55
  286. sky/templates/lambda-ray.yml.j2 +1 -0
  287. sky/templates/nebius-ray.yml.j2 +3 -0
  288. sky/templates/oci-ray.yml.j2 +1 -0
  289. sky/templates/paperspace-ray.yml.j2 +1 -0
  290. sky/templates/primeintellect-ray.yml.j2 +72 -0
  291. sky/templates/runpod-ray.yml.j2 +1 -0
  292. sky/templates/scp-ray.yml.j2 +1 -0
  293. sky/templates/seeweb-ray.yml.j2 +171 -0
  294. sky/templates/shadeform-ray.yml.j2 +73 -0
  295. sky/templates/vast-ray.yml.j2 +1 -0
  296. sky/templates/vsphere-ray.yml.j2 +1 -0
  297. sky/templates/websocket_proxy.py +188 -43
  298. sky/usage/usage_lib.py +16 -4
  299. sky/users/permission.py +60 -43
  300. sky/utils/accelerator_registry.py +6 -3
  301. sky/utils/admin_policy_utils.py +18 -5
  302. sky/utils/annotations.py +22 -0
  303. sky/utils/asyncio_utils.py +78 -0
  304. sky/utils/atomic.py +1 -1
  305. sky/utils/auth_utils.py +153 -0
  306. sky/utils/cli_utils/status_utils.py +12 -7
  307. sky/utils/cluster_utils.py +28 -6
  308. sky/utils/command_runner.py +88 -27
  309. sky/utils/command_runner.pyi +36 -3
  310. sky/utils/common.py +3 -1
  311. sky/utils/common_utils.py +37 -4
  312. sky/utils/config_utils.py +1 -14
  313. sky/utils/context.py +127 -40
  314. sky/utils/context_utils.py +73 -18
  315. sky/utils/controller_utils.py +229 -70
  316. sky/utils/db/db_utils.py +95 -18
  317. sky/utils/db/kv_cache.py +149 -0
  318. sky/utils/db/migration_utils.py +24 -7
  319. sky/utils/env_options.py +4 -0
  320. sky/utils/git.py +559 -1
  321. sky/utils/kubernetes/create_cluster.sh +15 -30
  322. sky/utils/kubernetes/delete_cluster.sh +10 -7
  323. sky/utils/kubernetes/{deploy_remote_cluster.py → deploy_ssh_node_pools.py} +258 -380
  324. sky/utils/kubernetes/generate_kind_config.py +6 -66
  325. sky/utils/kubernetes/gpu_labeler.py +13 -3
  326. sky/utils/kubernetes/k8s_gpu_labeler_job.yaml +2 -1
  327. sky/utils/kubernetes/k8s_gpu_labeler_setup.yaml +16 -16
  328. sky/utils/kubernetes/kubernetes_deploy_utils.py +213 -194
  329. sky/utils/kubernetes/rsync_helper.sh +11 -3
  330. sky/utils/kubernetes_enums.py +7 -15
  331. sky/utils/lock_events.py +4 -4
  332. sky/utils/locks.py +128 -31
  333. sky/utils/log_utils.py +0 -319
  334. sky/utils/resource_checker.py +13 -10
  335. sky/utils/resources_utils.py +53 -29
  336. sky/utils/rich_utils.py +8 -4
  337. sky/utils/schemas.py +107 -52
  338. sky/utils/subprocess_utils.py +17 -4
  339. sky/utils/thread_utils.py +91 -0
  340. sky/utils/timeline.py +2 -1
  341. sky/utils/ux_utils.py +35 -1
  342. sky/utils/volume.py +88 -4
  343. sky/utils/yaml_utils.py +9 -0
  344. sky/volumes/client/sdk.py +48 -10
  345. sky/volumes/server/core.py +59 -22
  346. sky/volumes/server/server.py +46 -17
  347. sky/volumes/volume.py +54 -42
  348. sky/workspaces/core.py +57 -21
  349. sky/workspaces/server.py +13 -12
  350. sky_templates/README.md +3 -0
  351. sky_templates/__init__.py +3 -0
  352. sky_templates/ray/__init__.py +0 -0
  353. sky_templates/ray/start_cluster +183 -0
  354. sky_templates/ray/stop_cluster +75 -0
  355. {skypilot_nightly-1.0.0.dev20250905.dist-info → skypilot_nightly-1.0.0.dev20251203.dist-info}/METADATA +331 -65
  356. skypilot_nightly-1.0.0.dev20251203.dist-info/RECORD +611 -0
  357. skypilot_nightly-1.0.0.dev20251203.dist-info/top_level.txt +2 -0
  358. sky/client/cli/git.py +0 -549
  359. sky/dashboard/out/_next/static/chunks/1121-408ed10b2f9fce17.js +0 -1
  360. sky/dashboard/out/_next/static/chunks/1141-943efc7aff0f0c06.js +0 -1
  361. sky/dashboard/out/_next/static/chunks/1836-37fede578e2da5f8.js +0 -40
  362. sky/dashboard/out/_next/static/chunks/3015-86cabed5d4669ad0.js +0 -1
  363. sky/dashboard/out/_next/static/chunks/3294.c80326aec9bfed40.js +0 -6
  364. sky/dashboard/out/_next/static/chunks/3785.4872a2f3aa489880.js +0 -1
  365. sky/dashboard/out/_next/static/chunks/4045.b30465273dc5e468.js +0 -21
  366. sky/dashboard/out/_next/static/chunks/4676-9da7fdbde90b5549.js +0 -10
  367. sky/dashboard/out/_next/static/chunks/4725.10f7a9a5d3ea8208.js +0 -1
  368. sky/dashboard/out/_next/static/chunks/5339.3fda4a4010ff4e06.js +0 -51
  369. sky/dashboard/out/_next/static/chunks/6135-4b4d5e824b7f9d3c.js +0 -1
  370. sky/dashboard/out/_next/static/chunks/649.b9d7f7d10c1b8c53.js +0 -45
  371. sky/dashboard/out/_next/static/chunks/6856-dca7962af4814e1b.js +0 -1
  372. sky/dashboard/out/_next/static/chunks/6990-08b2a1cae076a943.js +0 -1
  373. sky/dashboard/out/_next/static/chunks/7325.b4bc99ce0892dcd5.js +0 -6
  374. sky/dashboard/out/_next/static/chunks/754-d0da8ab45f9509e9.js +0 -18
  375. sky/dashboard/out/_next/static/chunks/7669.1f5d9a402bf5cc42.js +0 -36
  376. sky/dashboard/out/_next/static/chunks/8969-0be3036bf86f8256.js +0 -1
  377. sky/dashboard/out/_next/static/chunks/9025.c12318fb6a1a9093.js +0 -6
  378. sky/dashboard/out/_next/static/chunks/9037-fa1737818d0a0969.js +0 -6
  379. sky/dashboard/out/_next/static/chunks/pages/clusters/[cluster]/[job]-1cbba24bd1bd35f8.js +0 -16
  380. sky/dashboard/out/_next/static/chunks/pages/clusters/[cluster]-0b4b35dc1dfe046c.js +0 -16
  381. sky/dashboard/out/_next/static/chunks/pages/clusters-469814d711d63b1b.js +0 -1
  382. sky/dashboard/out/_next/static/chunks/pages/jobs/[job]-dd64309c3fe67ed2.js +0 -11
  383. sky/dashboard/out/_next/static/chunks/pages/jobs/pools/[pool]-07349868f7905d37.js +0 -16
  384. sky/dashboard/out/_next/static/chunks/pages/jobs-1f70d9faa564804f.js +0 -1
  385. sky/dashboard/out/_next/static/chunks/pages/users-018bf31cda52e11b.js +0 -1
  386. sky/dashboard/out/_next/static/chunks/pages/volumes-739726d6b823f532.js +0 -1
  387. sky/dashboard/out/_next/static/chunks/webpack-4fe903277b57b523.js +0 -1
  388. sky/dashboard/out/_next/static/css/4614e06482d7309e.css +0 -3
  389. sky/dashboard/out/_next/static/mS-4qZPSkRuA1u-g2wQhg/_buildManifest.js +0 -1
  390. sky/templates/kubernetes-ssh-jump.yml.j2 +0 -94
  391. sky/utils/kubernetes/ssh_jump_lifecycle_manager.py +0 -191
  392. skypilot_nightly-1.0.0.dev20250905.dist-info/RECORD +0 -547
  393. skypilot_nightly-1.0.0.dev20250905.dist-info/top_level.txt +0 -1
  394. /sky/dashboard/out/_next/static/{mS-4qZPSkRuA1u-g2wQhg → 96_E2yl3QAiIJGOYCkSpB}/_ssgManifest.js +0 -0
  395. {skypilot_nightly-1.0.0.dev20250905.dist-info → skypilot_nightly-1.0.0.dev20251203.dist-info}/WHEEL +0 -0
  396. {skypilot_nightly-1.0.0.dev20250905.dist-info → skypilot_nightly-1.0.0.dev20251203.dist-info}/entry_points.txt +0 -0
  397. {skypilot_nightly-1.0.0.dev20250905.dist-info → skypilot_nightly-1.0.0.dev20251203.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,184 @@
1
+ """Seeweb service catalog.
2
+
3
+ This module loads the service catalog file and can be used to
4
+ query instance types and pricing information for Seeweb.
5
+ """
6
+
7
+ import typing
8
+ from typing import Dict, List, Optional, Tuple
9
+
10
+ import pandas as pd
11
+
12
+ from sky.catalog import common
13
+ from sky.utils import resources_utils
14
+ from sky.utils import ux_utils
15
+
16
+ if typing.TYPE_CHECKING:
17
+ from sky.clouds import cloud
18
+
19
+ _PULL_FREQUENCY_HOURS = 8
20
+ _df = common.read_catalog('seeweb/vms.csv',
21
+ pull_frequency_hours=_PULL_FREQUENCY_HOURS)
22
+
23
+
24
+ def instance_type_exists(instance_type: str) -> bool:
25
+ result = common.instance_type_exists_impl(_df, instance_type)
26
+ return result
27
+
28
+
29
+ def validate_region_zone(
30
+ region: Optional[str],
31
+ zone: Optional[str]) -> Tuple[Optional[str], Optional[str]]:
32
+ if zone is not None:
33
+ with ux_utils.print_exception_no_traceback():
34
+ raise ValueError('Seeweb does not support zones.')
35
+
36
+ result = common.validate_region_zone_impl('Seeweb', _df, region, zone)
37
+ return result
38
+
39
+
40
+ def get_hourly_cost(instance_type: str,
41
+ use_spot: bool = False,
42
+ region: Optional[str] = None,
43
+ zone: Optional[str] = None) -> float:
44
+ """Returns the cost, or the cheapest cost among all zones for spot."""
45
+ if zone is not None:
46
+ with ux_utils.print_exception_no_traceback():
47
+ raise ValueError('Seeweb does not support zones.')
48
+
49
+ result = common.get_hourly_cost_impl(_df, instance_type, use_spot, region,
50
+ zone)
51
+ return result
52
+
53
+
54
+ def get_vcpus_mem_from_instance_type(
55
+ instance_type: str) -> Tuple[Optional[float], Optional[float]]:
56
+ result = common.get_vcpus_mem_from_instance_type_impl(_df, instance_type)
57
+ return result
58
+
59
+
60
+ def get_default_instance_type(cpus: Optional[str] = None,
61
+ memory: Optional[str] = None,
62
+ disk_tier: Optional[
63
+ resources_utils.DiskTier] = None,
64
+ region: Optional[str] = None,
65
+ zone: Optional[str] = None) -> Optional[str]:
66
+ del disk_tier # unused
67
+ result = common.get_instance_type_for_cpus_mem_impl(_df, cpus, memory,
68
+ region, zone)
69
+ return result
70
+
71
+
72
+ def get_accelerators_from_instance_type(
73
+ instance_type: str) -> Optional[Dict[str, int]]:
74
+ # Filter the dataframe for the specific instance type
75
+ df_filtered = _df[_df['InstanceType'] == instance_type]
76
+ if df_filtered.empty:
77
+ return None
78
+
79
+ # Get the first row (all rows for same instance
80
+ # type should have same accelerator info)
81
+ row = df_filtered.iloc[0]
82
+ acc_name = row['AcceleratorName']
83
+ acc_count = row['AcceleratorCount']
84
+
85
+ # Check if the instance has accelerators
86
+ if pd.isna(acc_name) or pd.isna(
87
+ acc_count) or acc_name == '' or acc_count == '':
88
+ return None
89
+
90
+ # Convert accelerator count to int/float
91
+ try:
92
+ if int(acc_count) == acc_count:
93
+ acc_count = int(acc_count)
94
+ else:
95
+ acc_count = float(acc_count)
96
+ except (ValueError, TypeError):
97
+ return None
98
+
99
+ result = {acc_name: acc_count}
100
+ return result
101
+
102
+
103
+ def get_instance_type_for_accelerator(
104
+ acc_name: str,
105
+ acc_count: int,
106
+ cpus: Optional[str] = None,
107
+ memory: Optional[str] = None,
108
+ use_spot: bool = False,
109
+ region: Optional[str] = None,
110
+ zone: Optional[str] = None) -> Tuple[Optional[List[str]], List[str]]:
111
+ """Returns a list of instance types satisfying
112
+ the required count of accelerators."""
113
+ if zone is not None:
114
+ with ux_utils.print_exception_no_traceback():
115
+ raise ValueError('Seeweb does not support zones.')
116
+
117
+ result = common.get_instance_type_for_accelerator_impl(df=_df,
118
+ acc_name=acc_name,
119
+ acc_count=acc_count,
120
+ cpus=cpus,
121
+ memory=memory,
122
+ use_spot=use_spot,
123
+ region=region,
124
+ zone=zone)
125
+ return result
126
+
127
+
128
+ def regions() -> List['cloud.Region']:
129
+ result = common.get_region_zones(_df, use_spot=False)
130
+ return result
131
+
132
+
133
+ def get_region_zones_for_instance_type(instance_type: str,
134
+ use_spot: bool = False
135
+ ) -> List['cloud.Region']:
136
+ """Returns a list of regions for a given instance type."""
137
+ # Filter the dataframe for the specific instance type
138
+ df_filtered = _df[_df['InstanceType'] == instance_type]
139
+ if df_filtered.empty:
140
+ return []
141
+
142
+ # Use common.get_region_zones() like all other providers
143
+ region_list = common.get_region_zones(df_filtered, use_spot)
144
+
145
+ # Default region: Frosinone (it-fr2)
146
+ # Other regions: Milano (it-mi2), Lugano (ch-lug1), Bulgaria (bg-sof1)
147
+ priority_regions = ['it-fr2']
148
+ prioritized_regions = []
149
+ other_regions = []
150
+
151
+ # First, add regions in priority order if they exist
152
+ for priority_region in priority_regions:
153
+ for region in region_list:
154
+ if region.name == priority_region:
155
+ prioritized_regions.append(region)
156
+ break
157
+
158
+ # Then, add any remaining regions that weren't in the priority list
159
+ for region in region_list:
160
+ if region.name not in priority_regions:
161
+ other_regions.append(region)
162
+
163
+ result = prioritized_regions + other_regions
164
+ return result
165
+
166
+
167
+ def list_accelerators(
168
+ gpus_only: bool,
169
+ name_filter: Optional[str],
170
+ region_filter: Optional[str],
171
+ quantity_filter: Optional[int],
172
+ case_sensitive: bool = True,
173
+ all_regions: bool = False,
174
+ require_price: bool = True) -> Dict[str, List[common.InstanceTypeInfo]]:
175
+ """Lists accelerators offered in Seeweb."""
176
+ # Filter out rows with empty or null regions (indicating unavailability)
177
+ df_filtered = _df.dropna(subset=['Region'])
178
+ df_filtered = df_filtered[df_filtered['Region'].str.strip() != '']
179
+
180
+ result = common.list_accelerators_impl('Seeweb', df_filtered, gpus_only,
181
+ name_filter, region_filter,
182
+ quantity_filter, case_sensitive,
183
+ all_regions, require_price)
184
+ return result
@@ -0,0 +1,165 @@
1
+ """ Shadeform | Catalog
2
+
3
+ This module loads pricing and instance information from the Shadeform API
4
+ and can be used to query instance types and pricing information for Shadeform.
5
+ """
6
+
7
+ import typing
8
+ from typing import Dict, List, Optional, Tuple, Union
9
+
10
+ import pandas as pd
11
+
12
+ from sky.catalog import common
13
+
14
+ if typing.TYPE_CHECKING:
15
+ from sky.clouds import cloud
16
+
17
+ # We'll use dynamic fetching, so no static CSV file to load
18
+ _df = None
19
+
20
+
21
+ def _get_df():
22
+ """Get the dataframe, fetching from API if needed."""
23
+ global _df
24
+ if _df is None:
25
+ # For now, we'll fall back to a minimal static catalog
26
+ # In a full implementation, this would call the Shadeform API
27
+ # to dynamically fetch the latest instance types and pricing
28
+ try:
29
+ df = common.read_catalog('shadeform/vms.csv')
30
+ except FileNotFoundError:
31
+ # If no static catalog exists, create an empty one
32
+ # This would be replaced with dynamic API fetching
33
+ _df = pd.DataFrame(columns=[
34
+ 'InstanceType', 'AcceleratorName', 'AcceleratorCount', 'vCPUs',
35
+ 'MemoryGiB', 'Price', 'Region', 'GpuInfo', 'SpotPrice'
36
+ ])
37
+ else:
38
+ df = df[df['InstanceType'].notna()]
39
+ if 'AcceleratorName' in df.columns:
40
+ df = df[df['AcceleratorName'].notna()]
41
+ df = df.assign(AcceleratorName=df['AcceleratorName'].astype(
42
+ str).str.strip())
43
+ _df = df.reset_index(drop=True)
44
+ return _df
45
+
46
+
47
+ def _is_not_found_error(err: ValueError) -> bool:
48
+ msg = str(err).lower()
49
+ return 'not found' in msg or 'not supported' in msg
50
+
51
+
52
+ def _call_or_default(func, default):
53
+ try:
54
+ return func()
55
+ except ValueError as err:
56
+ if _is_not_found_error(err):
57
+ return default
58
+ raise
59
+
60
+
61
+ def instance_type_exists(instance_type: str) -> bool:
62
+ """Check if an instance type exists."""
63
+ return common.instance_type_exists_impl(_get_df(), instance_type)
64
+
65
+
66
+ def validate_region_zone(
67
+ region: Optional[str],
68
+ zone: Optional[str]) -> Tuple[Optional[str], Optional[str]]:
69
+ """Validate region and zone for Shadeform."""
70
+ return common.validate_region_zone_impl('shadeform', _get_df(), region,
71
+ zone)
72
+
73
+
74
+ def get_hourly_cost(instance_type: str,
75
+ use_spot: bool = False,
76
+ region: Optional[str] = None,
77
+ zone: Optional[str] = None) -> float:
78
+ """Returns the cost, or the cheapest cost among all zones for spot."""
79
+ # Shadeform doesn't support spot instances currently
80
+ if use_spot:
81
+ raise ValueError('Spot instances are not supported on Shadeform')
82
+
83
+ return common.get_hourly_cost_impl(_get_df(), instance_type, use_spot,
84
+ region, zone)
85
+
86
+
87
+ def get_vcpus_mem_from_instance_type(
88
+ instance_type: str) -> Tuple[Optional[float], Optional[float]]:
89
+ """Get vCPUs and memory from instance type."""
90
+ return _call_or_default(
91
+ lambda: common.get_vcpus_mem_from_instance_type_impl(
92
+ _get_df(), instance_type), (None, None))
93
+
94
+
95
+ def get_default_instance_type(cpus: Optional[str] = None,
96
+ memory: Optional[str] = None,
97
+ disk_tier: Optional[str] = None,
98
+ region: Optional[str] = None,
99
+ zone: Optional[str] = None) -> Optional[str]:
100
+ """Get default instance type based on requirements."""
101
+ del disk_tier # Shadeform doesn't support custom disk tiers yet
102
+ return _call_or_default(
103
+ lambda: common.get_instance_type_for_cpus_mem_impl(
104
+ _get_df(), cpus, memory, region, zone), None)
105
+
106
+
107
+ def get_accelerators_from_instance_type(
108
+ instance_type: str) -> Optional[Dict[str, Union[int, float]]]:
109
+ """Get accelerator information from instance type."""
110
+ return _call_or_default(
111
+ lambda: common.get_accelerators_from_instance_type_impl(
112
+ _get_df(), instance_type), None)
113
+
114
+
115
+ def get_instance_type_for_accelerator(
116
+ acc_name: str,
117
+ acc_count: int,
118
+ cpus: Optional[str] = None,
119
+ memory: Optional[str] = None,
120
+ use_spot: bool = False,
121
+ region: Optional[str] = None,
122
+ zone: Optional[str] = None) -> Tuple[Optional[List[str]], List[str]]:
123
+ """Returns a list of instance types that have the given accelerator."""
124
+ if use_spot:
125
+ # Return empty lists since spot is not supported
126
+ return None, ['Spot instances are not supported on Shadeform']
127
+
128
+ return _call_or_default(
129
+ lambda: common.get_instance_type_for_accelerator_impl(
130
+ df=_get_df(),
131
+ acc_name=acc_name,
132
+ acc_count=acc_count,
133
+ cpus=cpus,
134
+ memory=memory,
135
+ use_spot=use_spot,
136
+ region=region,
137
+ zone=zone), (None, []))
138
+
139
+
140
+ def get_region_zones_for_instance_type(instance_type: str,
141
+ use_spot: bool) -> List['cloud.Region']:
142
+ """Get regions and zones for an instance type."""
143
+ if use_spot:
144
+ return [] # No spot support
145
+
146
+ df = _get_df()
147
+ df_filtered = df[df['InstanceType'] == instance_type]
148
+ return _call_or_default(
149
+ lambda: common.get_region_zones(df_filtered, use_spot), [])
150
+
151
+
152
+ def list_accelerators(
153
+ gpus_only: bool,
154
+ name_filter: Optional[str],
155
+ region_filter: Optional[str],
156
+ quantity_filter: Optional[int],
157
+ case_sensitive: bool = True,
158
+ all_regions: bool = False,
159
+ require_price: bool = True) -> Dict[str, List[common.InstanceTypeInfo]]:
160
+ """Returns all instance types in Shadeform offering GPUs."""
161
+ del require_price # Unused.
162
+ return common.list_accelerators_impl('Shadeform', _get_df(), gpus_only,
163
+ name_filter, region_filter,
164
+ quantity_filter, case_sensitive,
165
+ all_regions)
sky/check.py CHANGED
@@ -14,6 +14,7 @@ from sky import global_user_state
14
14
  from sky import sky_logging
15
15
  from sky import skypilot_config
16
16
  from sky.adaptors import cloudflare
17
+ from sky.adaptors import coreweave
17
18
  from sky.clouds import cloud as sky_cloud
18
19
  from sky.skylet import constants
19
20
  from sky.utils import common_utils
@@ -33,7 +34,8 @@ def _get_workspace_allowed_clouds(workspace: str) -> List[str]:
33
34
  # clouds. Also validate names with get_cloud_tuple.
34
35
  config_allowed_cloud_names = skypilot_config.get_nested(
35
36
  ('allowed_clouds',),
36
- [repr(c) for c in registry.CLOUD_REGISTRY.values()] + [cloudflare.NAME])
37
+ [repr(c) for c in registry.CLOUD_REGISTRY.values()] +
38
+ [cloudflare.NAME, coreweave.NAME])
37
39
  # filter out the clouds that are disabled in the workspace config
38
40
  workspace_disabled_clouds = []
39
41
  for cloud in config_allowed_cloud_names:
@@ -50,6 +52,32 @@ def _get_workspace_allowed_clouds(workspace: str) -> List[str]:
50
52
  return config_allowed_cloud_names
51
53
 
52
54
 
55
+ def _get_workspace_cloud_capabilities(
56
+ workspace: str,
57
+ cloud: str) -> Optional[List[sky_cloud.CloudCapability]]:
58
+ """Get the capabilities for a cloud in a workspace.
59
+
60
+ Returns:
61
+ A list of capabilities for the cloud in the workspace.
62
+ None if the capabilities are not explicitly specified
63
+ in the workspace or global config.
64
+ Returned value of None does not mean the cloud is disabled.
65
+ """
66
+ cloud_config = skypilot_config.get_workspace_cloud(cloud,
67
+ workspace=workspace)
68
+ cloud_capabilities = cloud_config.get('capabilities', None)
69
+ if not cloud_capabilities:
70
+ # get the capabilities from the global config
71
+ cloud_capabilities = skypilot_config.get_nested(
72
+ (cloud.lower(), 'capabilities'), default_value=None)
73
+ if cloud_capabilities:
74
+ return [
75
+ sky_cloud.CloudCapability(capability.lower())
76
+ for capability in cloud_capabilities
77
+ ]
78
+ return None
79
+
80
+
53
81
  def check_capabilities(
54
82
  quiet: bool = False,
55
83
  verbose: bool = False,
@@ -81,7 +109,7 @@ def check_capabilities(
81
109
 
82
110
  def get_all_clouds() -> Tuple[str, ...]:
83
111
  return tuple([repr(c) for c in registry.CLOUD_REGISTRY.values()] +
84
- [cloudflare.NAME])
112
+ [cloudflare.NAME, coreweave.NAME])
85
113
 
86
114
  def _execute_check_logic_for_workspace(
87
115
  current_workspace_name: str,
@@ -121,9 +149,12 @@ def check_capabilities(
121
149
  cloud_name: str
122
150
  ) -> Tuple[str, Union[sky_clouds.Cloud, ModuleType]]:
123
151
  # Validates cloud_name and returns a tuple of the cloud's name and
124
- # the cloud object. Includes special handling for Cloudflare.
152
+ # the cloud object. Includes special handling for Cloudflare and
153
+ # CoreWeave.
125
154
  if cloud_name.lower().startswith('cloudflare'):
126
155
  return cloudflare.NAME, cloudflare
156
+ elif cloud_name.lower().startswith('coreweave'):
157
+ return coreweave.NAME, coreweave
127
158
  else:
128
159
  cloud_obj = registry.CLOUD_REGISTRY.from_str(cloud_name)
129
160
  assert cloud_obj is not None, f'Cloud {cloud_name!r} not found'
@@ -147,12 +178,32 @@ def check_capabilities(
147
178
 
148
179
  # filter out the clouds that are disabled in the workspace config
149
180
  workspace_disabled_clouds = []
181
+ workspace_cloud_capabilities: Dict[
182
+ str, List[sky_cloud.CloudCapability]] = {}
150
183
  for cloud in config_allowed_cloud_names:
151
184
  cloud_config = skypilot_config.get_workspace_cloud(
152
185
  cloud, workspace=current_workspace_name)
153
186
  cloud_disabled = cloud_config.get('disabled', False)
154
187
  if cloud_disabled:
155
188
  workspace_disabled_clouds.append(cloud)
189
+ else:
190
+ specified_capabilities = _get_workspace_cloud_capabilities(
191
+ current_workspace_name, cloud)
192
+ if specified_capabilities:
193
+ # filter the capabilities to only the ones passed
194
+ # in as argument to this function
195
+ workspace_cloud_capabilities[cloud] = [
196
+ enabled_capability
197
+ for enabled_capability in specified_capabilities
198
+ if enabled_capability in capabilities
199
+ ]
200
+ # mark capabilities that are not enabled
201
+ # in the workspace config as disabled
202
+ for capability in capabilities:
203
+ if capability not in workspace_cloud_capabilities[
204
+ cloud]:
205
+ disabled_clouds.setdefault(cloud,
206
+ []).append(capability)
156
207
 
157
208
  config_allowed_cloud_names = [
158
209
  c for c in config_allowed_cloud_names
@@ -172,7 +223,8 @@ def check_capabilities(
172
223
  for c in clouds_to_check:
173
224
  allowed = c[0] in config_allowed_cloud_names
174
225
  if allowed or check_explicit:
175
- for capability in capabilities:
226
+ for capability in workspace_cloud_capabilities.get(
227
+ c[0], capabilities):
176
228
  combinations.append((c, capability, allowed))
177
229
 
178
230
  cloud2ctx2text: Dict[str, Dict[str, str]] = {}
@@ -219,23 +271,24 @@ def check_capabilities(
219
271
  # allowed_clouds in config.yaml, it will be disabled.
220
272
  all_enabled_clouds: Set[str] = set()
221
273
  for capability in capabilities:
222
- # Cloudflare is not a real cloud in registry.CLOUD_REGISTRY, and
223
- # should not be inserted into the DB (otherwise `sky launch` and
224
- # other code would error out when it's trying to look it up in the
225
- # registry).
274
+ # Cloudflare and CoreWeave are not real clouds in
275
+ # registry.CLOUD_REGISTRY, and should not be inserted into the DB
276
+ # (otherwise `sky launch` and other code would error out when it's
277
+ # trying to look it up in the registry).
226
278
  enabled_clouds_set = {
227
279
  cloud for cloud, capabilities in enabled_clouds.items()
228
- if capability in capabilities and
229
- not cloud.startswith('Cloudflare')
280
+ if capability in capabilities and not cloud.startswith(
281
+ 'Cloudflare') and not cloud.startswith('CoreWeave')
230
282
  }
231
283
  disabled_clouds_set = {
232
284
  cloud for cloud, capabilities in disabled_clouds.items()
233
- if capability in capabilities and
234
- not cloud.startswith('Cloudflare')
285
+ if capability in capabilities and not cloud.startswith(
286
+ 'Cloudflare') and not cloud.startswith('CoreWeave')
235
287
  }
236
288
  config_allowed_clouds_set = {
237
289
  cloud for cloud in config_allowed_cloud_names
238
- if not cloud.startswith('Cloudflare')
290
+ if not cloud.startswith('Cloudflare') and
291
+ not cloud.startswith('CoreWeave')
239
292
  }
240
293
  previously_enabled_clouds_set = {
241
294
  repr(cloud)
@@ -430,6 +483,12 @@ def get_cloud_credential_file_mounts(
430
483
  if r2_is_enabled:
431
484
  r2_credential_mounts = cloudflare.get_credential_file_mounts()
432
485
  file_mounts.update(r2_credential_mounts)
486
+
487
+ # Similarly, handle CoreWeave storage credentials
488
+ coreweave_is_enabled, _ = coreweave.check_storage_credentials()
489
+ if coreweave_is_enabled:
490
+ coreweave_credential_mounts = coreweave.get_credential_file_mounts()
491
+ file_mounts.update(coreweave_credential_mounts)
433
492
  return file_mounts
434
493
 
435
494
 
@@ -494,7 +553,7 @@ def _print_checked_cloud(
494
553
  style_str = f'{colorama.Fore.GREEN}{colorama.Style.NORMAL}'
495
554
  status_msg = 'enabled'
496
555
  capability_string = f'[{", ".join(enabled_capabilities)}]'
497
- if verbose and cloud is not cloudflare:
556
+ if verbose and cloud is not cloudflare and cloud is not coreweave:
498
557
  activated_account = cloud.get_active_user_identity_str()
499
558
  if isinstance(cloud_tuple[1], (sky_clouds.SSH, sky_clouds.Kubernetes)):
500
559
  detail_string = _format_context_details(cloud_tuple[1],
@@ -621,35 +680,6 @@ def _format_enabled_cloud(cloud_name: str,
621
680
  if cloud_name in [repr(sky_clouds.Kubernetes()), repr(sky_clouds.SSH())]:
622
681
  return (f'{title}' + _format_context_details(
623
682
  cloud_name, show_details=False, ctx2text=ctx2text))
624
-
625
- if cloud_name == repr(sky_clouds.Kubernetes()):
626
- # Get enabled contexts for Kubernetes
627
- existing_contexts = sky_clouds.Kubernetes.existing_allowed_contexts()
628
- if not existing_contexts:
629
- return _green_color(cloud_and_capabilities)
630
-
631
- # Check if allowed_contexts is explicitly set in config
632
- allowed_contexts = skypilot_config.get_effective_region_config(
633
- cloud='kubernetes',
634
- region=None,
635
- keys=('allowed_contexts',),
636
- default_value=None)
637
-
638
- # Format the context info with consistent styling
639
- if allowed_contexts is not None:
640
- contexts_formatted = []
641
- for i, context in enumerate(existing_contexts):
642
- symbol = (ux_utils.INDENT_LAST_SYMBOL
643
- if i == len(existing_contexts) -
644
- 1 else ux_utils.INDENT_SYMBOL)
645
- contexts_formatted.append(f'\n {symbol}{context}')
646
- context_info = f' Allowed contexts:{"".join(contexts_formatted)}'
647
- else:
648
- context_info = f' Active context: {existing_contexts[0]}'
649
-
650
- return (f'{_green_color(cloud_and_capabilities)}\n'
651
- f' {colorama.Style.DIM}{context_info}'
652
- f'{colorama.Style.RESET_ALL}')
653
683
  return _green_color(cloud_and_capabilities)
654
684
 
655
685