Source code for kittycad.api.unit.get_frequency_unit_conversion

from typing import Any, Dict, Optional, Union

import httpx

from ...client import Client
from ...models.error import Error
from ...models.unit_frequency import UnitFrequency
from ...models.unit_frequency_conversion import UnitFrequencyConversion
from ...types import Response


[docs]def _get_kwargs( input_unit: UnitFrequency, output_unit: UnitFrequency, value: float, *, client: Client, ) -> Dict[str, Any]: url = "{}/unit/conversion/frequency/{input_unit}/{output_unit}".format( client.base_url, input_unit=input_unit, output_unit=output_unit ) # noqa: E501 if value is not None: if "?" in url: url = url + "&value=" + str(value) else: url = url + "?value=" + str(value) 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[Union[UnitFrequencyConversion, Error]]: if response.status_code == 200: response_200 = UnitFrequencyConversion.from_dict(response.json()) return response_200 if response.status_code == 400: response_4XX = Error.from_dict(response.json()) return response_4XX if response.status_code == 500: response_5XX = Error.from_dict(response.json()) return response_5XX return Error.from_dict(response.json())
[docs]def _build_response( *, response: httpx.Response ) -> Response[Optional[Union[UnitFrequencyConversion, Error]]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), )
[docs]def sync_detailed( input_unit: UnitFrequency, output_unit: UnitFrequency, value: float, *, client: Client, ) -> Response[Optional[Union[UnitFrequencyConversion, Error]]]: kwargs = _get_kwargs( input_unit=input_unit, output_unit=output_unit, value=value, client=client, ) response = httpx.get( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response)
[docs]def sync( input_unit: UnitFrequency, output_unit: UnitFrequency, value: float, *, client: Client, ) -> Optional[Union[UnitFrequencyConversion, Error]]: """Convert a frequency unit value to another frequency unit value. This is a nice endpoint to use for helper functions.""" # noqa: E501 return sync_detailed( input_unit=input_unit, output_unit=output_unit, value=value, client=client, ).parsed
[docs]async def asyncio_detailed( input_unit: UnitFrequency, output_unit: UnitFrequency, value: float, *, client: Client, ) -> Response[Optional[Union[UnitFrequencyConversion, Error]]]: kwargs = _get_kwargs( input_unit=input_unit, output_unit=output_unit, value=value, client=client, ) async with httpx.AsyncClient(verify=client.verify_ssl) as _client: response = await _client.get(**kwargs) return _build_response(response=response)
[docs]async def asyncio( input_unit: UnitFrequency, output_unit: UnitFrequency, value: float, *, client: Client, ) -> Optional[Union[UnitFrequencyConversion, Error]]: """Convert a frequency unit value to another frequency unit value. This is a nice endpoint to use for helper functions.""" # noqa: E501 return ( await asyncio_detailed( input_unit=input_unit, output_unit=output_unit, value=value, client=client, ) ).parsed