lightning-sdk 0.2.11__py3-none-any.whl → 0.2.13__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 (61) hide show
  1. lightning_sdk/__init__.py +1 -1
  2. lightning_sdk/api/deployment_api.py +35 -3
  3. lightning_sdk/api/lit_container_api.py +13 -7
  4. lightning_sdk/api/llm_api.py +46 -0
  5. lightning_sdk/api/studio_api.py +17 -0
  6. lightning_sdk/cli/entrypoint.py +1 -1
  7. lightning_sdk/cli/serve.py +221 -62
  8. lightning_sdk/deployment/deployment.py +53 -7
  9. lightning_sdk/lightning_cloud/openapi/__init__.py +11 -1
  10. lightning_sdk/lightning_cloud/openapi/api/__init__.py +1 -0
  11. lightning_sdk/lightning_cloud/openapi/api/cloud_space_environment_template_service_api.py +4 -4
  12. lightning_sdk/lightning_cloud/openapi/api/cluster_service_api.py +13 -1
  13. lightning_sdk/lightning_cloud/openapi/api/data_connection_service_api.py +4 -4
  14. lightning_sdk/lightning_cloud/openapi/api/git_credentials_service_api.py +497 -0
  15. lightning_sdk/lightning_cloud/openapi/api/jobs_service_api.py +124 -0
  16. lightning_sdk/lightning_cloud/openapi/models/__init__.py +10 -1
  17. lightning_sdk/lightning_cloud/openapi/models/assistant_id_conversations_body.py +27 -1
  18. lightning_sdk/lightning_cloud/openapi/models/create_deployment_request_defines_a_spec_for_the_job_that_allows_for_autoscaling_jobs.py +27 -1
  19. lightning_sdk/lightning_cloud/openapi/models/deployments_id_body.py +27 -1
  20. lightning_sdk/lightning_cloud/openapi/models/orgs_id_body.py +27 -1
  21. lightning_sdk/lightning_cloud/openapi/models/projects_id_body.py +27 -1
  22. lightning_sdk/lightning_cloud/openapi/models/update.py +65 -195
  23. lightning_sdk/lightning_cloud/openapi/models/update1.py +357 -0
  24. lightning_sdk/lightning_cloud/openapi/models/v1_cloud_provider.py +1 -0
  25. lightning_sdk/lightning_cloud/openapi/models/v1_cloud_space_environment_template.py +27 -1
  26. lightning_sdk/lightning_cloud/openapi/models/v1_cluster_accelerator.py +27 -1
  27. lightning_sdk/lightning_cloud/openapi/models/v1_cluster_security_options.py +27 -1
  28. lightning_sdk/lightning_cloud/openapi/models/v1_cluster_spec.py +79 -1
  29. lightning_sdk/lightning_cloud/openapi/models/v1_create_deployment_request.py +27 -1
  30. lightning_sdk/lightning_cloud/openapi/models/v1_create_git_credentials_request.py +175 -0
  31. lightning_sdk/lightning_cloud/openapi/models/v1_delete_cloud_space_environment_template_response.py +1 -53
  32. lightning_sdk/lightning_cloud/openapi/models/v1_delete_git_credentials_response.py +97 -0
  33. lightning_sdk/lightning_cloud/openapi/models/v1_deployment.py +27 -1
  34. lightning_sdk/lightning_cloud/openapi/models/v1_deployment_state.py +2 -0
  35. lightning_sdk/lightning_cloud/openapi/models/v1_get_user_response.py +1 -27
  36. lightning_sdk/lightning_cloud/openapi/models/v1_git_credentials.py +227 -0
  37. lightning_sdk/lightning_cloud/openapi/models/v1_job_resource.py +279 -0
  38. lightning_sdk/lightning_cloud/openapi/models/v1_job_type.py +108 -0
  39. lightning_sdk/lightning_cloud/openapi/models/v1_list_git_credentials_response.py +123 -0
  40. lightning_sdk/lightning_cloud/openapi/models/v1_list_job_resources_response.py +123 -0
  41. lightning_sdk/lightning_cloud/openapi/models/v1_nebius_direct_v1.py +149 -0
  42. lightning_sdk/lightning_cloud/openapi/models/v1_organization.py +55 -1
  43. lightning_sdk/lightning_cloud/openapi/models/v1_project_settings.py +29 -1
  44. lightning_sdk/lightning_cloud/openapi/models/v1_reservation_billing_session.py +279 -0
  45. lightning_sdk/lightning_cloud/openapi/models/v1_resources.py +55 -3
  46. lightning_sdk/lightning_cloud/openapi/models/v1_update_user_request.py +1 -27
  47. lightning_sdk/lightning_cloud/openapi/models/v1_usage.py +27 -1
  48. lightning_sdk/lightning_cloud/openapi/models/v1_user_features.py +157 -1
  49. lightning_sdk/llm/__init__.py +3 -0
  50. lightning_sdk/llm/llm.py +118 -0
  51. lightning_sdk/plugin.py +19 -0
  52. lightning_sdk/serve.py +4 -6
  53. lightning_sdk/studio.py +33 -0
  54. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/METADATA +1 -1
  55. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/RECORD +60 -47
  56. lightning_sdk/lightning_cloud/openapi/models/environmenttemplates_id_body.py +0 -253
  57. /lightning_sdk/cli/{docker.py → docker_cli.py} +0 -0
  58. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/LICENSE +0 -0
  59. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/WHEEL +0 -0
  60. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/entry_points.txt +0 -0
  61. {lightning_sdk-0.2.11.dist-info → lightning_sdk-0.2.13.dist-info}/top_level.txt +0 -0
