2023-05-04 00:58:06 -07:00
|
|
|
from typing import Any, Dict, Optional, Union
|
2022-06-16 12:02:16 -07:00
|
|
|
|
|
|
|
import httpx
|
|
|
|
|
|
|
|
from ...client import Client
|
|
|
|
from ...models.error import Error
|
2023-05-26 12:31:24 -07:00
|
|
|
from ...models.unit_length import UnitLength
|
2023-05-04 00:58:06 -07:00
|
|
|
from ...models.unit_length_conversion import UnitLengthConversion
|
2022-06-16 12:02:16 -07:00
|
|
|
from ...types import Response
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
|
2022-06-16 12:02:16 -07:00
|
|
|
def _get_kwargs(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value: float,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
*,
|
|
|
|
client: Client,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-06-16 12:02:16 -07:00
|
|
|
) -> Dict[str, Any]:
|
2023-09-29 16:05:40 -07:00
|
|
|
url = "{}/unit/conversion/length/{input_unit}/{output_unit}".format(client.base_url, input_unit=input_unit,output_unit=output_unit,) # noqa: E501
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
if value is not None:
|
|
|
|
if "?" in url:
|
|
|
|
url = url + "&value=" + str(value)
|
|
|
|
else:
|
|
|
|
url = url + "?value=" + str(value)
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
|
|
|
|
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(),
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-09-29 16:05:40 -07:00
|
|
|
def _parse_response(*, response: httpx.Response) -> Optional[Union[UnitLengthConversion, Error]] :
|
|
|
|
if response.status_code == 200:
|
|
|
|
response_200 = UnitLengthConversion.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())
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
|
|
|
|
|
|
|
|
def _build_response(
|
|
|
|
*, response: httpx.Response
|
2023-09-29 16:05:40 -07:00
|
|
|
) -> Response[Optional[Union[UnitLengthConversion, Error]]]:
|
2023-05-04 00:58:06 -07:00
|
|
|
return Response(
|
|
|
|
status_code=response.status_code,
|
|
|
|
content=response.content,
|
|
|
|
headers=response.headers,
|
|
|
|
parsed=_parse_response(response=response),
|
|
|
|
)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
|
|
|
|
|
|
|
def sync_detailed(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value: float,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
*,
|
|
|
|
client: Client,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
) -> Response[Optional[Union[UnitLengthConversion, Error]]]:
|
2023-05-04 00:58:06 -07:00
|
|
|
kwargs = _get_kwargs(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit=input_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit=output_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value=value,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
client=client,
|
|
|
|
)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
response = httpx.get(
|
|
|
|
verify=client.verify_ssl,
|
|
|
|
**kwargs,
|
|
|
|
)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
return _build_response(response=response)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
|
|
|
|
|
|
|
def sync(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value: float,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
*,
|
|
|
|
client: Client,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
) -> Optional[Union[UnitLengthConversion, Error]] :
|
2023-05-04 00:58:06 -07:00
|
|
|
"""Convert a length unit value to another length unit value. This is a nice endpoint to use for helper functions.""" # noqa: E501
|
2022-06-16 12:02:16 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
return sync_detailed(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit=input_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit=output_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value=value,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
client=client,
|
|
|
|
).parsed
|
2022-06-16 12:02:16 -07:00
|
|
|
|
|
|
|
|
|
|
|
async def asyncio_detailed(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value: float,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
*,
|
|
|
|
client: Client,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
) -> Response[Optional[Union[UnitLengthConversion, Error]]]:
|
2023-05-04 00:58:06 -07:00
|
|
|
kwargs = _get_kwargs(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit=input_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit=output_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value=value,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
client=client,
|
|
|
|
)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
async with httpx.AsyncClient(verify=client.verify_ssl) as _client:
|
|
|
|
response = await _client.get(**kwargs)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
return _build_response(response=response)
|
2022-06-16 12:02:16 -07:00
|
|
|
|
|
|
|
|
|
|
|
async def asyncio(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit: UnitLength,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value: float,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
*,
|
|
|
|
client: Client,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
) -> Optional[Union[UnitLengthConversion, Error]] :
|
2023-05-04 00:58:06 -07:00
|
|
|
"""Convert a length unit value to another length unit value. This is a nice endpoint to use for helper functions.""" # noqa: E501
|
|
|
|
|
|
|
|
return (
|
|
|
|
await asyncio_detailed(
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
input_unit=input_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-26 12:31:24 -07:00
|
|
|
output_unit=output_unit,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
value=value,
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-05-04 00:58:06 -07:00
|
|
|
client=client,
|
|
|
|
)
|
|
|
|
).parsed
|