lightning-sdk 0.1.49__py3-none-any.whl → 2025.11.5__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.
- lightning_sdk/__init__.py +19 -9
- lightning_sdk/__version__.py +3 -0
- lightning_sdk/agents.py +2 -1
- lightning_sdk/ai_hub.py +43 -38
- lightning_sdk/api/__init__.py +2 -0
- lightning_sdk/api/ai_hub_api.py +49 -6
- lightning_sdk/api/base_studio_api.py +90 -0
- lightning_sdk/api/cloud_account_api.py +225 -0
- lightning_sdk/api/deployment_api.py +133 -27
- lightning_sdk/api/job_api.py +147 -34
- lightning_sdk/api/license_api.py +37 -0
- lightning_sdk/api/lit_container_api.py +231 -19
- lightning_sdk/api/llm_api.py +306 -0
- lightning_sdk/api/mmt_api.py +112 -28
- lightning_sdk/api/pipeline_api.py +120 -0
- lightning_sdk/api/studio_api.py +440 -89
- lightning_sdk/api/teamspace_api.py +269 -31
- lightning_sdk/api/user_api.py +56 -2
- lightning_sdk/api/utils.py +185 -52
- lightning_sdk/base_studio.py +123 -0
- lightning_sdk/cli/__init__.py +1 -0
- lightning_sdk/cli/base_studio/__init__.py +10 -0
- lightning_sdk/cli/base_studio/list.py +43 -0
- lightning_sdk/cli/config/__init__.py +14 -0
- lightning_sdk/cli/config/get.py +57 -0
- lightning_sdk/cli/config/set.py +92 -0
- lightning_sdk/cli/config/show.py +9 -0
- lightning_sdk/cli/entrypoint.py +98 -56
- lightning_sdk/cli/groups.py +56 -0
- lightning_sdk/cli/job/__init__.py +7 -0
- lightning_sdk/cli/legacy/__init__.py +0 -0
- lightning_sdk/cli/legacy/ai_hub.py +65 -0
- lightning_sdk/cli/legacy/clusters_menu.py +49 -0
- lightning_sdk/cli/legacy/configure.py +129 -0
- lightning_sdk/cli/legacy/connect.py +34 -0
- lightning_sdk/cli/legacy/create.py +115 -0
- lightning_sdk/cli/legacy/delete.py +131 -0
- lightning_sdk/cli/legacy/deploy/__init__.py +0 -0
- lightning_sdk/cli/legacy/deploy/_auth.py +196 -0
- lightning_sdk/cli/legacy/deploy/devbox.py +163 -0
- lightning_sdk/cli/legacy/deploy/serve.py +452 -0
- lightning_sdk/cli/legacy/docker_cli.py +22 -0
- lightning_sdk/cli/legacy/download.py +322 -0
- lightning_sdk/cli/legacy/entrypoint.py +110 -0
- lightning_sdk/cli/legacy/generate.py +52 -0
- lightning_sdk/cli/legacy/inspection.py +45 -0
- lightning_sdk/cli/{job_and_mmt_action.py → legacy/job_and_mmt_action.py} +6 -6
- lightning_sdk/cli/{jobs_menu.py → legacy/jobs_menu.py} +3 -2
- lightning_sdk/cli/legacy/list.py +326 -0
- lightning_sdk/cli/{mmts_menu.py → legacy/mmts_menu.py} +3 -2
- lightning_sdk/cli/legacy/open.py +81 -0
- lightning_sdk/cli/legacy/run.py +443 -0
- lightning_sdk/cli/legacy/start.py +107 -0
- lightning_sdk/cli/legacy/stop.py +107 -0
- lightning_sdk/cli/{studios_menu.py → legacy/studios_menu.py} +24 -1
- lightning_sdk/cli/legacy/switch.py +63 -0
- lightning_sdk/cli/{teamspace_menu.py → legacy/teamspace_menu.py} +12 -3
- lightning_sdk/cli/legacy/upload.py +382 -0
- lightning_sdk/cli/license/__init__.py +14 -0
- lightning_sdk/cli/license/get.py +15 -0
- lightning_sdk/cli/license/list.py +45 -0
- lightning_sdk/cli/license/set.py +13 -0
- lightning_sdk/cli/mmt/__init__.py +7 -0
- lightning_sdk/cli/studio/__init__.py +24 -0
- lightning_sdk/cli/studio/connect.py +139 -0
- lightning_sdk/cli/studio/create.py +96 -0
- lightning_sdk/cli/studio/delete.py +49 -0
- lightning_sdk/cli/studio/list.py +85 -0
- lightning_sdk/cli/studio/ssh.py +64 -0
- lightning_sdk/cli/studio/start.py +115 -0
- lightning_sdk/cli/studio/stop.py +45 -0
- lightning_sdk/cli/studio/switch.py +66 -0
- lightning_sdk/cli/utils/__init__.py +7 -0
- lightning_sdk/cli/utils/cloud_account_map.py +10 -0
- lightning_sdk/cli/utils/coloring.py +60 -0
- lightning_sdk/cli/utils/get_base_studio.py +24 -0
- lightning_sdk/cli/utils/handle_machine_and_gpus_args.py +69 -0
- lightning_sdk/cli/utils/logging.py +122 -0
- lightning_sdk/cli/utils/owner_selection.py +110 -0
- lightning_sdk/cli/utils/resolve.py +28 -0
- lightning_sdk/cli/utils/richt_print.py +35 -0
- lightning_sdk/cli/utils/save_to_config.py +27 -0
- lightning_sdk/cli/utils/ssh_connection.py +59 -0
- lightning_sdk/cli/utils/studio_selection.py +113 -0
- lightning_sdk/cli/utils/teamspace_selection.py +125 -0
- lightning_sdk/cli/vm/__init__.py +20 -0
- lightning_sdk/cli/vm/create.py +33 -0
- lightning_sdk/cli/vm/delete.py +25 -0
- lightning_sdk/cli/vm/list.py +30 -0
- lightning_sdk/cli/vm/ssh.py +31 -0
- lightning_sdk/cli/vm/start.py +60 -0
- lightning_sdk/cli/vm/stop.py +25 -0
- lightning_sdk/cli/vm/switch.py +38 -0
- lightning_sdk/constants.py +1 -0
- lightning_sdk/deployment/__init__.py +4 -0
- lightning_sdk/deployment/deployment.py +208 -28
- lightning_sdk/helpers.py +73 -34
- lightning_sdk/job/base.py +112 -12
- lightning_sdk/job/job.py +73 -44
- lightning_sdk/job/v1.py +28 -35
- lightning_sdk/job/v2.py +54 -17
- lightning_sdk/job/work.py +7 -3
- lightning_sdk/lightning_cloud/login.py +325 -18
- lightning_sdk/lightning_cloud/openapi/__init__.py +346 -26
- lightning_sdk/lightning_cloud/openapi/api/__init__.py +14 -0
- lightning_sdk/lightning_cloud/openapi/api/assistants_service_api.py +1801 -384
- lightning_sdk/lightning_cloud/openapi/api/auth_service_api.py +376 -0
- lightning_sdk/lightning_cloud/openapi/api/billing_service_api.py +414 -2
- lightning_sdk/lightning_cloud/openapi/api/blog_posts_service_api.py +533 -0
- lightning_sdk/lightning_cloud/openapi/api/cloud_space_environment_template_service_api.py +638 -0
- lightning_sdk/lightning_cloud/openapi/api/cloud_space_service_api.py +2563 -866
- lightning_sdk/lightning_cloud/openapi/api/cloudy_service_api.py +327 -0
- lightning_sdk/lightning_cloud/openapi/api/cluster_service_api.py +1720 -347
- lightning_sdk/lightning_cloud/openapi/api/data_connection_service_api.py +210 -4
- lightning_sdk/lightning_cloud/openapi/api/endpoint_service_api.py +126 -2119
- lightning_sdk/lightning_cloud/openapi/api/file_system_service_api.py +283 -0
- lightning_sdk/lightning_cloud/openapi/api/git_credentials_service_api.py +497 -0
- lightning_sdk/lightning_cloud/openapi/api/incidents_service_api.py +1058 -0
- lightning_sdk/lightning_cloud/openapi/api/jobs_service_api.py +2326 -492
- lightning_sdk/lightning_cloud/openapi/api/k8_s_cluster_service_api.py +2273 -0
- lightning_sdk/lightning_cloud/openapi/api/lit_dataset_service_api.py +1973 -0
- lightning_sdk/lightning_cloud/openapi/api/lit_logger_service_api.py +17 -5
- lightning_sdk/lightning_cloud/openapi/api/lit_registry_service_api.py +473 -5
- lightning_sdk/lightning_cloud/openapi/api/markets_service_api.py +145 -0
- lightning_sdk/lightning_cloud/openapi/api/models_store_api.py +24 -24
- lightning_sdk/lightning_cloud/openapi/api/organizations_service_api.py +105 -0
- lightning_sdk/lightning_cloud/openapi/api/pipeline_templates_service_api.py +339 -0
- lightning_sdk/lightning_cloud/openapi/api/pipelines_service_api.py +795 -0
- lightning_sdk/lightning_cloud/openapi/api/product_license_service_api.py +525 -0
- lightning_sdk/lightning_cloud/openapi/api/projects_service_api.py +106 -5
- lightning_sdk/lightning_cloud/openapi/api/schedules_service_api.py +924 -0
- lightning_sdk/lightning_cloud/openapi/api/sdk_command_history_service_api.py +141 -0
- lightning_sdk/lightning_cloud/openapi/api/slurm_jobs_user_service_api.py +202 -0
- lightning_sdk/lightning_cloud/openapi/api/storage_service_api.py +1508 -251
- lightning_sdk/lightning_cloud/openapi/api/user_service_api.py +121 -97
- lightning_sdk/lightning_cloud/openapi/api/volume_service_api.py +258 -0
- lightning_sdk/lightning_cloud/openapi/configuration.py +4 -20
- lightning_sdk/lightning_cloud/openapi/models/__init__.py +332 -26
- lightning_sdk/lightning_cloud/openapi/models/agentmanagedendpoints_id_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/agents_id_body.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/alertingevents_id_body.py +409 -0
- lightning_sdk/lightning_cloud/openapi/models/alerts_config_billing.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/alerts_config_studios.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/assistant_id_conversations_body.py +303 -17
- lightning_sdk/lightning_cloud/openapi/models/blogposts_id_body.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/cloudspace_id_systemmetrics_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/cloudspace_id_visibility_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/cloudspaces_id_body.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_capacityblock_body.py +15 -15
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_capacityreservations_body.py +81 -3
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_kubernetestemplates_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_metrics_body.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_slurmusers_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/cluster_id_usagerestrictions_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/conversations_id_body1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/create.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/create_deployment_request_defines_a_spec_for_the_job_that_allows_for_autoscaling_jobs.py +131 -1
- lightning_sdk/lightning_cloud/openapi/models/create_machine_request_represents_the_request_to_create_a_machine.py +461 -0
- lightning_sdk/lightning_cloud/openapi/models/credits_autoreplenish_body.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/credits_autoreplenish_body1.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/dataset_id_versions_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/dataset_id_visibility_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/deployment_id_alertingpolicies_body.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/deployment_id_alertingpolicies_body1.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/deployments_id_body.py +315 -3
- lightning_sdk/lightning_cloud/openapi/models/endpoints_id_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/externalv1_cloud_space_instance_status.py +199 -69
- lightning_sdk/lightning_cloud/openapi/models/externalv1_cluster.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/externalv1_user_status.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/id_codeconfig_body.py +1 -53
- lightning_sdk/lightning_cloud/openapi/models/id_contactowner_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/id_fork_body1.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/id_render_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/id_reportrestarttimings_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/id_sleepconfig_body.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/id_transfer_body.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/id_visibility_body1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/id_visibility_body2.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/incident_id_messages_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/incidents_id_body.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_list_service_executions_response.py → job_id_reportroutingtelemetry_body.py} +23 -23
- lightning_sdk/lightning_cloud/openapi/models/kubernetestemplates_id_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/license_key_validate_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/litdatasets_dataset_id_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/litregistry_lit_repo_name_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/message_id_actions_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/messages_id_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/messages_message_id_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/metricsstream_create_body.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/metricsstream_id_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/model_id_versions_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/model_id_visibility_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/models_id_body.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/models_model_id_body.py +109 -31
- lightning_sdk/lightning_cloud/openapi/models/models_model_id_body1.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/org_id_memberships_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/orgs_id_body.py +627 -3
- lightning_sdk/lightning_cloud/openapi/models/pipelines_id_body.py +539 -0
- lightning_sdk/lightning_cloud/openapi/models/pipelines_id_body1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/pipelinetemplates_id_body.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/project_id_agents_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/project_id_cloudspaces_body.py +131 -1
- lightning_sdk/lightning_cloud/openapi/models/project_id_litdatasets_body.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/project_id_litregistry_body.py +2 -0
- lightning_sdk/lightning_cloud/openapi/models/project_id_pipelines_body.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/project_id_schedules_body.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/project_id_storage_body.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/project_id_storagetransfers_body.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/project_tab_management_messages.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/projects_id_body.py +523 -3
- lightning_sdk/lightning_cloud/openapi/models/{service_artifact_artifact_kind.py → protobuf_null_value.py} +7 -9
- lightning_sdk/lightning_cloud/openapi/models/schedules_id_body.py +513 -0
- lightning_sdk/lightning_cloud/openapi/models/server_id_alerts_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/setup.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/slurm_jobs_body.py +93 -15
- lightning_sdk/lightning_cloud/openapi/models/storage_complete_body.py +41 -15
- lightning_sdk/lightning_cloud/openapi/models/storagetransfers_validate_body.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/update.py +233 -129
- lightning_sdk/lightning_cloud/openapi/models/update1.py +383 -0
- lightning_sdk/lightning_cloud/openapi/models/upload_id_complete_body1.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/upload_id_parts_body1.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/uploads_upload_id_body.py +1 -27
- lightning_sdk/lightning_cloud/openapi/models/uploads_upload_id_body1.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/usagerestrictions_id_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/user_id_affiliatelinks_body.py +107 -3
- lightning_sdk/lightning_cloud/openapi/models/user_id_upgradetrigger_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/user_user_id_body.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_abort_storage_transfer_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_agent_job.py +188 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_aggregated_pod_metrics.py +799 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_ai_pod_v1.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_alert_method.py +102 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_alerts_config.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_artifact.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_assistant.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_assistant_model_status.py +6 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_assistant_session_daily_aggregated.py +383 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_author.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_aws_direct_v1.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_billing_subscription.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_billing_tier.py +1 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_blog_post.py +435 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cancel_running_cloud_space_instance_transfer_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_capacity_block_offering.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_check_cluster_name_availability_request.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_check_cluster_name_availability_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_provider.py +117 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space.py +313 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_artifact_event.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_artifact_event_type.py +103 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_cold_start_metrics.py +669 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_cold_start_metrics_stats.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_environment_config.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_environment_template.py +409 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_environment_template_config.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_environment_type.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_session.py +29 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_source_type.py +103 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_specialized_view.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_state.py +1 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_transfer_metadata.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloudflare_v1.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloudy_expert.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cloudy_settings.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_accelerator.py +445 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_capacity_reservation.py +211 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_deletion_options.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_metrics.py +1527 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_security_options.py +209 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_spec.py +521 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_status.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_tagging_options.py +55 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_type.py +2 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_upload_service_execution_artifact_response.py → v1_cluster_upload.py} +34 -34
- lightning_sdk/lightning_cloud/openapi/models/v1_cluster_usage_restriction.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_complete_lit_dataset_multi_part_upload_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_complete_lit_dataset_upload_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_complete_running_cloud_space_instance_transfer_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/{id_complete_body.py → v1_complete_upload_temporary_artifact_request.py} +29 -29
- lightning_sdk/lightning_cloud/openapi/models/v1_contact_assistant_owner_reason.py +102 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_contact_assistant_owner_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_container_metrics.py +461 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_conversation.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_conversation_response_chunk.py +107 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_create_billing_upgrade_trigger_record_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_blog_post_request.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_checkout_session_request.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_create_cloud_space_environment_template_request.py +409 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_cluster_capacity_reservation_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_create_deployment_request.py +539 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_deployment_template_request.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_create_git_credentials_request.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_incident_request.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_job_request.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_license_request.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_lit_dataset_multi_part_upload_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_machine_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_managed_endpoint_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_model_metrics_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_multi_machine_job_request.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_organization_request.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_create_pipeline_template_request.py +383 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_project_request.py +209 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_create_sdk_command_history_request.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_sdk_command_history_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_server_alert_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_create_subscription_checkout_session_request.py +55 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_daily_model_metrics.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_daily_usage.py +81 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_data_connection.py +261 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_data_connection_tier.py +103 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_blog_post_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_cloud_space_environment_template_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_cluster_usage_restriction_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_deployment_alerting_policy_response.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_git_credentials_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_incident_message_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_incident_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_kubernetes_template_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_license_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_lit_dataset_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_lit_dataset_version_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_lit_registry_repository_image_artifact_version_by_digest_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_machine_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_delete_file_endpoint_response.py → v1_delete_pipeline_response.py} +25 -25
- lightning_sdk/lightning_cloud/openapi/models/v1_delete_schedule_response.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment.py +315 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_event.py +487 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_policy.py +409 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_policy_frequency.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_policy_operation.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_policy_severity.py +106 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_policy_type.py +112 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_alerting_recipients.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_api.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_details.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_state.py +4 -2
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_status.py +47 -21
- lightning_sdk/lightning_cloud/openapi/models/v1_deployment_template.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_endpoint.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_external_cluster.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_external_cluster_spec.py +931 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_external_search_user.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_filestore_data_connection.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_filesystem_job.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_filesystem_metric.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_filesystem_metrics.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_filesystem_mmt.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_find_capacity_block_offering_response.py +29 -3
- lightning_sdk/lightning_cloud/openapi/models/{id_uploads_body1.py → v1_firewall_rule.py} +53 -53
- lightning_sdk/lightning_cloud/openapi/models/v1_function_call.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_function_tool.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_list_file_endpoints_response.py → v1_gcp_data_connection_setup.py} +23 -23
- lightning_sdk/lightning_cloud/openapi/models/v1_gcp_direct_vpc.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_ge_list_deployment_routing_telemetry_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_artifacts_page_response.py +29 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_get_assistant_session_daily_aggregated_response.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_cold_start_metrics_stats_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_instance_open_ports_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_instance_system_metrics_aggregate_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_required_balance_status_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_size_response.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cloud_space_transfer_estimate_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cluster_accelerator_demand_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_cluster_health_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_deployment_routing_telemetry_content_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_job_stats_response.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_get_latest_model_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_upload_service_execution_artifact_parts_response.py → v1_get_lit_dataset_file_upload_urls_response.py} +16 -16
- lightning_sdk/lightning_cloud/openapi/models/v1_get_lit_dataset_files_url_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_machine_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_market_pricing_response.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_model_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_organization_storage_metadata_response.py +487 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_project_balance_response.py +1 -27
- lightning_sdk/lightning_cloud/openapi/models/v1_get_project_storage_metadata_response.py +263 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_get_temp_bucket_credentials_response.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_get_user_response.py +235 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_get_user_storage_breakdown_response.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_get_volume_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_git_credentials.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_google_cloud_direct_v1.py +185 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_group_node_metrics.py +1215 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_group_pod_metrics.py +1241 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_guest_login_request.py +177 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_guest_login_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_service_artifact.py → v1_guest_user.py} +60 -60
- lightning_sdk/lightning_cloud/openapi/models/v1_incident.py +565 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_incident_detail.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_incident_event.py +591 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_incident_message.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_incident_severity.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_incident_type.py +108 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_instance_overprovisioning_spec.py +95 -41
- lightning_sdk/lightning_cloud/openapi/models/v1_job.py +237 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_job_artifacts_type.py +103 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_job_resource.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_job_spec.py +209 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_job_timing.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_job_type.py +109 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_k8s_incident_indexes.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kai_scheduler_queue_metrics.py +627 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_aws_config.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_direct_settings_v1.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_direct_v1.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_direct_v1_status.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_template.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_kubernetes_template_property.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lambda_labs_direct_v1.py +67 -17
- lightning_sdk/lightning_cloud/openapi/models/v1_license.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lightning_elastic_cluster_v1.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lightning_run.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_lightningapp_instance_artifact.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_like_status.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_aggregated_pod_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_download_service_execution_artifact_response.py → v1_list_blog_posts_response.py} +41 -41
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cloud_space_cold_start_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cloud_space_environment_templates_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cloudy_experts_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cluster_metric_timestamps_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cluster_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cluster_namespace_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cluster_namespace_user_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_cluster_usage_restrictions_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_clusters_response.py +6 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_list_container_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_conversation_message_actions_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_deployment_alerting_events_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_deployment_alerting_policies_response.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_filesystem_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_filesystem_mm_ts_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_git_credentials_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_group_pod_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_incident_events_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_incident_messages_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_incidents_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_job_resources_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_kai_scheduler_queues_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_kubernetes_templates_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_license_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_lit_dataset_versions_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_lit_datasets_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_lit_registry_repository_image_artifact_versions_response.py +257 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_machines_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_node_file_system_metrics_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_node_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_notification_dialogs_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_pipelines_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_platform_notifications_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_pod_metrics_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_project_clusters_response.py +6 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_list_published_managed_endpoints_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_schedule_runs_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_schedules_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_slurm_cluster_users_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_list_storage_transfers_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lit_dataset.py +539 -0
- lightning_sdk/lightning_cloud/openapi/models/{id_storage_body.py → v1_lit_dataset_file.py} +49 -49
- lightning_sdk/lightning_cloud/openapi/models/v1_lit_dataset_version_archive.py +435 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lit_registry_artifact.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lit_registry_project.py +35 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_lit_repository.py +81 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_lite_published_cloud_space_response.py +513 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_lustre_data_connection.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_machine.py +617 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_machine_direct_v1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_magic_link_login_response.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_managed_endpoint.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_managed_model.py +341 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_market_price.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_membership.py +121 -17
- lightning_sdk/lightning_cloud/openapi/models/v1_message.py +159 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_message_action.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_metadata.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_metrics_stream.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_model.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_model_metrics.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_delete_service_execution_response.py → v1_modify_filesystem_volume_response.py} +6 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_multi_machine_job.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_multi_machine_job_state.py +2 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_namespace_metrics.py +591 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_namespace_user_metrics.py +435 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_nebius_direct_v1.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_node_metrics.py +695 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_notification_type.py +2 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_organization.py +837 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_path_mapping.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pause_storage_transfer_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline.py +591 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_parameter.py +435 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_parameter_placement.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_parameter_placement_type.py +106 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_parameter_type.py +106 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_state.py +111 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_step.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_step_status.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_step_type.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_template.py +513 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pipeline_template_visibility_type.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_platform_notification.py +279 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_pod_metrics.py +747 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_post_cloud_space_artifact_events_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_project.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_project_cluster_binding.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_project_membership.py +121 -17
- lightning_sdk/lightning_cloud/openapi/models/v1_project_settings.py +525 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_project_storage.py +235 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_project_tab.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_purchase_annual_upsell_request.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_purchase_annual_upsell_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_quote_annual_upsell_response.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_quote_subscription_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_r2_data_connection.py +305 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_render_kubernetes_template_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_report_cloud_space_instance_stop_at_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_report_cloud_space_instance_system_metrics_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_report_deployment_routing_telemetry_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_report_k8s_cluster_metrics_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_report_restart_timings_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_request_cloud_space_access_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_required_balance_reason.py +107 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_reservation_details.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_reset_api_key_request.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_reset_api_key_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_resource_visibility.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_resources.py +55 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_response_choice.py +29 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_restart_timing.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_resume_storage_transfer_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_routing_telemetry.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_rule_resource.py +5 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_schedule.py +565 -0
- lightning_sdk/lightning_cloud/openapi/models/{command_argument_command_argument_type.py → v1_schedule_action_type.py} +9 -8
- lightning_sdk/lightning_cloud/openapi/models/v1_schedule_resource_type.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_schedule_run.py +357 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_sdk_command_history_severity.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_sdk_command_history_type.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_secret_type.py +2 -0
- lightning_sdk/lightning_cloud/openapi/models/{v1_get_service_execution_status_response.py → v1_server_alert.py} +74 -48
- lightning_sdk/lightning_cloud/openapi/models/v1_server_alert_phase.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_server_alert_severity.py +103 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_server_alert_type.py +108 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_service_health.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_setup_data_connection_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_shared_filesystem.py +331 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_slack_notifier.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_slack_notifier_type.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_sleep_server_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_slurm_cluster_user.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_slurm_job.py +84 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_slurm_node.py +31 -291
- lightning_sdk/lightning_cloud/openapi/models/v1_slurm_v1.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_slurm_v1_status.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_storage_asset.py +159 -3
- lightning_sdk/lightning_cloud/openapi/models/v1_storage_asset_type.py +4 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_storage_transfer.py +435 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_storage_transfer_status.py +108 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_subnet_spec.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_system_metrics_aggregated.py +227 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_token_login_request.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_token_login_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_token_owner_type.py +104 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_token_usage.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_tool.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_tool_call.py +175 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_transaction.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_transfer_cloud_space_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_trigger_filesystem_upgrade_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_cloud_space_instance_config_request.py +253 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_cloud_space_visibility_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_conversation_like_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_conversation_message_like_response.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_deployment_visibility_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_job_visibility_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_lit_dataset_visibility_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_lit_repository_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_metrics_stream_visibility_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_update_model_visibility_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/{v1_complete_upload_service_execution_artifact_response.py → v1_update_organization_credits_auto_replenish_response.py} +6 -6
- lightning_sdk/lightning_cloud/openapi/models/v1_update_project_tab_order_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_user_credits_auto_replenish_response.py +97 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_update_user_request.py +131 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_update_volume_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_upload_project_artifact_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/{v1_list_new_features_for_user_response.py → v1_upload_temporary_artifact_request.py} +23 -23
- lightning_sdk/lightning_cloud/openapi/models/v1_usage.py +105 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_usage_report.py +79 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_user_features.py +894 -842
- lightning_sdk/lightning_cloud/openapi/models/v1_user_requested_compute_config.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_validate_data_connection_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_validate_deployment_image_request.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_validate_license_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_validate_managed_endpoint_response.py +27 -1
- lightning_sdk/lightning_cloud/openapi/models/v1_validate_storage_transfer_response.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_voltage_park_direct_v1.py +229 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_volume.py +513 -45
- lightning_sdk/lightning_cloud/openapi/models/v1_volume_state.py +105 -0
- lightning_sdk/lightning_cloud/openapi/models/v1_vultr_direct_v1.py +1 -27
- lightning_sdk/lightning_cloud/openapi/models/v1_weka_data_connection.py +201 -0
- lightning_sdk/lightning_cloud/openapi/models/validate.py +53 -1
- lightning_sdk/lightning_cloud/openapi/models/version_default_body.py +29 -29
- lightning_sdk/lightning_cloud/openapi/models/version_default_body1.py +149 -0
- lightning_sdk/lightning_cloud/openapi/models/version_uploads_body1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/versions_version_body1.py +123 -0
- lightning_sdk/lightning_cloud/openapi/models/volumes_id_body.py +123 -0
- lightning_sdk/lightning_cloud/rest_client.py +61 -48
- lightning_sdk/lightning_cloud/source_code/logs_socket_api.py +8 -3
- lightning_sdk/lightning_cloud/utils/data_connection.py +234 -7
- lightning_sdk/lit_container.py +68 -9
- lightning_sdk/llm/__init__.py +3 -0
- lightning_sdk/llm/llm.py +497 -0
- lightning_sdk/llm/public_assistants.py +54 -0
- lightning_sdk/machine.py +221 -30
- lightning_sdk/mmt/base.py +67 -32
- lightning_sdk/mmt/mmt.py +68 -50
- lightning_sdk/mmt/v1.py +16 -32
- lightning_sdk/mmt/v2.py +47 -18
- lightning_sdk/models.py +74 -24
- lightning_sdk/organization.py +4 -0
- lightning_sdk/owner.py +2 -1
- lightning_sdk/pipeline/__init__.py +14 -0
- lightning_sdk/pipeline/pipeline.py +163 -0
- lightning_sdk/pipeline/printer.py +124 -0
- lightning_sdk/pipeline/schedule.py +859 -0
- lightning_sdk/pipeline/steps.py +365 -0
- lightning_sdk/pipeline/utils.py +116 -0
- lightning_sdk/plugin.py +39 -20
- lightning_sdk/sandbox.py +160 -0
- lightning_sdk/serve.py +309 -0
- lightning_sdk/services/__init__.py +1 -1
- lightning_sdk/services/file_endpoint.py +3 -4
- lightning_sdk/services/utilities.py +16 -2
- lightning_sdk/studio.py +515 -41
- lightning_sdk/teamspace.py +335 -30
- lightning_sdk/user.py +19 -1
- lightning_sdk/utils/config.py +179 -0
- lightning_sdk/utils/license.py +13 -0
- lightning_sdk/utils/logging.py +79 -0
- lightning_sdk/utils/names.py +1179 -0
- lightning_sdk/utils/progress.py +283 -0
- lightning_sdk/utils/resolve.py +149 -13
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/METADATA +14 -11
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/RECORD +649 -250
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/WHEEL +1 -1
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/entry_points.txt +1 -0
- lightning_sdk/cli/ai_hub.py +0 -49
- lightning_sdk/cli/delete.py +0 -58
- lightning_sdk/cli/download.py +0 -132
- lightning_sdk/cli/inspect.py +0 -31
- lightning_sdk/cli/legacy.py +0 -135
- lightning_sdk/cli/list.py +0 -112
- lightning_sdk/cli/run.py +0 -225
- lightning_sdk/cli/serve.py +0 -218
- lightning_sdk/cli/stop.py +0 -37
- lightning_sdk/cli/upload.py +0 -255
- lightning_sdk/lightning_cloud/openapi/models/fileendpoints_id_body.py +0 -409
- lightning_sdk/lightning_cloud/openapi/models/project_id_fileendpoints_body.py +0 -357
- lightning_sdk/lightning_cloud/openapi/models/project_id_serviceexecution_body.py +0 -175
- lightning_sdk/lightning_cloud/openapi/models/serviceexecution_id_body.py +0 -331
- lightning_sdk/lightning_cloud/openapi/models/v1_command_argument.py +0 -305
- lightning_sdk/lightning_cloud/openapi/models/v1_ebs.py +0 -279
- lightning_sdk/lightning_cloud/openapi/models/v1_file_endpoint.py +0 -461
- lightning_sdk/lightning_cloud/openapi/models/v1_get_user_storage_response.py +0 -201
- lightning_sdk/lightning_cloud/openapi/models/v1_list_service_execution_lightningapp_instances_response.py +0 -175
- lightning_sdk/lightning_cloud/openapi/models/v1_service_execution.py +0 -383
- /lightning_sdk/cli/{exceptions.py → legacy/exceptions.py} +0 -0
- /lightning_sdk/services/{finetune/__init__.py → finetune_llm.py} +0 -0
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/LICENSE +0 -0
- {lightning_sdk-0.1.49.dist-info → lightning_sdk-2025.11.5.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,365 @@
|
|
|
1
|
+
from typing import TYPE_CHECKING, Any, Dict, List, Optional, Union
|
|
2
|
+
|
|
3
|
+
from lightning_sdk.api.deployment_api import (
|
|
4
|
+
AutoScaleConfig,
|
|
5
|
+
AutoScalingMetric,
|
|
6
|
+
BasicAuth,
|
|
7
|
+
Env,
|
|
8
|
+
ExecHealthCheck,
|
|
9
|
+
HttpHealthCheck,
|
|
10
|
+
ReleaseStrategy,
|
|
11
|
+
Secret,
|
|
12
|
+
TokenAuth,
|
|
13
|
+
to_autoscaling,
|
|
14
|
+
to_endpoint,
|
|
15
|
+
to_spec,
|
|
16
|
+
to_strategy,
|
|
17
|
+
)
|
|
18
|
+
from lightning_sdk.job.v2 import JobApiV2
|
|
19
|
+
from lightning_sdk.lightning_cloud.openapi.models import (
|
|
20
|
+
V1CreateDeploymentRequest,
|
|
21
|
+
V1PipelineStep,
|
|
22
|
+
V1PipelineStepType,
|
|
23
|
+
V1SharedFilesystem,
|
|
24
|
+
)
|
|
25
|
+
from lightning_sdk.machine import Machine
|
|
26
|
+
from lightning_sdk.mmt.v2 import MMTApiV2
|
|
27
|
+
from lightning_sdk.pipeline.utils import DEFAULT, _get_studio, _to_wait_for, _validate_cloud_account
|
|
28
|
+
from lightning_sdk.studio import CloudAccountApi, Studio
|
|
29
|
+
|
|
30
|
+
if TYPE_CHECKING:
|
|
31
|
+
from lightning_sdk.organization import Organization
|
|
32
|
+
from lightning_sdk.teamspace import CloudProvider, Teamspace
|
|
33
|
+
from lightning_sdk.user import User
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
class DeploymentStep:
|
|
37
|
+
# Note: This class is only temporary while pipeline is wip
|
|
38
|
+
|
|
39
|
+
def __init__(
|
|
40
|
+
self,
|
|
41
|
+
name: Optional[str] = None,
|
|
42
|
+
studio: Optional[Union[str, Studio]] = None,
|
|
43
|
+
machine: Optional["Machine"] = None,
|
|
44
|
+
image: Optional[str] = None,
|
|
45
|
+
autoscale: Optional[AutoScaleConfig] = None,
|
|
46
|
+
ports: Optional[Union[float, List[float]]] = None,
|
|
47
|
+
release_strategy: Optional[ReleaseStrategy] = None,
|
|
48
|
+
entrypoint: Optional[str] = None,
|
|
49
|
+
command: Optional[str] = None,
|
|
50
|
+
commands: Optional[List[str]] = None,
|
|
51
|
+
env: Union[List[Union[Secret, Env]], Dict[str, str], None] = None,
|
|
52
|
+
spot: Optional[bool] = None,
|
|
53
|
+
replicas: Optional[int] = None,
|
|
54
|
+
health_check: Optional[Union[HttpHealthCheck, ExecHealthCheck]] = None,
|
|
55
|
+
auth: Optional[Union[BasicAuth, TokenAuth]] = None,
|
|
56
|
+
cloud_account: Optional[str] = None,
|
|
57
|
+
custom_domain: Optional[str] = None,
|
|
58
|
+
quantity: Optional[int] = None,
|
|
59
|
+
include_credentials: Optional[bool] = None,
|
|
60
|
+
max_runtime: Optional[int] = None,
|
|
61
|
+
wait_for: Optional[Union[str, List[str]]] = DEFAULT,
|
|
62
|
+
cloud_provider: Optional[Union["CloudProvider", str]] = None,
|
|
63
|
+
) -> None:
|
|
64
|
+
self.name = name
|
|
65
|
+
self.studio = _get_studio(studio)
|
|
66
|
+
if cloud_account and studio and cloud_account != studio.cloud_account != cloud_account:
|
|
67
|
+
raise ValueError(
|
|
68
|
+
f"The provided cloud account `{cloud_account}` doesn't match"
|
|
69
|
+
f" the Studio cloud account {self.studio.cloud_account}"
|
|
70
|
+
)
|
|
71
|
+
|
|
72
|
+
self.machine = machine or Machine.CPU
|
|
73
|
+
self.image = image
|
|
74
|
+
autoscaling_metric_name = (
|
|
75
|
+
("CPU" if self.machine.is_cpu() else "GPU") if isinstance(self.machine, Machine) else "CPU"
|
|
76
|
+
)
|
|
77
|
+
self.autoscale = autoscale or AutoScaleConfig(
|
|
78
|
+
min_replicas=0,
|
|
79
|
+
max_replicas=1,
|
|
80
|
+
target_metrics=[
|
|
81
|
+
AutoScalingMetric(
|
|
82
|
+
name=autoscaling_metric_name,
|
|
83
|
+
target=80,
|
|
84
|
+
)
|
|
85
|
+
],
|
|
86
|
+
)
|
|
87
|
+
self.ports = ports
|
|
88
|
+
self.release_strategy = release_strategy
|
|
89
|
+
self.entrypoint = entrypoint
|
|
90
|
+
self.command = command
|
|
91
|
+
self.commands = commands
|
|
92
|
+
self.env = env
|
|
93
|
+
self.spot = spot
|
|
94
|
+
self.replicas = replicas or 1
|
|
95
|
+
self.health_check = health_check
|
|
96
|
+
self.auth = auth
|
|
97
|
+
self.cloud_account = cloud_account or "" if self.studio is None else self.studio.cloud_account
|
|
98
|
+
self.custom_domain = custom_domain
|
|
99
|
+
self.quantity = quantity
|
|
100
|
+
self.include_credentials = include_credentials or True
|
|
101
|
+
self.max_runtime = max_runtime
|
|
102
|
+
self.wait_for = wait_for
|
|
103
|
+
self.cloud_provider = cloud_provider
|
|
104
|
+
|
|
105
|
+
def to_proto(
|
|
106
|
+
self, teamspace: "Teamspace", cloud_account: str, shared_filesystem: Union[bool, V1SharedFilesystem]
|
|
107
|
+
) -> V1PipelineStep:
|
|
108
|
+
machine_image_version = None
|
|
109
|
+
|
|
110
|
+
studio = _get_studio(self.studio)
|
|
111
|
+
if isinstance(studio, Studio):
|
|
112
|
+
machine_image_version = studio._studio.machine_image_version
|
|
113
|
+
|
|
114
|
+
if self.cloud_account is None:
|
|
115
|
+
self.cloud_account = studio.cloud_account
|
|
116
|
+
elif studio.cloud_account != self.cloud_account:
|
|
117
|
+
raise ValueError("The provided cloud account doesn't match the studio")
|
|
118
|
+
|
|
119
|
+
resolved_cloud_account = CloudAccountApi().resolve_cloud_account(
|
|
120
|
+
teamspace.id, self.cloud_account, self.cloud_provider, teamspace.default_cloud_account
|
|
121
|
+
)
|
|
122
|
+
|
|
123
|
+
_validate_cloud_account(cloud_account, resolved_cloud_account, shared_filesystem)
|
|
124
|
+
|
|
125
|
+
return V1PipelineStep(
|
|
126
|
+
name=self.name,
|
|
127
|
+
type=V1PipelineStepType.DEPLOYMENT,
|
|
128
|
+
wait_for=_to_wait_for(self.wait_for),
|
|
129
|
+
deployment=V1CreateDeploymentRequest(
|
|
130
|
+
autoscaling=to_autoscaling(self.autoscale, self.replicas),
|
|
131
|
+
endpoint=to_endpoint(self.ports, self.auth, self.custom_domain),
|
|
132
|
+
name=self.name,
|
|
133
|
+
project_id=teamspace.id,
|
|
134
|
+
replicas=self.replicas,
|
|
135
|
+
spec=to_spec(
|
|
136
|
+
cloud_account=self.cloud_account or cloud_account,
|
|
137
|
+
command=self.command,
|
|
138
|
+
entrypoint=self.entrypoint,
|
|
139
|
+
env=self.env,
|
|
140
|
+
image=self.image,
|
|
141
|
+
spot=self.spot,
|
|
142
|
+
machine=self.machine,
|
|
143
|
+
health_check=self.health_check,
|
|
144
|
+
quantity=self.quantity,
|
|
145
|
+
cloudspace_id=self.studio._studio.id if self.studio else None,
|
|
146
|
+
include_credentials=self.include_credentials,
|
|
147
|
+
max_runtime=self.max_runtime,
|
|
148
|
+
machine_image_version=machine_image_version,
|
|
149
|
+
),
|
|
150
|
+
strategy=to_strategy(self.release_strategy),
|
|
151
|
+
),
|
|
152
|
+
)
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
class JobStep:
|
|
156
|
+
# Note: This class is only temporary while pipeline is wip
|
|
157
|
+
|
|
158
|
+
def __init__(
|
|
159
|
+
self,
|
|
160
|
+
machine: Optional[Union["Machine", str]] = None,
|
|
161
|
+
name: Optional[str] = None,
|
|
162
|
+
command: Optional[str] = None,
|
|
163
|
+
studio: Union["Studio", str, None] = None,
|
|
164
|
+
image: Union[str, None] = None,
|
|
165
|
+
teamspace: Union[str, "Teamspace", None] = None,
|
|
166
|
+
org: Union[str, "Organization", None] = None,
|
|
167
|
+
user: Union[str, "User", None] = None,
|
|
168
|
+
cloud_account: Optional[str] = None,
|
|
169
|
+
cloud_provider: Optional[Union["CloudProvider", str]] = None,
|
|
170
|
+
env: Optional[Dict[str, str]] = None,
|
|
171
|
+
interruptible: bool = False,
|
|
172
|
+
image_credentials: Optional[str] = None,
|
|
173
|
+
cloud_account_auth: bool = False,
|
|
174
|
+
entrypoint: str = "sh -c",
|
|
175
|
+
path_mappings: Optional[Dict[str, str]] = None,
|
|
176
|
+
max_runtime: Optional[int] = None,
|
|
177
|
+
wait_for: Union[str, List[str], None] = DEFAULT,
|
|
178
|
+
reuse_snapshot: bool = True,
|
|
179
|
+
) -> None:
|
|
180
|
+
self.name = name
|
|
181
|
+
self.machine = machine or Machine.CPU
|
|
182
|
+
self.command = command
|
|
183
|
+
self.studio = _get_studio(studio)
|
|
184
|
+
|
|
185
|
+
if cloud_account and self.studio and cloud_account != self.studio.cloud_account != cloud_account:
|
|
186
|
+
raise ValueError(
|
|
187
|
+
f"The provided cloud account `{cloud_account}` doesn't match"
|
|
188
|
+
f" the Studio cloud account {self.studio.cloud_account}"
|
|
189
|
+
)
|
|
190
|
+
|
|
191
|
+
self.image = image
|
|
192
|
+
self.teamspace = teamspace
|
|
193
|
+
self.org = org
|
|
194
|
+
self.user = user
|
|
195
|
+
self.cloud_account = cloud_account or "" if self.studio is None else self.studio.cloud_account
|
|
196
|
+
self.cloud_provider = cloud_provider
|
|
197
|
+
self.env = env
|
|
198
|
+
self.interruptible = interruptible
|
|
199
|
+
self.image_credentials = image_credentials
|
|
200
|
+
self.cloud_account_auth = cloud_account_auth
|
|
201
|
+
self.entrypoint = entrypoint
|
|
202
|
+
self.path_mappings = path_mappings
|
|
203
|
+
self.max_runtime = max_runtime
|
|
204
|
+
self.wait_for = wait_for
|
|
205
|
+
self.reuse_snapshot = reuse_snapshot
|
|
206
|
+
|
|
207
|
+
def to_proto(
|
|
208
|
+
self, teamspace: "Teamspace", cloud_account: str, shared_filesystem: Union[bool, V1SharedFilesystem]
|
|
209
|
+
) -> V1PipelineStep:
|
|
210
|
+
machine_image_version = None
|
|
211
|
+
|
|
212
|
+
studio = _get_studio(self.studio)
|
|
213
|
+
if isinstance(studio, Studio):
|
|
214
|
+
machine_image_version = studio._studio.machine_image_version
|
|
215
|
+
|
|
216
|
+
if self.cloud_account is None:
|
|
217
|
+
self.cloud_account = studio.cloud_account
|
|
218
|
+
elif studio.cloud_account != self.cloud_account:
|
|
219
|
+
raise ValueError("The provided cloud account doesn't match the studio")
|
|
220
|
+
|
|
221
|
+
resolved_cloud_account = CloudAccountApi().resolve_cloud_account(
|
|
222
|
+
teamspace.id, self.cloud_account, self.cloud_provider, teamspace.default_cloud_account
|
|
223
|
+
)
|
|
224
|
+
|
|
225
|
+
_validate_cloud_account(cloud_account, resolved_cloud_account, shared_filesystem)
|
|
226
|
+
|
|
227
|
+
body = JobApiV2._create_job_body(
|
|
228
|
+
name=self.name,
|
|
229
|
+
command=self.command,
|
|
230
|
+
cloud_account=resolved_cloud_account or cloud_account,
|
|
231
|
+
studio_id=studio._studio.id if isinstance(studio, Studio) else None,
|
|
232
|
+
image=self.image,
|
|
233
|
+
machine=self.machine,
|
|
234
|
+
interruptible=self.interruptible,
|
|
235
|
+
env=self.env,
|
|
236
|
+
image_credentials=self.image_credentials,
|
|
237
|
+
cloud_account_auth=self.cloud_account_auth,
|
|
238
|
+
entrypoint=self.entrypoint,
|
|
239
|
+
path_mappings=self.path_mappings,
|
|
240
|
+
artifacts_local=None,
|
|
241
|
+
artifacts_remote=None,
|
|
242
|
+
max_runtime=self.max_runtime,
|
|
243
|
+
machine_image_version=machine_image_version,
|
|
244
|
+
reuse_snapshot=self.reuse_snapshot,
|
|
245
|
+
)
|
|
246
|
+
|
|
247
|
+
return V1PipelineStep(
|
|
248
|
+
name=self.name,
|
|
249
|
+
type=V1PipelineStepType.JOB,
|
|
250
|
+
wait_for=_to_wait_for(self.wait_for),
|
|
251
|
+
job=body,
|
|
252
|
+
)
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
class MMTStep:
|
|
256
|
+
# Note: This class is only temporary while pipeline is wip
|
|
257
|
+
|
|
258
|
+
def __init__(
|
|
259
|
+
self,
|
|
260
|
+
name: str,
|
|
261
|
+
machine: Union["Machine", str],
|
|
262
|
+
num_machines: Optional[int] = 2,
|
|
263
|
+
command: Optional[str] = None,
|
|
264
|
+
studio: Union["Studio", str, None] = None,
|
|
265
|
+
image: Optional[str] = None,
|
|
266
|
+
teamspace: Union[str, "Teamspace", None] = None,
|
|
267
|
+
org: Union[str, "Organization", None] = None,
|
|
268
|
+
user: Union[str, "User", None] = None,
|
|
269
|
+
cloud_account: Optional[str] = None,
|
|
270
|
+
env: Optional[Dict[str, str]] = None,
|
|
271
|
+
interruptible: bool = False,
|
|
272
|
+
image_credentials: Optional[str] = None,
|
|
273
|
+
cloud_account_auth: bool = False,
|
|
274
|
+
entrypoint: str = "sh -c",
|
|
275
|
+
path_mappings: Optional[Dict[str, str]] = None,
|
|
276
|
+
max_runtime: Optional[int] = None,
|
|
277
|
+
wait_for: Optional[Union[str, List[str]]] = DEFAULT,
|
|
278
|
+
reuse_snapshot: bool = True,
|
|
279
|
+
) -> None:
|
|
280
|
+
self.machine = machine or Machine.CPU
|
|
281
|
+
self.num_machines = num_machines
|
|
282
|
+
self.name = name
|
|
283
|
+
self.command = command
|
|
284
|
+
self.studio = _get_studio(studio)
|
|
285
|
+
|
|
286
|
+
if cloud_account and self.studio and cloud_account != self.studio.cloud_account != cloud_account:
|
|
287
|
+
raise ValueError(
|
|
288
|
+
f"The provided cloud account `{cloud_account}` doesn't match"
|
|
289
|
+
f" the Studio cloud account {self.studio.cloud_account}"
|
|
290
|
+
)
|
|
291
|
+
self.image = image
|
|
292
|
+
self.teamspace = teamspace
|
|
293
|
+
self.org = org
|
|
294
|
+
self.user = user
|
|
295
|
+
self.cloud_account = cloud_account or "" if self.studio is None else self.studio.cloud_account
|
|
296
|
+
self.env = env
|
|
297
|
+
self.interruptible = interruptible
|
|
298
|
+
self.image_credentials = image_credentials
|
|
299
|
+
self.cloud_account_auth = cloud_account_auth
|
|
300
|
+
self.entrypoint = entrypoint
|
|
301
|
+
self.path_mappings = path_mappings
|
|
302
|
+
self.max_runtime = max_runtime
|
|
303
|
+
self.wait_for = wait_for
|
|
304
|
+
self.reuse_snapshot = reuse_snapshot
|
|
305
|
+
|
|
306
|
+
def to_proto(
|
|
307
|
+
self, teamspace: "Teamspace", cloud_account: str, shared_filesystem: Union[bool, V1SharedFilesystem]
|
|
308
|
+
) -> V1PipelineStep:
|
|
309
|
+
machine_image_version = None
|
|
310
|
+
|
|
311
|
+
studio = _get_studio(self.studio)
|
|
312
|
+
if isinstance(studio, Studio):
|
|
313
|
+
machine_image_version = studio._studio.machine_image_version
|
|
314
|
+
|
|
315
|
+
if self.cloud_account is None:
|
|
316
|
+
self.cloud_account = studio.cloud_account
|
|
317
|
+
elif studio.cloud_account != self.cloud_account:
|
|
318
|
+
raise ValueError("The provided cloud account doesn't match the studio")
|
|
319
|
+
|
|
320
|
+
_validate_cloud_account(cloud_account, self.cloud_account, shared_filesystem)
|
|
321
|
+
|
|
322
|
+
body = MMTApiV2._create_mmt_body(
|
|
323
|
+
name=self.name,
|
|
324
|
+
num_machines=self.num_machines,
|
|
325
|
+
command=self.command,
|
|
326
|
+
cloud_account=self.cloud_account or cloud_account,
|
|
327
|
+
studio_id=studio._studio.id if isinstance(studio, Studio) else None,
|
|
328
|
+
image=self.image,
|
|
329
|
+
machine=self.machine,
|
|
330
|
+
interruptible=self.interruptible,
|
|
331
|
+
env=self.env,
|
|
332
|
+
image_credentials=self.image_credentials,
|
|
333
|
+
cloud_account_auth=self.cloud_account_auth,
|
|
334
|
+
entrypoint=self.entrypoint,
|
|
335
|
+
path_mappings=self.path_mappings,
|
|
336
|
+
artifacts_local=None, # deprecated in favor of path_mappings
|
|
337
|
+
artifacts_remote=None, # deprecated in favor of path_mappings
|
|
338
|
+
max_runtime=self.max_runtime,
|
|
339
|
+
machine_image_version=machine_image_version,
|
|
340
|
+
reuse_snapshot=self.reuse_snapshot,
|
|
341
|
+
)
|
|
342
|
+
|
|
343
|
+
return V1PipelineStep(
|
|
344
|
+
name=self.name,
|
|
345
|
+
type=V1PipelineStepType.MMT,
|
|
346
|
+
wait_for=_to_wait_for(self.wait_for),
|
|
347
|
+
mmt=body,
|
|
348
|
+
)
|
|
349
|
+
|
|
350
|
+
|
|
351
|
+
class DeploymentReleaseStep(DeploymentStep):
|
|
352
|
+
def __init__(self, *args: Any, deployment_name: Optional[str] = None, **kwargs: Any) -> None:
|
|
353
|
+
if not deployment_name:
|
|
354
|
+
raise ValueError("The deployment name is required")
|
|
355
|
+
self._deployment_name = deployment_name
|
|
356
|
+
super().__init__(*args, **kwargs)
|
|
357
|
+
|
|
358
|
+
def to_proto(self, *args: Any, **kwargs: Any) -> V1PipelineStep:
|
|
359
|
+
proto: V1PipelineStep = super().to_proto(*args, **kwargs)
|
|
360
|
+
proto.deployment.name = self._deployment_name
|
|
361
|
+
proto.deployment.pipeline_reuse_deployment_between_runs = True
|
|
362
|
+
return proto
|
|
363
|
+
|
|
364
|
+
|
|
365
|
+
__all__ = ["JobStep", "MMTStep", "DeploymentStep", "DeploymentReleaseStep"]
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
from typing import Any, List, Literal, Optional, Union
|
|
2
|
+
|
|
3
|
+
from lightning_sdk.lightning_cloud.openapi.models import (
|
|
4
|
+
V1JobSpec,
|
|
5
|
+
V1PipelineStep,
|
|
6
|
+
V1PipelineStepType,
|
|
7
|
+
V1SharedFilesystem,
|
|
8
|
+
)
|
|
9
|
+
from lightning_sdk.studio import Studio
|
|
10
|
+
|
|
11
|
+
DEFAULT = "DEFAULT"
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
def prepare_steps(steps: List["V1PipelineStep"]) -> List["V1PipelineStep"]:
|
|
15
|
+
"""The prepare_steps function is responsible for creating dependencies between steps.
|
|
16
|
+
|
|
17
|
+
The dependencies are based on whether a step wait_for to be executed before another.
|
|
18
|
+
"""
|
|
19
|
+
name_to_step = {}
|
|
20
|
+
name_to_idx = {}
|
|
21
|
+
|
|
22
|
+
for current_step_idx, current_step in enumerate(steps):
|
|
23
|
+
if current_step.name not in name_to_step:
|
|
24
|
+
name_to_step[current_step.name] = current_step
|
|
25
|
+
name_to_idx[current_step.name] = current_step_idx
|
|
26
|
+
else:
|
|
27
|
+
raise ValueError(f"A step with the name {current_step.name} already exists.")
|
|
28
|
+
|
|
29
|
+
if steps[0].wait_for not in [None, DEFAULT, []]:
|
|
30
|
+
raise ValueError("The first step isn't allowed to receive `wait_for=...`.")
|
|
31
|
+
|
|
32
|
+
steps[0].wait_for = []
|
|
33
|
+
|
|
34
|
+
# This implements a linear dependency between the steps as the default behaviour
|
|
35
|
+
for current_step_idx, current_step in reversed(list(enumerate(steps))):
|
|
36
|
+
if current_step_idx == 0:
|
|
37
|
+
continue
|
|
38
|
+
|
|
39
|
+
if current_step.wait_for == DEFAULT:
|
|
40
|
+
prev_step_idx = current_step_idx - 1
|
|
41
|
+
wait_for = []
|
|
42
|
+
while prev_step_idx > -1:
|
|
43
|
+
prev_step = steps[prev_step_idx]
|
|
44
|
+
wait_for.insert(0, steps[prev_step_idx].name)
|
|
45
|
+
if prev_step.wait_for != []:
|
|
46
|
+
break
|
|
47
|
+
prev_step_idx -= 1
|
|
48
|
+
current_step.wait_for = wait_for
|
|
49
|
+
else:
|
|
50
|
+
for name in current_step.wait_for:
|
|
51
|
+
if current_step.name == name:
|
|
52
|
+
raise ValueError(f"You can only reference prior steps. Found {current_step.name}")
|
|
53
|
+
|
|
54
|
+
if name not in name_to_step:
|
|
55
|
+
raise ValueError(f"The step {current_step_idx} doesn't have a valid wait_for. Found {name}")
|
|
56
|
+
|
|
57
|
+
if name_to_idx[name] >= name_to_idx[current_step.name]:
|
|
58
|
+
raise ValueError("You can only reference prior steps")
|
|
59
|
+
|
|
60
|
+
return steps
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
def _get_studio(studio: Union["Studio", str, None]) -> Union[Studio, None]:
|
|
64
|
+
if studio is None:
|
|
65
|
+
return None
|
|
66
|
+
|
|
67
|
+
if isinstance(studio, Studio):
|
|
68
|
+
return studio
|
|
69
|
+
|
|
70
|
+
return Studio(studio)
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
def _validate_cloud_account(
|
|
74
|
+
pipeline_cloud_account: str, step_cloud_account: str, shared_filesystem: Union[bool, V1SharedFilesystem]
|
|
75
|
+
) -> None:
|
|
76
|
+
shared_filesystem_enable = (
|
|
77
|
+
shared_filesystem.enabled if isinstance(shared_filesystem, V1SharedFilesystem) else shared_filesystem
|
|
78
|
+
)
|
|
79
|
+
if not shared_filesystem_enable:
|
|
80
|
+
return
|
|
81
|
+
|
|
82
|
+
if pipeline_cloud_account != "" and step_cloud_account != "" and pipeline_cloud_account != step_cloud_account:
|
|
83
|
+
raise ValueError(
|
|
84
|
+
"With shared filesystem enabled, all the pipeline steps requires to be on the same cluster."
|
|
85
|
+
f" Found {pipeline_cloud_account} and {step_cloud_account}"
|
|
86
|
+
)
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
def _to_wait_for(wait_for: Optional[Union[str, List[str]]]) -> Optional[Union[List[str], Literal["DEFAULT"]]]:
|
|
90
|
+
if wait_for == DEFAULT:
|
|
91
|
+
return wait_for
|
|
92
|
+
|
|
93
|
+
if wait_for is None:
|
|
94
|
+
return []
|
|
95
|
+
|
|
96
|
+
return wait_for if isinstance(wait_for, list) else [wait_for]
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
def _get_cloud_account(steps: List[V1PipelineStep]) -> Optional[str]:
|
|
100
|
+
if len(steps) == 0:
|
|
101
|
+
return None
|
|
102
|
+
|
|
103
|
+
cluster_ids: set[str] = set()
|
|
104
|
+
for step in steps:
|
|
105
|
+
job_spec = _get_spec(step)
|
|
106
|
+
cluster_ids.add(job_spec.cluster_id)
|
|
107
|
+
|
|
108
|
+
return sorted(cluster_ids)[0]
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
def _get_spec(step: Any) -> V1JobSpec:
|
|
112
|
+
if step.type == V1PipelineStepType.DEPLOYMENT:
|
|
113
|
+
return step.deployment.spec
|
|
114
|
+
if step.type == V1PipelineStepType.MMT:
|
|
115
|
+
return step.mmt.spec
|
|
116
|
+
return step.job.spec
|
lightning_sdk/plugin.py
CHANGED
|
@@ -9,6 +9,7 @@ from typing import TYPE_CHECKING, Any, Generator, Optional, Protocol, Union, run
|
|
|
9
9
|
from lightning_sdk.job import Job
|
|
10
10
|
from lightning_sdk.machine import Machine
|
|
11
11
|
from lightning_sdk.studio import Studio
|
|
12
|
+
from lightning_sdk.utils.logging import TrackCallsABCMeta
|
|
12
13
|
from lightning_sdk.utils.resolve import (
|
|
13
14
|
_LIGHTNING_SERVICE_EXECUTION_ID_KEY,
|
|
14
15
|
_resolve_deprecated_cloud_compute,
|
|
@@ -22,7 +23,7 @@ if TYPE_CHECKING:
|
|
|
22
23
|
_logger = _setup_logger(__name__)
|
|
23
24
|
|
|
24
25
|
|
|
25
|
-
class _Plugin(ABC):
|
|
26
|
+
class _Plugin(ABC, metaclass=TrackCallsABCMeta):
|
|
26
27
|
"""Abstract Plugin class defining the API.
|
|
27
28
|
|
|
28
29
|
Args:
|
|
@@ -128,6 +129,7 @@ class JobsPlugin(_Plugin):
|
|
|
128
129
|
machine: Machine = Machine.CPU,
|
|
129
130
|
cloud_compute: Optional[Machine] = None,
|
|
130
131
|
interruptible: bool = False,
|
|
132
|
+
reuse_snapshot: bool = True,
|
|
131
133
|
) -> Job:
|
|
132
134
|
"""Launches an asynchronous job.
|
|
133
135
|
|
|
@@ -137,6 +139,8 @@ class JobsPlugin(_Plugin):
|
|
|
137
139
|
machine: The machine to run the job on.
|
|
138
140
|
interruptible: Whether to run the job on an interruptible machine.
|
|
139
141
|
These are cheaper but can be preempted at any time.
|
|
142
|
+
reuse_snapshot: Whether the job should reuse a Studio snapshot when multiple jobs for the same Studio are
|
|
143
|
+
submitted. Turning this off may result in longer job startup times. Defaults to True.
|
|
140
144
|
"""
|
|
141
145
|
if not name:
|
|
142
146
|
name = _run_name("job")
|
|
@@ -151,6 +155,7 @@ class JobsPlugin(_Plugin):
|
|
|
151
155
|
teamspace=self._studio.teamspace,
|
|
152
156
|
cloud_account=self._studio.cloud_account,
|
|
153
157
|
interruptible=interruptible,
|
|
158
|
+
reuse_snapshot=reuse_snapshot,
|
|
154
159
|
)
|
|
155
160
|
|
|
156
161
|
|
|
@@ -186,16 +191,15 @@ class MultiMachineTrainingPlugin(_Plugin):
|
|
|
186
191
|
|
|
187
192
|
machine = _resolve_deprecated_cloud_compute(machine, cloud_compute)
|
|
188
193
|
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
)
|
|
194
|
+
return MMT.run(
|
|
195
|
+
name=name,
|
|
196
|
+
num_machines=num_instances,
|
|
197
|
+
machine=machine,
|
|
198
|
+
command=command,
|
|
199
|
+
studio=self._studio,
|
|
200
|
+
teamspace=self._studio.teamspace,
|
|
201
|
+
interruptible=interruptible,
|
|
202
|
+
)
|
|
199
203
|
|
|
200
204
|
|
|
201
205
|
class MultiMachineDataPrepPlugin(_Plugin):
|
|
@@ -304,7 +308,6 @@ class SlurmJobsPlugin(_Plugin):
|
|
|
304
308
|
name: Optional[str] = None,
|
|
305
309
|
cluster_id: Optional[str] = None,
|
|
306
310
|
work_dir: str = "/home/lightning_manager",
|
|
307
|
-
num_gpus: int = 1,
|
|
308
311
|
sync_env: bool = True,
|
|
309
312
|
cache_id: Optional[str] = None,
|
|
310
313
|
) -> "Externalv1LightningappInstance":
|
|
@@ -316,7 +319,6 @@ class SlurmJobsPlugin(_Plugin):
|
|
|
316
319
|
cluster_id: The name of the SLURM Cluster to submit the job on.
|
|
317
320
|
If the cluster_id isn't provided, the oldest running SLURM cluster will be selected.
|
|
318
321
|
work_dir: The position where the the files will be created on the SLURM cluster.
|
|
319
|
-
num_gpus: The number of GPUs requested.
|
|
320
322
|
sync_env: Whether to force an environement sync.
|
|
321
323
|
cache_id: A string to avoid re-downloading the Studio files to the SLURM cluster.
|
|
322
324
|
If you update your files and don't change the cache_id, they won't be used.
|
|
@@ -327,9 +329,6 @@ class SlurmJobsPlugin(_Plugin):
|
|
|
327
329
|
if work_dir == "":
|
|
328
330
|
raise ValueError("The argument `work_dir` needs to be a proper path on the SLURM Cluster.")
|
|
329
331
|
|
|
330
|
-
if num_gpus <= 0:
|
|
331
|
-
raise ValueError("The argument `num_gpus` needs to be strictly positive.")
|
|
332
|
-
|
|
333
332
|
if name is None:
|
|
334
333
|
name = _run_name("slurm")
|
|
335
334
|
|
|
@@ -393,7 +392,6 @@ class SlurmJobsPlugin(_Plugin):
|
|
|
393
392
|
sync_env=sync_env,
|
|
394
393
|
work_dir=work_dir,
|
|
395
394
|
service_id=service_id,
|
|
396
|
-
num_gpus=num_gpus,
|
|
397
395
|
cache_id=cache_id,
|
|
398
396
|
),
|
|
399
397
|
)
|
|
@@ -402,6 +400,25 @@ class SlurmJobsPlugin(_Plugin):
|
|
|
402
400
|
return resp
|
|
403
401
|
|
|
404
402
|
|
|
403
|
+
class CustomPortPlugin(_Plugin):
|
|
404
|
+
"""Plugin handling the port of a given service."""
|
|
405
|
+
|
|
406
|
+
_plugin_run_name = "Custom Port"
|
|
407
|
+
_slug_name = "custom-port"
|
|
408
|
+
|
|
409
|
+
def run(self, name: Optional[str] = None, port: int = 8000) -> str:
|
|
410
|
+
"""Starts a new port to the given Studio."""
|
|
411
|
+
if name is None:
|
|
412
|
+
name = _run_name("port")
|
|
413
|
+
|
|
414
|
+
return self._studio._studio_api.start_new_port(
|
|
415
|
+
teamspace_id=self._studio._teamspace.id,
|
|
416
|
+
studio_id=self._studio._studio.id,
|
|
417
|
+
name=name,
|
|
418
|
+
port=port,
|
|
419
|
+
)
|
|
420
|
+
|
|
421
|
+
|
|
405
422
|
@runtime_checkable
|
|
406
423
|
class _RunnablePlugin(Protocol):
|
|
407
424
|
_plugin_run_name: str
|
|
@@ -432,6 +449,8 @@ def _success_message(resp: Union["Externalv1LightningappInstance", Job], plugin_
|
|
|
432
449
|
def forced_v1(cls: Any) -> Generator[Any, None, None]:
|
|
433
450
|
"""Forces to use the v1 version of a class when using a class with multiple backends."""
|
|
434
451
|
orig_val = getattr(cls, "_force_v1", False)
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
452
|
+
try:
|
|
453
|
+
cls._force_v1 = True
|
|
454
|
+
yield cls
|
|
455
|
+
finally:
|
|
456
|
+
cls._force_v1 = orig_val
|