@@ -1,4 +1,5 @@
1
1
  import os
2
+ from datetime import datetime
2
3
  from typing import Any, Dict, List, Optional, Union
3
4
 
4
5
  import requests
@@ -15,6 +16,7 @@ from lightning_sdk.api.deployment_api import (
15
16
  ReleaseStrategy,
16
17
  Secret,
17
18
  TokenAuth,
19
+ compose_commands,
18
20
  restore_auth,
19
21
  restore_autoscale,
20
22
  restore_env,
@@ -30,6 +32,7 @@ from lightning_sdk.lightning_cloud.openapi import V1Deployment
30
32
  from lightning_sdk.machine import Machine
31
33
  from lightning_sdk.organization import Organization
32
34
  from lightning_sdk.services.utilities import _get_cluster
35
+ from lightning_sdk.studio import Studio
33
36
  from lightning_sdk.teamspace import Teamspace
34
37
  from lightning_sdk.user import User
35
38
  from lightning_sdk.utils.resolve import _resolve_deprecated_cluster, _resolve_org, _resolve_teamspace, _resolve_user
@@ -55,7 +58,7 @@ class Deployment:
55
58
 
56
59
  def __init__(
57
60
  self,
58
- name: str,
61
+ name: Optional[str] = None,
59
62
  teamspace: Optional[Union[str, Teamspace]] = None,
60
63
  org: Optional[Union[str, Organization]] = None,
61
64
  user: Optional[Union[str, User]] = None,
@@ -72,6 +75,9 @@ class Deployment:
72
75
  except ConnectionError as e:
73
76
  raise e
74
77
 
78
+ if name is None:
79
+ name = "dep_" + datetime.now().strftime("%m-%d_%H:%M:%S")
80
+
75
81
  self._name = name
76
82
  self._user = _resolve_user(self._user or user)
77
83
  self._org = _resolve_org(org)
@@ -102,13 +108,15 @@ class Deployment:
102
108
 
103
109
  def start(
104
110
  self,
111
+ studio: Optional[Union[str, Studio]] = None,
105
112
  machine: Optional[Machine] = None,
106
113
  image: Optional[str] = None,
107
114
  autoscale: Optional[AutoScaleConfig] = None,
108
- ports: Optional[List[float]] = None,
115
+ ports: Optional[Union[float, List[float]]] = None,
109
116
  release_strategy: Optional[ReleaseStrategy] = None,
110
117
  entrypoint: Optional[str] = None,
111
118
  command: Optional[str] = None,
119
+ commands: Optional[List[str]] = None,
112
120
  env: Union[List[Union[Secret, Env]], Dict[str, str], None] = None,
113
121
  spot: Optional[bool] = None,
114
122
  replicas: Optional[int] = None,
@@ -157,12 +165,45 @@ class Deployment:
157
165
  if self._is_created:
158
166
  raise RuntimeError("This deployment has already been started.")
159
167
 
160
- cloud_account = _resolve_deprecated_cluster(cloud_account, cluster)
168
+ if isinstance(studio, Studio):
169
+ cloudspace_id = studio._studio.id
170
+ cloud_account = studio._studio.cluster_id
171
+
172
+ if isinstance(studio, str):
173
+ studio = Studio(studio)
174
+ cloudspace_id = studio._studio.id
175
+ cloud_account = studio._studio.cluster_id
176
+
177
+ if cloud_account is None:
178
+ cloud_account = _resolve_deprecated_cluster(cloud_account, cluster)
161
179
 
162
180
  if cloud_account is None and self._cloud_account is not None:
163
181
  print(f"No cloud account was provided, defaulting to {self._cloud_account.cluster_id}")
164
182
  cloud_account = os.getenv("LIGHTNING_CLUSTER_ID") or self._cloud_account.cluster_id
165
183
 
184
+ if isinstance(ports, float):
185
+ ports = [ports]
186
+
187
+ if replicas is None and autoscale is None:
188
+ replicas = 1
189
+
190
+ if machine is None:
191
+ machine = Machine.CPU
192
+
193
+ if commands is not None and command is not None:
194
+ raise ValueError("Commands and command are mutually exclusive")
195
+
196
+ if commands is not None:
197
+ command = compose_commands(commands)
198
+
199
+ if autoscale is None:
200
+ autoscale = AutoScaleConfig(
201
+ min_replicas=0,
202
+ max_replicas=1,
203
+ metric="CPU" if machine.is_cpu() else "GPU",
204
+ threshold=90,
205
+ )
206
+
166
207
  self._deployment = self._deployment_api.create_deployment(
167
208
  V1Deployment(
168
209
  autoscaling=to_autoscaling(autoscale, replicas),
@@ -182,6 +223,7 @@ class Deployment:
182
223
  health_check=health_check,
183
224
  quantity=quantity,
184
225
  include_credentials=include_credentials if include_credentials is not None else True,
226
+ cloudspace_id=cloudspace_id,
185
227
  ),
186
228
  strategy=to_strategy(release_strategy),
187
229
  ),
@@ -199,6 +241,7 @@ class Deployment:
199
241
  image: Optional[str] = None,
200
242
  entrypoint: Optional[str] = None,
201
243
  command: Optional[str] = None,
244
+ commands: Optional[List[str]] = None,
202
245
  env: Optional[List[Union[Env, Secret]]] = None,
203
246
  spot: Optional[bool] = None,
204
247
  cloud_account: Optional[str] = None,
@@ -218,6 +261,9 @@ class Deployment:
218
261
  ) -> None:
219
262
  cloud_account = _resolve_deprecated_cluster(cloud_account, cluster)
220
263
 
264
+ if command is None and commands is not None:
265
+ command = compose_commands(commands)
266
+
221
267
  self._deployment = self._deployment_api.update_deployment(
222
268
  self._deployment,
223
269
  name=name or self._name,
@@ -228,8 +274,8 @@ class Deployment:
228
274
  cloud_account=cloud_account,
229
275
  machine=machine,
230
276
  image=image,
231
- entrypoint=entrypoint,
232
- command=command,
277
+ entrypoint=entrypoint or "",
278
+ command=command or "",
233
279
  ports=ports,
234
280
  custom_domain=custom_domain,
235
281
  auth=auth,
@@ -237,7 +283,7 @@ class Deployment:
237
283
  health_check=health_check,
238
284
  release_strategy=release_strategy,
239
285
  quantity=quantity,
240
- include_credentials=include_credentials if include_credentials is not None else True,
286
+ include_credentials=include_credentials,
241
287
  )
242
288
 
243
289
  def stop(self) -> None:
@@ -316,7 +362,7 @@ class Deployment:
316
362
  return None
317
363
 
318
364
  @property
319
- def env(self) -> Optional[AutoScaleConfig]:
365
+ def env(self) -> Optional[List[Union[Secret, Env]]]:
320
366
  """The env configuration of the deployment."""
321
367
  if self._deployment:
322
368
  self._deployment = self._deployment_api.get_deployment_by_name(self._name, self._teamspace.id)
@@ -36,6 +36,7 @@ from lightning_sdk.lightning_cloud.openapi.api.deployment_templates_service_api
36
36
  from lightning_sdk.lightning_cloud.openapi.api.endpoint_service_api import EndpointServiceApi
37
37
  from lightning_sdk.lightning_cloud.openapi.api.experiments_service_api import ExperimentsServiceApi
38
38
  from lightning_sdk.lightning_cloud.openapi.api.file_system_service_api import FileSystemServiceApi
39
+ from lightning_sdk.lightning_cloud.openapi.api.git_credentials_service_api import GitCredentialsServiceApi
39
40
  from lightning_sdk.lightning_cloud.openapi.api.jobs_service_api import JobsServiceApi
40
41
  from lightning_sdk.lightning_cloud.openapi.api.lightningapp_instance_service_api import LightningappInstanceServiceApi
41
42
  from lightning_sdk.lightning_cloud.openapi.api.lightningapp_v2_service_api import LightningappV2ServiceApi
@@ -104,7 +105,6 @@ from lightning_sdk.lightning_cloud.openapi.models.datasets_id_body import Datase
104
105
  from lightning_sdk.lightning_cloud.openapi.models.deployments_id_body import DeploymentsIdBody
105
106
  from lightning_sdk.lightning_cloud.openapi.models.deploymenttemplates_id_body import DeploymenttemplatesIdBody
106
107
  from lightning_sdk.lightning_cloud.openapi.models.endpoints_id_body import EndpointsIdBody
107
- from lightning_sdk.lightning_cloud.openapi.models.environmenttemplates_id_body import EnvironmenttemplatesIdBody
108
108
  from lightning_sdk.lightning_cloud.openapi.models.experiment_name_variant_name_body import ExperimentNameVariantNameBody
109
109
  from lightning_sdk.lightning_cloud.openapi.models.externalv1_cloud_space_instance_status import Externalv1CloudSpaceInstanceStatus
110
110
  from lightning_sdk.lightning_cloud.openapi.models.externalv1_cluster import Externalv1Cluster
@@ -214,6 +214,7 @@ from lightning_sdk.lightning_cloud.openapi.models.stream_result_of_v1_conversati
214
214
  from lightning_sdk.lightning_cloud.openapi.models.stream_result_of_v1_get_long_running_command_in_cloud_space_response import StreamResultOfV1GetLongRunningCommandInCloudSpaceResponse
215
215
  from lightning_sdk.lightning_cloud.openapi.models.studioapp_jobs_body import StudioappJobsBody
216
216
  from lightning_sdk.lightning_cloud.openapi.models.update import Update
217
+ from lightning_sdk.lightning_cloud.openapi.models.update1 import Update1
217
218
  from lightning_sdk.lightning_cloud.openapi.models.upload_id_complete_body import UploadIdCompleteBody
218
219
  from lightning_sdk.lightning_cloud.openapi.models.upload_id_complete_body1 import UploadIdCompleteBody1
219
220
  from lightning_sdk.lightning_cloud.openapi.models.upload_id_parts_body import UploadIdPartsBody
@@ -345,6 +346,7 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_create_cluster_request impo
345
346
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_cluster_response import V1CreateClusterResponse
346
347
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_deployment_request import V1CreateDeploymentRequest
347
348
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_deployment_template_request import V1CreateDeploymentTemplateRequest
349
+ from lightning_sdk.lightning_cloud.openapi.models.v1_create_git_credentials_request import V1CreateGitCredentialsRequest
348
350
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_job_request import V1CreateJobRequest
349
351
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_lit_dataset_multi_part_upload_response import V1CreateLitDatasetMultiPartUploadResponse
350
352
  from lightning_sdk.lightning_cloud.openapi.models.v1_create_lit_page_request import V1CreateLitPageRequest
@@ -391,6 +393,7 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_delete_deployment_release_r
391
393
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_deployment_response import V1DeleteDeploymentResponse
392
394
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_endpoint_response import V1DeleteEndpointResponse
393
395
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_file_endpoint_response import V1DeleteFileEndpointResponse
396
+ from lightning_sdk.lightning_cloud.openapi.models.v1_delete_git_credentials_response import V1DeleteGitCredentialsResponse
394
397
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_index_response import V1DeleteIndexResponse
395
398
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_job_response import V1DeleteJobResponse
396
399
  from lightning_sdk.lightning_cloud.openapi.models.v1_delete_lightning_run_response import V1DeleteLightningRunResponse
@@ -534,6 +537,7 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_get_user_notification_prefe
534
537
  from lightning_sdk.lightning_cloud.openapi.models.v1_get_user_response import V1GetUserResponse
535
538
  from lightning_sdk.lightning_cloud.openapi.models.v1_get_user_storage_breakdown_response import V1GetUserStorageBreakdownResponse
536
539
  from lightning_sdk.lightning_cloud.openapi.models.v1_get_user_storage_response import V1GetUserStorageResponse
540
+ from lightning_sdk.lightning_cloud.openapi.models.v1_git_credentials import V1GitCredentials
537
541
  from lightning_sdk.lightning_cloud.openapi.models.v1_google_cloud_direct_v1 import V1GoogleCloudDirectV1
538
542
  from lightning_sdk.lightning_cloud.openapi.models.v1_google_cloud_direct_v1_status import V1GoogleCloudDirectV1Status
539
543
  from lightning_sdk.lightning_cloud.openapi.models.v1_header import V1Header
@@ -556,8 +560,10 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_job_health_check_config imp
556
560
  from lightning_sdk.lightning_cloud.openapi.models.v1_job_log_entry import V1JobLogEntry
557
561
  from lightning_sdk.lightning_cloud.openapi.models.v1_job_logs_page import V1JobLogsPage
558
562
  from lightning_sdk.lightning_cloud.openapi.models.v1_job_logs_response import V1JobLogsResponse
563
+ from lightning_sdk.lightning_cloud.openapi.models.v1_job_resource import V1JobResource
559
564
  from lightning_sdk.lightning_cloud.openapi.models.v1_job_spec import V1JobSpec
560
565
  from lightning_sdk.lightning_cloud.openapi.models.v1_job_timing import V1JobTiming
566
+ from lightning_sdk.lightning_cloud.openapi.models.v1_job_type import V1JobType
561
567
  from lightning_sdk.lightning_cloud.openapi.models.v1_joinable_organization import V1JoinableOrganization
562
568
  from lightning_sdk.lightning_cloud.openapi.models.v1_keep_alive_cloud_space_instance_response import V1KeepAliveCloudSpaceInstanceResponse
563
569
  from lightning_sdk.lightning_cloud.openapi.models.v1_knowledge_configuration import V1KnowledgeConfiguration
@@ -623,7 +629,9 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_list_filesystem_slurm_jobs_
623
629
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_filesystem_snowflake_response import V1ListFilesystemSnowflakeResponse
624
630
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_gallery_components_response import V1ListGalleryComponentsResponse
625
631
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_gallery_lightningapps_response import V1ListGalleryLightningappsResponse
632
+ from lightning_sdk.lightning_cloud.openapi.models.v1_list_git_credentials_response import V1ListGitCredentialsResponse
626
633
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_job_files_response import V1ListJobFilesResponse
634
+ from lightning_sdk.lightning_cloud.openapi.models.v1_list_job_resources_response import V1ListJobResourcesResponse
627
635
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_jobs_response import V1ListJobsResponse
628
636
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_joinable_organizations_response import V1ListJoinableOrganizationsResponse
629
637
  from lightning_sdk.lightning_cloud.openapi.models.v1_list_lightning_run_response import V1ListLightningRunResponse
@@ -717,6 +725,7 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_multi_machine_job_fault_tol
717
725
  from lightning_sdk.lightning_cloud.openapi.models.v1_multi_machine_job_state import V1MultiMachineJobState
718
726
  from lightning_sdk.lightning_cloud.openapi.models.v1_multi_machine_job_status import V1MultiMachineJobStatus
719
727
  from lightning_sdk.lightning_cloud.openapi.models.v1_named_get_logger_metrics import V1NamedGetLoggerMetrics
728
+ from lightning_sdk.lightning_cloud.openapi.models.v1_nebius_direct_v1 import V1NebiusDirectV1
720
729
  from lightning_sdk.lightning_cloud.openapi.models.v1_network_config import V1NetworkConfig
721
730
  from lightning_sdk.lightning_cloud.openapi.models.v1_new_feature import V1NewFeature
722
731
  from lightning_sdk.lightning_cloud.openapi.models.v1_notification_preference import V1NotificationPreference
@@ -788,6 +797,7 @@ from lightning_sdk.lightning_cloud.openapi.models.v1_report_restart_timings_resp
788
797
  from lightning_sdk.lightning_cloud.openapi.models.v1_request_cluster_access_request import V1RequestClusterAccessRequest
789
798
  from lightning_sdk.lightning_cloud.openapi.models.v1_request_cluster_access_response import V1RequestClusterAccessResponse
790
799
  from lightning_sdk.lightning_cloud.openapi.models.v1_request_verification_code_response import V1RequestVerificationCodeResponse
800
+ from lightning_sdk.lightning_cloud.openapi.models.v1_reservation_billing_session import V1ReservationBillingSession
791
801
  from lightning_sdk.lightning_cloud.openapi.models.v1_reservation_details import V1ReservationDetails
792
802
  from lightning_sdk.lightning_cloud.openapi.models.v1_resource_tag import V1ResourceTag
793
803
  from lightning_sdk.lightning_cloud.openapi.models.v1_resource_visibility import V1ResourceVisibility
@@ -17,6 +17,7 @@ from lightning_sdk.lightning_cloud.openapi.api.deployment_templates_service_api
17
17
  from lightning_sdk.lightning_cloud.openapi.api.endpoint_service_api import EndpointServiceApi
18
18
  from lightning_sdk.lightning_cloud.openapi.api.experiments_service_api import ExperimentsServiceApi
19
19
  from lightning_sdk.lightning_cloud.openapi.api.file_system_service_api import FileSystemServiceApi
20
+ from lightning_sdk.lightning_cloud.openapi.api.git_credentials_service_api import GitCredentialsServiceApi
20
21
  from lightning_sdk.lightning_cloud.openapi.api.jobs_service_api import JobsServiceApi
21
22
  from lightning_sdk.lightning_cloud.openapi.api.lightningapp_instance_service_api import LightningappInstanceServiceApi
22
23
  from lightning_sdk.lightning_cloud.openapi.api.lightningapp_v2_service_api import LightningappV2ServiceApi
@@ -431,7 +431,7 @@ class CloudSpaceEnvironmentTemplateServiceApi(object):
431
431
  _request_timeout=params.get('_request_timeout'),
432
432
  collection_formats=collection_formats)
433
433
 
434
- def cloud_space_environment_template_service_update_cloud_space_environment_template(self, body: 'EnvironmenttemplatesIdBody', id: 'str', **kwargs) -> 'V1CloudSpaceEnvironmentTemplate': # noqa: E501
434
+ def cloud_space_environment_template_service_update_cloud_space_environment_template(self, body: 'Update', id: 'str', **kwargs) -> 'V1CloudSpaceEnvironmentTemplate': # noqa: E501
435
435
  """cloud_space_environment_template_service_update_cloud_space_environment_template # noqa: E501
436
436
 
437
437
  This method makes a synchronous HTTP request by default. To make an
@@ -440,7 +440,7 @@ class CloudSpaceEnvironmentTemplateServiceApi(object):
440
440
  >>> result = thread.get()
441
441
 
442
442
  :param async_req bool
443
- :param EnvironmenttemplatesIdBody body: (required)
443
+ :param Update body: (required)
444
444
  :param str id: (required)
445
445
  :return: V1CloudSpaceEnvironmentTemplate
446
446
  If the method is called asynchronously,
@@ -453,7 +453,7 @@ class CloudSpaceEnvironmentTemplateServiceApi(object):
453
453
  (data) = self.cloud_space_environment_template_service_update_cloud_space_environment_template_with_http_info(body, id, **kwargs) # noqa: E501
454
454
  return data
455
455
 
456
- def cloud_space_environment_template_service_update_cloud_space_environment_template_with_http_info(self, body: 'EnvironmenttemplatesIdBody', id: 'str', **kwargs) -> 'V1CloudSpaceEnvironmentTemplate': # noqa: E501
456
+ def cloud_space_environment_template_service_update_cloud_space_environment_template_with_http_info(self, body: 'Update', id: 'str', **kwargs) -> 'V1CloudSpaceEnvironmentTemplate': # noqa: E501
457
457
  """cloud_space_environment_template_service_update_cloud_space_environment_template # noqa: E501
458
458
 
459
459
  This method makes a synchronous HTTP request by default. To make an
@@ -462,7 +462,7 @@ class CloudSpaceEnvironmentTemplateServiceApi(object):
462
462
  >>> result = thread.get()
463
463
 
464
464
  :param async_req bool
465
- :param EnvironmenttemplatesIdBody body: (required)
465
+ :param Update body: (required)
466
466
  :param str id: (required)
467
467
  :return: V1CloudSpaceEnvironmentTemplate
468
468
  If the method is called asynchronously,
@@ -2328,6 +2328,9 @@ class ClusterServiceApi(object):
2328
2328
  :param async_req bool
2329
2329
  :param str project_id: (required)
2330
2330
  :param str cluster_id: (required)
2331
+ :param datetime start_time:
2332
+ :param datetime end_time:
2333
+ :param bool available_only:
2331
2334
  :return: V1ListClusterCapacityReservationsResponse
2332
2335
  If the method is called asynchronously,
2333
2336
  returns the request thread.
@@ -2350,12 +2353,15 @@ class ClusterServiceApi(object):
2350
2353
  :param async_req bool
2351
2354
  :param str project_id: (required)
2352
2355
  :param str cluster_id: (required)
2356
+ :param datetime start_time:
2357
+ :param datetime end_time:
2358
+ :param bool available_only:
2353
2359
  :return: V1ListClusterCapacityReservationsResponse
2354
2360
  If the method is called asynchronously,
2355
2361
  returns the request thread.
2356
2362
  """
2357
2363
 
2358
- all_params = ['project_id', 'cluster_id'] # noqa: E501
2364
+ all_params = ['project_id', 'cluster_id', 'start_time', 'end_time', 'available_only'] # noqa: E501
2359
2365
  all_params.append('async_req')
2360
2366
  all_params.append('_return_http_data_only')
2361
2367
  all_params.append('_preload_content')
@@ -2388,6 +2394,12 @@ class ClusterServiceApi(object):
2388
2394
  path_params['clusterId'] = params['cluster_id'] # noqa: E501
2389
2395
 
2390
2396
  query_params = []
2397
+ if 'start_time' in params:
2398
+ query_params.append(('startTime', params['start_time'])) # noqa: E501
2399
+ if 'end_time' in params:
2400
+ query_params.append(('endTime', params['end_time'])) # noqa: E501
2401
+ if 'available_only' in params:
2402
+ query_params.append(('availableOnly', params['available_only'])) # noqa: E501
2391
2403
 
2392
2404
  header_params = {}
2393
2405
 
@@ -1025,7 +1025,7 @@ class DataConnectionServiceApi(object):
1025
1025
  _request_timeout=params.get('_request_timeout'),
1026
1026
  collection_formats=collection_formats)
1027
1027
 
1028
- def data_connection_service_update_data_connection(self, body: 'Update', project_id: 'str', id: 'str', **kwargs) -> 'V1DataConnection': # noqa: E501
1028
+ def data_connection_service_update_data_connection(self, body: 'Update1', project_id: 'str', id: 'str', **kwargs) -> 'V1DataConnection': # noqa: E501
1029
1029
  """data_connection_service_update_data_connection # noqa: E501
1030
1030
 
1031
1031
  This method makes a synchronous HTTP request by default. To make an
@@ -1034,7 +1034,7 @@ class DataConnectionServiceApi(object):
1034
1034
  >>> result = thread.get()
1035
1035
 
1036
1036
  :param async_req bool
1037
- :param Update body: (required)
1037
+ :param Update1 body: (required)
1038
1038
  :param str project_id: (required)
1039
1039
  :param str id: (required)
1040
1040
  :return: V1DataConnection
@@ -1048,7 +1048,7 @@ class DataConnectionServiceApi(object):
1048
1048
  (data) = self.data_connection_service_update_data_connection_with_http_info(body, project_id, id, **kwargs) # noqa: E501
1049
1049
  return data
1050
1050
 
1051
- def data_connection_service_update_data_connection_with_http_info(self, body: 'Update', project_id: 'str', id: 'str', **kwargs) -> 'V1DataConnection': # noqa: E501
1051
+ def data_connection_service_update_data_connection_with_http_info(self, body: 'Update1', project_id: 'str', id: 'str', **kwargs) -> 'V1DataConnection': # noqa: E501
1052
1052
  """data_connection_service_update_data_connection # noqa: E501
1053
1053
 
1054
1054
  This method makes a synchronous HTTP request by default. To make an
@@ -1057,7 +1057,7 @@ class DataConnectionServiceApi(object):
1057
1057
  >>> result = thread.get()
1058
1058
 
1059
1059
  :param async_req bool
1060
- :param Update body: (required)
1060
+ :param Update1 body: (required)
1061
1061
  :param str project_id: (required)
1062
1062
  :param str id: (required)
1063
1063
  :return: V1DataConnection