Source code for pydelfini.delfini_core.api.auth.auth_get_csrf

"""Return object containing CSRF token"""
from http import HTTPStatus
from typing import Any
from typing import Dict
from typing import Union

import httpx

from ... import errors
from ...client import AuthenticatedClient
from ...client import Client
from ...models.auth_get_csrf_response_200 import AuthGetCsrfResponse200
from ...models.server_error import ServerError
from ...types import Response


def _get_kwargs() -> Dict[str, Any]:
    _kwargs: Dict[str, Any] = {
        "method": "get",
        "url": "/auth/csrf",
    }

    return _kwargs


def _parse_response(
    *, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Union[AuthGetCsrfResponse200, ServerError]:
    if response.status_code == HTTPStatus.OK:
        response_200 = AuthGetCsrfResponse200.from_dict(response.json())

        return response_200
    if response.status_code == HTTPStatus.INTERNAL_SERVER_ERROR:
        response_500 = ServerError.from_dict(response.json())

        return response_500

    raise errors.UnexpectedStatus(response.status_code, response.content)


def _build_response(
    *, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[AuthGetCsrfResponse200, ServerError]]:
    return Response(
        status_code=HTTPStatus(response.status_code),
        content=response.content,
        headers=response.headers,
        parsed=_parse_response(client=client, response=response),
    )


[docs] def sync_detailed( *, client: Union[AuthenticatedClient, Client], ) -> Response[Union[AuthGetCsrfResponse200, ServerError]]: """Return object containing CSRF token Raises: errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True. httpx.TimeoutException: If the request takes longer than Client.timeout. Returns: Response[Union[AuthGetCsrfResponse200, ServerError]] """ kwargs = _get_kwargs() response = client.get_httpx_client().request( **kwargs, ) return _build_response(client=client, response=response)
[docs] def sync( *, client: Union[AuthenticatedClient, Client], ) -> Union[AuthGetCsrfResponse200]: """Return object containing CSRF token Raises: errors.UnexpectedStatus: If the server returns a status code greater than or equal to 300. httpx.TimeoutException: If the request takes longer than Client.timeout. Returns: Union[AuthGetCsrfResponse200] """ response = sync_detailed( client=client, ) if isinstance(response.parsed, ServerError): raise errors.UnexpectedStatus(response.status_code, response.content) return response.parsed
[docs] async def asyncio_detailed( *, client: Union[AuthenticatedClient, Client], ) -> Response[Union[AuthGetCsrfResponse200, ServerError]]: """Return object containing CSRF token Raises: errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True. httpx.TimeoutException: If the request takes longer than Client.timeout. Returns: Response[Union[AuthGetCsrfResponse200, ServerError]] """ kwargs = _get_kwargs() response = await client.get_async_httpx_client().request(**kwargs) return _build_response(client=client, response=response)
[docs] async def asyncio( *, client: Union[AuthenticatedClient, Client], ) -> Union[AuthGetCsrfResponse200]: """Return object containing CSRF token Raises: errors.UnexpectedStatus: If the server returns a status code greater than or equal to 300. httpx.TimeoutException: If the request takes longer than Client.timeout. Returns: Union[AuthGetCsrfResponse200] """ response = await asyncio_detailed( client=client, ) if isinstance(response.parsed, ServerError): raise errors.UnexpectedStatus(response.status_code, response.content) return response.parsed