from typing import Any, Dict, Optional, Union import httpx from ...client import AuthenticatedClient from ...models.instance_metadata import InstanceMetadata from ...types import Response def _get_kwargs( *, client: AuthenticatedClient, ) -> Dict[str, Any]: url = "{}/_meta/debug/instance".format(client.base_url) 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(), } def _parse_response(*, response: httpx.Response) -> Optional[Union[Any, InstanceMetadata]]: if response.status_code == 200: response_200 = InstanceMetadata.from_dict(response.json()) return response_200 if response.status_code == 400: response_400 = None return response_400 if response.status_code == 401: response_401 = None return response_401 if response.status_code == 403: response_403 = None return response_403 return None def _build_response(*, response: httpx.Response) -> Response[Union[Any, InstanceMetadata]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), ) def sync_detailed( *, client: AuthenticatedClient, ) -> Response[Union[Any, InstanceMetadata]]: kwargs = _get_kwargs( client=client, ) response = httpx.get( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response) def sync( *, client: AuthenticatedClient, ) -> Optional[Union[Any, InstanceMetadata]]: """Get information about this specific API server instance. This is primarily used for debugging.""" return sync_detailed( client=client, ).parsed async def asyncio_detailed( *, client: AuthenticatedClient, ) -> Response[Union[Any, InstanceMetadata]]: kwargs = _get_kwargs( client=client, ) async with httpx.AsyncClient(verify=client.verify_ssl) as _client: response = await _client.get(**kwargs) return _build_response(response=response) async def asyncio( *, client: AuthenticatedClient, ) -> Optional[Union[Any, InstanceMetadata]]: """Get information about this specific API server instance. This is primarily used for debugging.""" return ( await asyncio_detailed( client=client, ) ).parsed