Source code for kittycad.api.service_accounts.delete_service_account_for_org

from typing import Any, Dict, Optional

import httpx

from ...client import Client
from ...models.error import Error
from ...models.service_account_uuid import ServiceAccountUuid
from ...types import Response


[docs] def _get_kwargs( token: ServiceAccountUuid, *, client: Client, ) -> Dict[str, Any]: url = "{}/org/service-accounts/{token}".format( client.base_url, token=token, ) # noqa: E501 headers: Dict[str, Any] = client.get_headers() cookies: Dict[str, Any] = client.get_cookies() return { "url": url, "headers": headers, "cookies": cookies, "timeout": client.get_timeout(), }
[docs] def _parse_response(*, response: httpx.Response) -> Optional[Error]: return None if response.status_code == 400: response_4XX = Error(**response.json()) return response_4XX if response.status_code == 500: response_5XX = Error(**response.json()) return response_5XX return Error(**response.json())
[docs] def _build_response(*, response: httpx.Response) -> Response[Optional[Error]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), )
[docs] def sync_detailed( token: ServiceAccountUuid, *, client: Client, ) -> Response[Optional[Error]]: kwargs = _get_kwargs( token=token, client=client, ) response = httpx.delete( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response)
[docs] def sync( token: ServiceAccountUuid, *, client: Client, ) -> Optional[Error]: """This endpoint requires authentication by an org admin. It deletes the requested service account for the organization. This endpoint does not actually delete the service account from the database. It merely marks the token as invalid. We still want to keep the service account in the database for historical purposes.""" # noqa: E501 return sync_detailed( token=token, client=client, ).parsed
[docs] async def asyncio_detailed( token: ServiceAccountUuid, *, client: Client, ) -> Response[Optional[Error]]: kwargs = _get_kwargs( token=token, client=client, ) async with httpx.AsyncClient(verify=client.verify_ssl) as _client: response = await _client.delete(**kwargs) return _build_response(response=response)
[docs] async def asyncio( token: ServiceAccountUuid, *, client: Client, ) -> Optional[Error]: """This endpoint requires authentication by an org admin. It deletes the requested service account for the organization. This endpoint does not actually delete the service account from the database. It merely marks the token as invalid. We still want to keep the service account in the database for historical purposes.""" # noqa: E501 return ( await asyncio_detailed( token=token, client=client, ) ).parsed