from http import HTTPStatus from typing import Any, Dict, Optional, Union, cast import httpx from ... import errors from ...client import Client from ...models.http_validation_error import HTTPValidationError from ...types import UNSET, Response def _get_kwargs( user: str, *, client: Client, code: str, ) -> Dict[str, Any]: url = "{}/users/{user}/confirm".format(client.base_url, user=user) headers: Dict[str, str] = client.get_headers() cookies: Dict[str, Any] = client.get_cookies() params: Dict[str, Any] = {} params["code"] = code params = {k: v for k, v in params.items() if v is not UNSET and v is not None} return { "method": "patch", "url": url, "headers": headers, "cookies": cookies, "timeout": client.get_timeout(), "params": params, } def _parse_response(*, client: Client, response: httpx.Response) -> Optional[Union[Any, HTTPValidationError]]: if response.status_code == HTTPStatus.OK: response_200 = cast(Any, response.json()) return response_200 if response.status_code == HTTPStatus.BAD_REQUEST: response_400 = cast(Any, None) return response_400 if response.status_code == HTTPStatus.UNPROCESSABLE_ENTITY: response_422 = HTTPValidationError.from_dict(response.json()) return response_422 if client.raise_on_unexpected_status: raise errors.UnexpectedStatus(f"Unexpected status code: {response.status_code}") else: return None def _build_response(*, client: Client, response: httpx.Response) -> Response[Union[Any, HTTPValidationError]]: return Response( status_code=HTTPStatus(response.status_code), content=response.content, headers=response.headers, parsed=_parse_response(client=client, response=response), ) def sync_detailed( user: str, *, client: Client, code: str, ) -> Response[Union[Any, HTTPValidationError]]: """User Confirm Args: user (str): code (str): 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[Any, HTTPValidationError]] """ kwargs = _get_kwargs( user=user, client=client, code=code, ) response = httpx.request( verify=client.verify_ssl, **kwargs, ) return _build_response(client=client, response=response) def sync( user: str, *, client: Client, code: str, ) -> Optional[Union[Any, HTTPValidationError]]: """User Confirm Args: user (str): code (str): 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[Any, HTTPValidationError]] """ return sync_detailed( user=user, client=client, code=code, ).parsed async def asyncio_detailed( user: str, *, client: Client, code: str, ) -> Response[Union[Any, HTTPValidationError]]: """User Confirm Args: user (str): code (str): 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[Any, HTTPValidationError]] """ kwargs = _get_kwargs( user=user, client=client, code=code, ) async with httpx.AsyncClient(verify=client.verify_ssl) as _client: response = await _client.request(**kwargs) return _build_response(client=client, response=response) async def asyncio( user: str, *, client: Client, code: str, ) -> Optional[Union[Any, HTTPValidationError]]: """User Confirm Args: user (str): code (str): 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[Any, HTTPValidationError]] """ return ( await asyncio_detailed( user=user, client=client, code=code, ) ).parsed