from http import HTTPStatus from typing import Any, cast from urllib.parse import quote import httpx from ... import errors from ...client import AuthenticatedClient, Client from ...models.login_request import LoginRequest from ...models.login_response_200 import LoginResponse200 from ...types import UNSET, Response def _get_kwargs( *, body: LoginRequest, ) -> dict[str, Any]: headers: dict[str, Any] = {} _kwargs: dict[str, Any] = { "method": "post", "url": "/auth/login", } _kwargs["json"] = body.to_dict() headers["Content-Type"] = "application/json" _kwargs["headers"] = headers return _kwargs def _parse_response( *, client: AuthenticatedClient | Client, response: httpx.Response ) -> Any | LoginResponse200 | None: if response.status_code == 200: response_200 = LoginResponse200.from_dict(response.json()) return response_200 if response.status_code == 400: response_400 = cast(Any, None) return response_400 if response.status_code == 401: response_401 = cast(Any, None) return response_401 if client.raise_on_unexpected_status: raise errors.UnexpectedStatus(response.status_code, response.content) else: return None def _build_response( *, client: AuthenticatedClient | Client, response: httpx.Response ) -> Response[Any | LoginResponse200]: return Response( status_code=HTTPStatus(response.status_code), content=response.content, headers=response.headers, parsed=_parse_response(client=client, response=response), ) def sync_detailed( *, client: AuthenticatedClient | Client, body: LoginRequest, ) -> Response[Any | LoginResponse200]: """Login endpoint POST /auth/login Args: body (LoginRequest): Login request 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[Any | LoginResponse200] """ kwargs = _get_kwargs( body=body, ) response = client.get_httpx_client().request( **kwargs, ) return _build_response(client=client, response=response) def sync( *, client: AuthenticatedClient | Client, body: LoginRequest, ) -> Any | LoginResponse200 | None: """Login endpoint POST /auth/login Args: body (LoginRequest): Login request 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: Any | LoginResponse200 """ return sync_detailed( client=client, body=body, ).parsed async def asyncio_detailed( *, client: AuthenticatedClient | Client, body: LoginRequest, ) -> Response[Any | LoginResponse200]: """Login endpoint POST /auth/login Args: body (LoginRequest): Login request 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[Any | LoginResponse200] """ kwargs = _get_kwargs( body=body, ) response = await client.get_async_httpx_client().request(**kwargs) return _build_response(client=client, response=response) async def asyncio( *, client: AuthenticatedClient | Client, body: LoginRequest, ) -> Any | LoginResponse200 | None: """Login endpoint POST /auth/login Args: body (LoginRequest): Login request 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: Any | LoginResponse200 """ return ( await asyncio_detailed( client=client, body=body, ) ).parsed