From 34c0a9f27d36be9e773a9d6e19a6164a1117d2e8 Mon Sep 17 00:00:00 2001 From: stackit-pipeline <142982727+stackit-pipeline@users.noreply.github.com> Date: Thu, 6 Feb 2025 09:42:22 +0100 Subject: [PATCH] Generator: Update SDK /services/serverupdate (#637) * Generate serverupdate * Add changelog Signed-off-by: Alexander Dahmen --------- Signed-off-by: Alexander Dahmen Co-authored-by: Alexander Dahmen --- CHANGELOG.md | 3 + services/serverupdate/CHANGELOG.md | 5 + services/serverupdate/pyproject.toml | 2 +- .../src/stackit/serverupdate/__init__.py | 7 +- .../stackit/serverupdate/api/default_api.py | 250 ++++++++++++++++++ .../stackit/serverupdate/models/__init__.py | 7 +- .../models/create_update_payload.py | 18 +- .../models/create_update_schedule_payload.py | 6 +- .../models/get_update_service_response.py | 82 ++++++ .../serverupdate/models/update_schedule.py | 6 +- ...s.py => update_schedule_create_request.py} | 28 +- .../models/update_update_schedule_payload.py | 6 +- 12 files changed, 378 insertions(+), 42 deletions(-) create mode 100644 services/serverupdate/src/stackit/serverupdate/models/get_update_service_response.py rename services/serverupdate/src/stackit/serverupdate/models/{backup_properties.py => update_schedule_create_request.py} (72%) diff --git a/CHANGELOG.md b/CHANGELOG.md index bcc00d52..0c67eab0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,8 @@ ## Release (2025-XX-XX) +- `serverupdate`: [v0.3.0](services/serverupdate/CHANGELOG.md#v030-2025-02-06) + - **Breaking Change:**: Remove field `BackupProperties` from `CreateUpdatePayload` model + - **Fix**: Remove field `Id` from `CreateUpdateSchedulePayload` model - `authorization`: [v0.2.2](services/authorization/CHANGELOG.md#v022-2025-01-21) - **Bugfix:** Revert back to global URL configuration - `sqlserverflex`: [v0.3.0](services/sqlserverflex/CHANGELOG.md#v030-2025-01-21) diff --git a/services/serverupdate/CHANGELOG.md b/services/serverupdate/CHANGELOG.md index ef500818..6bf1c4ea 100644 --- a/services/serverupdate/CHANGELOG.md +++ b/services/serverupdate/CHANGELOG.md @@ -1,3 +1,8 @@ +## v0.3.0 (2025-02-06) + +- **Breaking Change:**: Remove field `BackupProperties` from `CreateUpdatePayload` model +- **Fix**: Remove field `Id` from `CreateUpdateSchedulePayload` model + ## v0.2.0 (2025-01-13) - **Breaking Change:**: `get_host_from_settings` returns an error if a region is specified for a global URL. diff --git a/services/serverupdate/pyproject.toml b/services/serverupdate/pyproject.toml index bf5d61bd..6f3c40f9 100644 --- a/services/serverupdate/pyproject.toml +++ b/services/serverupdate/pyproject.toml @@ -3,7 +3,7 @@ name = "stackit-serverupdate" [tool.poetry] name = "stackit-serverupdate" -version = "v0.2.0" +version = "v0.3.0" authors = [ "STACKIT Developer Tools ", ] diff --git a/services/serverupdate/src/stackit/serverupdate/__init__.py b/services/serverupdate/src/stackit/serverupdate/__init__.py index 195a5ada..0522cf5c 100644 --- a/services/serverupdate/src/stackit/serverupdate/__init__.py +++ b/services/serverupdate/src/stackit/serverupdate/__init__.py @@ -34,7 +34,6 @@ ) # import models into sdk package -from stackit.serverupdate.models.backup_properties import BackupProperties from stackit.serverupdate.models.create_update_payload import CreateUpdatePayload from stackit.serverupdate.models.create_update_schedule_payload import ( CreateUpdateSchedulePayload, @@ -49,10 +48,16 @@ from stackit.serverupdate.models.get_update_schedules_response import ( GetUpdateSchedulesResponse, ) +from stackit.serverupdate.models.get_update_service_response import ( + GetUpdateServiceResponse, +) from stackit.serverupdate.models.get_updates_list_response import GetUpdatesListResponse from stackit.serverupdate.models.update import Update from stackit.serverupdate.models.update_policy import UpdatePolicy from stackit.serverupdate.models.update_schedule import UpdateSchedule +from stackit.serverupdate.models.update_schedule_create_request import ( + UpdateScheduleCreateRequest, +) from stackit.serverupdate.models.update_update_schedule_payload import ( UpdateUpdateSchedulePayload, ) diff --git a/services/serverupdate/src/stackit/serverupdate/api/default_api.py b/services/serverupdate/src/stackit/serverupdate/api/default_api.py index 1f3afd03..1da71a00 100644 --- a/services/serverupdate/src/stackit/serverupdate/api/default_api.py +++ b/services/serverupdate/src/stackit/serverupdate/api/default_api.py @@ -35,6 +35,9 @@ from stackit.serverupdate.models.get_update_schedules_response import ( GetUpdateSchedulesResponse, ) +from stackit.serverupdate.models.get_update_service_response import ( + GetUpdateServiceResponse, +) from stackit.serverupdate.models.get_updates_list_response import GetUpdatesListResponse from stackit.serverupdate.models.update import Update from stackit.serverupdate.models.update_schedule import UpdateSchedule @@ -1879,6 +1882,253 @@ def _enable_service_resource_serialize( _request_auth=_request_auth, ) + @validate_call + def get_service_resource( + self, + project_id: Annotated[StrictStr, Field(description="project id")], + server_id: Annotated[StrictStr, Field(description="server id")], + _request_timeout: Union[ + None, + Annotated[StrictFloat, Field(gt=0)], + Tuple[Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]], + ] = None, + _request_auth: Optional[Dict[StrictStr, Any]] = None, + _content_type: Optional[StrictStr] = None, + _headers: Optional[Dict[StrictStr, Any]] = None, + _host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0, + ) -> GetUpdateServiceResponse: + """get update service details + + + :param project_id: project id (required) + :type project_id: str + :param server_id: server id (required) + :type server_id: str + :param _request_timeout: timeout setting for this request. If one + number provided, it will be total request + timeout. It can also be a pair (tuple) of + (connection, read) timeouts. + :type _request_timeout: int, tuple(int, int), optional + :param _request_auth: set to override the auth_settings for an a single + request; this effectively ignores the + authentication in the spec for a single request. + :type _request_auth: dict, optional + :param _content_type: force content-type for the request. + :type _content_type: str, Optional + :param _headers: set to override the headers for a single + request; this effectively ignores the headers + in the spec for a single request. + :type _headers: dict, optional + :param _host_index: set to override the host_index for a single + request; this effectively ignores the host_index + in the spec for a single request. + :type _host_index: int, optional + :return: Returns the result object. + """ # noqa: E501 docstring might be too long + + _param = self._get_service_resource_serialize( + project_id=project_id, + server_id=server_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "GetUpdateServiceResponse", + "400": None, + "401": None, + "404": None, + } + response_data = self.api_client.call_api(*_param, _request_timeout=_request_timeout) + response_data.read() + return self.api_client.response_deserialize( + response_data=response_data, + response_types_map=_response_types_map, + ).data + + @validate_call + def get_service_resource_with_http_info( + self, + project_id: Annotated[StrictStr, Field(description="project id")], + server_id: Annotated[StrictStr, Field(description="server id")], + _request_timeout: Union[ + None, + Annotated[StrictFloat, Field(gt=0)], + Tuple[Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]], + ] = None, + _request_auth: Optional[Dict[StrictStr, Any]] = None, + _content_type: Optional[StrictStr] = None, + _headers: Optional[Dict[StrictStr, Any]] = None, + _host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0, + ) -> ApiResponse[GetUpdateServiceResponse]: + """get update service details + + + :param project_id: project id (required) + :type project_id: str + :param server_id: server id (required) + :type server_id: str + :param _request_timeout: timeout setting for this request. If one + number provided, it will be total request + timeout. It can also be a pair (tuple) of + (connection, read) timeouts. + :type _request_timeout: int, tuple(int, int), optional + :param _request_auth: set to override the auth_settings for an a single + request; this effectively ignores the + authentication in the spec for a single request. + :type _request_auth: dict, optional + :param _content_type: force content-type for the request. + :type _content_type: str, Optional + :param _headers: set to override the headers for a single + request; this effectively ignores the headers + in the spec for a single request. + :type _headers: dict, optional + :param _host_index: set to override the host_index for a single + request; this effectively ignores the host_index + in the spec for a single request. + :type _host_index: int, optional + :return: Returns the result object. + """ # noqa: E501 docstring might be too long + + _param = self._get_service_resource_serialize( + project_id=project_id, + server_id=server_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "GetUpdateServiceResponse", + "400": None, + "401": None, + "404": None, + } + response_data = self.api_client.call_api(*_param, _request_timeout=_request_timeout) + response_data.read() + return self.api_client.response_deserialize( + response_data=response_data, + response_types_map=_response_types_map, + ) + + @validate_call + def get_service_resource_without_preload_content( + self, + project_id: Annotated[StrictStr, Field(description="project id")], + server_id: Annotated[StrictStr, Field(description="server id")], + _request_timeout: Union[ + None, + Annotated[StrictFloat, Field(gt=0)], + Tuple[Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]], + ] = None, + _request_auth: Optional[Dict[StrictStr, Any]] = None, + _content_type: Optional[StrictStr] = None, + _headers: Optional[Dict[StrictStr, Any]] = None, + _host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0, + ) -> RESTResponseType: + """get update service details + + + :param project_id: project id (required) + :type project_id: str + :param server_id: server id (required) + :type server_id: str + :param _request_timeout: timeout setting for this request. If one + number provided, it will be total request + timeout. It can also be a pair (tuple) of + (connection, read) timeouts. + :type _request_timeout: int, tuple(int, int), optional + :param _request_auth: set to override the auth_settings for an a single + request; this effectively ignores the + authentication in the spec for a single request. + :type _request_auth: dict, optional + :param _content_type: force content-type for the request. + :type _content_type: str, Optional + :param _headers: set to override the headers for a single + request; this effectively ignores the headers + in the spec for a single request. + :type _headers: dict, optional + :param _host_index: set to override the host_index for a single + request; this effectively ignores the host_index + in the spec for a single request. + :type _host_index: int, optional + :return: Returns the result object. + """ # noqa: E501 docstring might be too long + + _param = self._get_service_resource_serialize( + project_id=project_id, + server_id=server_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "GetUpdateServiceResponse", + "400": None, + "401": None, + "404": None, + } + response_data = self.api_client.call_api(*_param, _request_timeout=_request_timeout) + return response_data.response + + def _get_service_resource_serialize( + self, + project_id, + server_id, + _request_auth, + _content_type, + _headers, + _host_index, + ) -> RequestSerialized: + + _host = None + + _collection_formats: Dict[str, str] = {} + + _path_params: Dict[str, str] = {} + _query_params: List[Tuple[str, str]] = [] + _header_params: Dict[str, Optional[str]] = _headers or {} + _form_params: List[Tuple[str, str]] = [] + _files: Dict[str, Union[str, bytes]] = {} + _body_params: Optional[bytes] = None + + # process the path parameters + if project_id is not None: + _path_params["projectId"] = project_id + if server_id is not None: + _path_params["serverId"] = server_id + # process the query parameters + # process the header parameters + # process the form parameters + # process the body parameter + + # set the HTTP header `Accept` + if "Accept" not in _header_params: + _header_params["Accept"] = self.api_client.select_header_accept(["application/json"]) + + # authentication setting + _auth_settings: List[str] = [] + + return self.api_client.param_serialize( + method="GET", + resource_path="/v1/projects/{projectId}/servers/{serverId}/service", + path_params=_path_params, + query_params=_query_params, + header_params=_header_params, + body=_body_params, + post_params=_form_params, + files=_files, + auth_settings=_auth_settings, + collection_formats=_collection_formats, + _host=_host, + _request_auth=_request_auth, + ) + @validate_call def get_update( self, diff --git a/services/serverupdate/src/stackit/serverupdate/models/__init__.py b/services/serverupdate/src/stackit/serverupdate/models/__init__.py index 0064b4ad..8018a8a3 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/__init__.py +++ b/services/serverupdate/src/stackit/serverupdate/models/__init__.py @@ -15,7 +15,6 @@ # import models into model package -from stackit.serverupdate.models.backup_properties import BackupProperties from stackit.serverupdate.models.create_update_payload import CreateUpdatePayload from stackit.serverupdate.models.create_update_schedule_payload import ( CreateUpdateSchedulePayload, @@ -30,10 +29,16 @@ from stackit.serverupdate.models.get_update_schedules_response import ( GetUpdateSchedulesResponse, ) +from stackit.serverupdate.models.get_update_service_response import ( + GetUpdateServiceResponse, +) from stackit.serverupdate.models.get_updates_list_response import GetUpdatesListResponse from stackit.serverupdate.models.update import Update from stackit.serverupdate.models.update_policy import UpdatePolicy from stackit.serverupdate.models.update_schedule import UpdateSchedule +from stackit.serverupdate.models.update_schedule_create_request import ( + UpdateScheduleCreateRequest, +) from stackit.serverupdate.models.update_update_schedule_payload import ( UpdateUpdateSchedulePayload, ) diff --git a/services/serverupdate/src/stackit/serverupdate/models/create_update_payload.py b/services/serverupdate/src/stackit/serverupdate/models/create_update_payload.py index 90cc4f5d..7f7b8293 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/create_update_payload.py +++ b/services/serverupdate/src/stackit/serverupdate/models/create_update_payload.py @@ -21,8 +21,6 @@ from pydantic import BaseModel, ConfigDict, Field, StrictBool from typing_extensions import Annotated, Self -from stackit.serverupdate.models.backup_properties import BackupProperties - class CreateUpdatePayload(BaseModel): """ @@ -30,9 +28,8 @@ class CreateUpdatePayload(BaseModel): """ backup_before_update: Optional[StrictBool] = Field(default=None, alias="backupBeforeUpdate") - backup_properties: Optional[BackupProperties] = Field(default=None, alias="backupProperties") maintenance_window: Annotated[int, Field(le=24, strict=True, ge=1)] = Field(alias="maintenanceWindow") - __properties: ClassVar[List[str]] = ["backupBeforeUpdate", "backupProperties", "maintenanceWindow"] + __properties: ClassVar[List[str]] = ["backupBeforeUpdate", "maintenanceWindow"] model_config = ConfigDict( populate_by_name=True, @@ -71,9 +68,6 @@ def to_dict(self) -> Dict[str, Any]: exclude=excluded_fields, exclude_none=True, ) - # override the default output from pydantic by calling `to_dict()` of backup_properties - if self.backup_properties: - _dict["backupProperties"] = self.backup_properties.to_dict() return _dict @classmethod @@ -86,14 +80,6 @@ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: return cls.model_validate(obj) _obj = cls.model_validate( - { - "backupBeforeUpdate": obj.get("backupBeforeUpdate"), - "backupProperties": ( - BackupProperties.from_dict(obj["backupProperties"]) - if obj.get("backupProperties") is not None - else None - ), - "maintenanceWindow": obj.get("maintenanceWindow"), - } + {"backupBeforeUpdate": obj.get("backupBeforeUpdate"), "maintenanceWindow": obj.get("maintenanceWindow")} ) return _obj diff --git a/services/serverupdate/src/stackit/serverupdate/models/create_update_schedule_payload.py b/services/serverupdate/src/stackit/serverupdate/models/create_update_schedule_payload.py index 77e40c80..bdc3bc0e 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/create_update_schedule_payload.py +++ b/services/serverupdate/src/stackit/serverupdate/models/create_update_schedule_payload.py @@ -18,7 +18,7 @@ import pprint from typing import Any, ClassVar, Dict, List, Optional, Set -from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictInt, StrictStr +from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictStr from typing_extensions import Annotated, Self @@ -28,11 +28,10 @@ class CreateUpdateSchedulePayload(BaseModel): """ enabled: StrictBool - id: Optional[StrictInt] = None maintenance_window: Annotated[int, Field(le=24, strict=True, ge=1)] = Field(alias="maintenanceWindow") name: StrictStr rrule: StrictStr - __properties: ClassVar[List[str]] = ["enabled", "id", "maintenanceWindow", "name", "rrule"] + __properties: ClassVar[List[str]] = ["enabled", "maintenanceWindow", "name", "rrule"] model_config = ConfigDict( populate_by_name=True, @@ -85,7 +84,6 @@ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: _obj = cls.model_validate( { "enabled": obj.get("enabled"), - "id": obj.get("id"), "maintenanceWindow": obj.get("maintenanceWindow"), "name": obj.get("name"), "rrule": obj.get("rrule"), diff --git a/services/serverupdate/src/stackit/serverupdate/models/get_update_service_response.py b/services/serverupdate/src/stackit/serverupdate/models/get_update_service_response.py new file mode 100644 index 00000000..23a87478 --- /dev/null +++ b/services/serverupdate/src/stackit/serverupdate/models/get_update_service_response.py @@ -0,0 +1,82 @@ +# coding: utf-8 + +""" + STACKIT Server Update Management API + + API endpoints for Server Update Operations on STACKIT Servers. + + The version of the OpenAPI document: 1.0 + Contact: support@stackit.de + Generated by OpenAPI Generator (https://openapi-generator.tech) + + Do not edit the class manually. +""" # noqa: E501 docstring might be too long + +from __future__ import annotations + +import json +import pprint +from typing import Any, ClassVar, Dict, List, Optional, Set + +from pydantic import BaseModel, ConfigDict, StrictBool +from typing_extensions import Self + + +class GetUpdateServiceResponse(BaseModel): + """ + GetUpdateServiceResponse + """ + + enabled: Optional[StrictBool] = None + __properties: ClassVar[List[str]] = ["enabled"] + + model_config = ConfigDict( + populate_by_name=True, + validate_assignment=True, + protected_namespaces=(), + ) + + def to_str(self) -> str: + """Returns the string representation of the model using alias""" + return pprint.pformat(self.model_dump(by_alias=True)) + + def to_json(self) -> str: + """Returns the JSON representation of the model using alias""" + # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead + return json.dumps(self.to_dict()) + + @classmethod + def from_json(cls, json_str: str) -> Optional[Self]: + """Create an instance of GetUpdateServiceResponse from a JSON string""" + return cls.from_dict(json.loads(json_str)) + + def to_dict(self) -> Dict[str, Any]: + """Return the dictionary representation of the model using alias. + + This has the following differences from calling pydantic's + `self.model_dump(by_alias=True)`: + + * `None` is only added to the output dict for nullable fields that + were set at model initialization. Other fields with value `None` + are ignored. + """ + excluded_fields: Set[str] = set([]) + + _dict = self.model_dump( + by_alias=True, + exclude=excluded_fields, + exclude_none=True, + ) + return _dict + + @classmethod + def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: + """Create an instance of GetUpdateServiceResponse from a dict""" + if obj is None: + return None + + if not isinstance(obj, dict): + return cls.model_validate(obj) + + _obj = cls.model_validate({"enabled": obj.get("enabled")}) + return _obj diff --git a/services/serverupdate/src/stackit/serverupdate/models/update_schedule.py b/services/serverupdate/src/stackit/serverupdate/models/update_schedule.py index 6e4a79ef..533942fe 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/update_schedule.py +++ b/services/serverupdate/src/stackit/serverupdate/models/update_schedule.py @@ -28,11 +28,11 @@ class UpdateSchedule(BaseModel): """ enabled: StrictBool - id: Optional[StrictInt] = None maintenance_window: Annotated[int, Field(le=24, strict=True, ge=1)] = Field(alias="maintenanceWindow") name: StrictStr rrule: StrictStr - __properties: ClassVar[List[str]] = ["enabled", "id", "maintenanceWindow", "name", "rrule"] + id: StrictInt + __properties: ClassVar[List[str]] = ["enabled", "maintenanceWindow", "name", "rrule", "id"] model_config = ConfigDict( populate_by_name=True, @@ -85,10 +85,10 @@ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: _obj = cls.model_validate( { "enabled": obj.get("enabled"), - "id": obj.get("id"), "maintenanceWindow": obj.get("maintenanceWindow"), "name": obj.get("name"), "rrule": obj.get("rrule"), + "id": obj.get("id"), } ) return _obj diff --git a/services/serverupdate/src/stackit/serverupdate/models/backup_properties.py b/services/serverupdate/src/stackit/serverupdate/models/update_schedule_create_request.py similarity index 72% rename from services/serverupdate/src/stackit/serverupdate/models/backup_properties.py rename to services/serverupdate/src/stackit/serverupdate/models/update_schedule_create_request.py index d0bd56ff..e9c7799e 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/backup_properties.py +++ b/services/serverupdate/src/stackit/serverupdate/models/update_schedule_create_request.py @@ -18,21 +18,20 @@ import pprint from typing import Any, ClassVar, Dict, List, Optional, Set -from pydantic import BaseModel, ConfigDict, Field, StrictStr +from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictStr from typing_extensions import Annotated, Self -class BackupProperties(BaseModel): +class UpdateScheduleCreateRequest(BaseModel): """ - BackupProperties + UpdateScheduleCreateRequest """ - name: StrictStr = Field(description="Max 255 characters") - retention_period: Annotated[int, Field(le=36500, strict=True, ge=1)] = Field( - description="Values are set in days (1-36500)", alias="retentionPeriod" - ) - volume_ids: Optional[List[StrictStr]] = Field(default=None, alias="volumeIds") - __properties: ClassVar[List[str]] = ["name", "retentionPeriod", "volumeIds"] + enabled: StrictBool + maintenance_window: Annotated[int, Field(le=24, strict=True, ge=1)] = Field(alias="maintenanceWindow") + name: StrictStr + rrule: StrictStr + __properties: ClassVar[List[str]] = ["enabled", "maintenanceWindow", "name", "rrule"] model_config = ConfigDict( populate_by_name=True, @@ -51,7 +50,7 @@ def to_json(self) -> str: @classmethod def from_json(cls, json_str: str) -> Optional[Self]: - """Create an instance of BackupProperties from a JSON string""" + """Create an instance of UpdateScheduleCreateRequest from a JSON string""" return cls.from_dict(json.loads(json_str)) def to_dict(self) -> Dict[str, Any]: @@ -75,7 +74,7 @@ def to_dict(self) -> Dict[str, Any]: @classmethod def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: - """Create an instance of BackupProperties from a dict""" + """Create an instance of UpdateScheduleCreateRequest from a dict""" if obj is None: return None @@ -83,6 +82,11 @@ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: return cls.model_validate(obj) _obj = cls.model_validate( - {"name": obj.get("name"), "retentionPeriod": obj.get("retentionPeriod"), "volumeIds": obj.get("volumeIds")} + { + "enabled": obj.get("enabled"), + "maintenanceWindow": obj.get("maintenanceWindow"), + "name": obj.get("name"), + "rrule": obj.get("rrule"), + } ) return _obj diff --git a/services/serverupdate/src/stackit/serverupdate/models/update_update_schedule_payload.py b/services/serverupdate/src/stackit/serverupdate/models/update_update_schedule_payload.py index bee19930..91436fce 100644 --- a/services/serverupdate/src/stackit/serverupdate/models/update_update_schedule_payload.py +++ b/services/serverupdate/src/stackit/serverupdate/models/update_update_schedule_payload.py @@ -18,7 +18,7 @@ import pprint from typing import Any, ClassVar, Dict, List, Optional, Set -from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictInt, StrictStr +from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictStr from typing_extensions import Annotated, Self @@ -28,11 +28,10 @@ class UpdateUpdateSchedulePayload(BaseModel): """ enabled: StrictBool - id: Optional[StrictInt] = None maintenance_window: Annotated[int, Field(le=24, strict=True, ge=1)] = Field(alias="maintenanceWindow") name: StrictStr rrule: StrictStr - __properties: ClassVar[List[str]] = ["enabled", "id", "maintenanceWindow", "name", "rrule"] + __properties: ClassVar[List[str]] = ["enabled", "maintenanceWindow", "name", "rrule"] model_config = ConfigDict( populate_by_name=True, @@ -85,7 +84,6 @@ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]: _obj = cls.model_validate( { "enabled": obj.get("enabled"), - "id": obj.get("id"), "maintenanceWindow": obj.get("maintenanceWindow"), "name": obj.get("name"), "rrule": obj.get("rrule"),