From b76c2cf8c26f6c4875cc2673998c30a161316693 Mon Sep 17 00:00:00 2001 From: SDK Generator Bot Date: Mon, 4 May 2026 07:12:14 +0000 Subject: [PATCH 1/2] Generate serviceaccount --- services/serviceaccount/oas_commit | 2 +- .../stackit/serviceaccount/api/default_api.py | 271 ++++++++++++++++++ 2 files changed, 272 insertions(+), 1 deletion(-) diff --git a/services/serviceaccount/oas_commit b/services/serviceaccount/oas_commit index 36076afe..c08a6770 100644 --- a/services/serviceaccount/oas_commit +++ b/services/serviceaccount/oas_commit @@ -1 +1 @@ -87a3ad63dec0a953ff5c6072ad9a15fddd8ec5f8 +4407196dbbef4e53e6798809e856725cbc84ae05 diff --git a/services/serviceaccount/src/stackit/serviceaccount/api/default_api.py b/services/serviceaccount/src/stackit/serviceaccount/api/default_api.py index 6d243c0d..46469836 100644 --- a/services/serviceaccount/src/stackit/serviceaccount/api/default_api.py +++ b/services/serviceaccount/src/stackit/serviceaccount/api/default_api.py @@ -2581,6 +2581,277 @@ def _delete_service_federated_identity_provider_serialize( _request_auth=_request_auth, ) + @validate_call + def get_federated_identity_provider( + self, + project_id: Annotated[StrictStr, Field(description="The ID of the project.")], + service_account_email: Annotated[StrictStr, Field(description="The email of the service account.")], + federation_id: Annotated[UUID, Field(description="ID of the Federated Identity Provider.")], + _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, + ) -> FederatedIdentityProvider: + """Get a service account Federated Identity Provider + + Get a Federated Identity Provider of the service account by its ID. + + :param project_id: The ID of the project. (required) + :type project_id: str + :param service_account_email: The email of the service account. (required) + :type service_account_email: str + :param federation_id: ID of the Federated Identity Provider. (required) + :type federation_id: UUID + :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 + + _param = self._get_federated_identity_provider_serialize( + project_id=project_id, + service_account_email=service_account_email, + federation_id=federation_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "FederatedIdentityProvider", + "400": "Error", + "401": "AuthError", + "403": "AuthError", + "404": "Error", + "500": "Error", + } + 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_federated_identity_provider_with_http_info( + self, + project_id: Annotated[StrictStr, Field(description="The ID of the project.")], + service_account_email: Annotated[StrictStr, Field(description="The email of the service account.")], + federation_id: Annotated[UUID, Field(description="ID of the Federated Identity Provider.")], + _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[FederatedIdentityProvider]: + """Get a service account Federated Identity Provider + + Get a Federated Identity Provider of the service account by its ID. + + :param project_id: The ID of the project. (required) + :type project_id: str + :param service_account_email: The email of the service account. (required) + :type service_account_email: str + :param federation_id: ID of the Federated Identity Provider. (required) + :type federation_id: UUID + :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 + + _param = self._get_federated_identity_provider_serialize( + project_id=project_id, + service_account_email=service_account_email, + federation_id=federation_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "FederatedIdentityProvider", + "400": "Error", + "401": "AuthError", + "403": "AuthError", + "404": "Error", + "500": "Error", + } + 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_federated_identity_provider_without_preload_content( + self, + project_id: Annotated[StrictStr, Field(description="The ID of the project.")], + service_account_email: Annotated[StrictStr, Field(description="The email of the service account.")], + federation_id: Annotated[UUID, Field(description="ID of the Federated Identity Provider.")], + _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 a service account Federated Identity Provider + + Get a Federated Identity Provider of the service account by its ID. + + :param project_id: The ID of the project. (required) + :type project_id: str + :param service_account_email: The email of the service account. (required) + :type service_account_email: str + :param federation_id: ID of the Federated Identity Provider. (required) + :type federation_id: UUID + :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 + + _param = self._get_federated_identity_provider_serialize( + project_id=project_id, + service_account_email=service_account_email, + federation_id=federation_id, + _request_auth=_request_auth, + _content_type=_content_type, + _headers=_headers, + _host_index=_host_index, + ) + + _response_types_map: Dict[str, Optional[str]] = { + "200": "FederatedIdentityProvider", + "400": "Error", + "401": "AuthError", + "403": "AuthError", + "404": "Error", + "500": "Error", + } + response_data = self.api_client.call_api(*_param, _request_timeout=_request_timeout) + return response_data.response + + def _get_federated_identity_provider_serialize( + self, + project_id, + service_account_email, + federation_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, List[str], List[bytes], List[Tuple[str, bytes]]]] = {} + _body_params: Optional[bytes] = None + + # process the path parameters + if project_id is not None: + _path_params["projectId"] = project_id + if service_account_email is not None: + _path_params["serviceAccountEmail"] = service_account_email + if federation_id is not None: + _path_params["federationId"] = federation_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="/v2/projects/{projectId}/service-accounts/{serviceAccountEmail}/federations/{federationId}", + 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_jwks( self, From 300450e5736bfa3b964e741682ce5197268c9854 Mon Sep 17 00:00:00 2001 From: Ruben Hoenle Date: Mon, 4 May 2026 12:13:24 +0200 Subject: [PATCH 2/2] changelogs --- CHANGELOG.md | 5 ++++- services/serviceaccount/CHANGELOG.md | 3 +++ services/serviceaccount/pyproject.toml | 2 +- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6678a96b..2ddaf3aa 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -44,8 +44,11 @@ - **Feature:** New enum type `RetentionMode` - **Feature:** New field `object_lock_enabled` in `Bucket` model struct - **Feature:** New API client methods: `create_compliance_lock`, `delete_compliance_lock`, `delete_default_retention`, `get_compliance_lock`, `get_credentials_group`, `get_default_retention`, `set_default_retention` -- `serviceaccount`: [v0.7.0](services/serviceaccount/CHANGELOG.md#v070) +- `serviceaccount`: + - [v0.7.0](services/serviceaccount/CHANGELOG.md#v070) - **Feature:** Add `token_endpoint` attribute to `CreateServiceAccountKeyResponseCredentials` model class + - [v0.8.0](services/serviceaccount/CHANGELOG.md#v080) + - **Feature:** New API client method `get_federated_identity_provider` - `observability`: [v0.14.0](services/observability/CHANGELOG.md#v0140) - **Feature:** Add attribute `otlp_http_logs_url` to `InstanceSensitiveData` model class - `vpn`: [v0.1.0](services/vpn/CHANGELOG.md#v010) diff --git a/services/serviceaccount/CHANGELOG.md b/services/serviceaccount/CHANGELOG.md index dc8eb4c0..1d67188f 100644 --- a/services/serviceaccount/CHANGELOG.md +++ b/services/serviceaccount/CHANGELOG.md @@ -1,3 +1,6 @@ +## v0.8.0 +- **Feature:** New API client method `get_federated_identity_provider` + ## v0.7.0 - **Feature:** Add `token_endpoint` attribute to `CreateServiceAccountKeyResponseCredentials` model class diff --git a/services/serviceaccount/pyproject.toml b/services/serviceaccount/pyproject.toml index 37e50214..902e01a6 100644 --- a/services/serviceaccount/pyproject.toml +++ b/services/serviceaccount/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "stackit-serviceaccount" -version = "v0.7.0" +version = "v0.8.0" description = "Service Account API" authors = [{ name = "STACKIT Developer Tools", email = "developer-tools@stackit.cloud" }] requires-python = ">=3.9,<4.0"