Source code for kittycad.api.ai.create_text_to_cad

from typing import Any, Dict, Optional, Union

import httpx

from ...client import Client
from ...models.error import Error
from ...models.file_export_format import FileExportFormat
from ...models.text_to_cad import TextToCad
from ...models.text_to_cad_create_body import TextToCadCreateBody
from ...types import Response


[docs] def _get_kwargs( output_format: FileExportFormat, body: TextToCadCreateBody, *, client: Client, kcl: Optional[bool] = None, ) -> Dict[str, Any]: url = "{}/ai/text-to-cad/{output_format}".format( client.base_url, output_format=output_format, ) # noqa: E501 if kcl is not None: if "?" in url: url = url + "&kcl=" + str(kcl) else: url = url + "?kcl=" + str(kcl) 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(), "content": body.model_dump_json(), }
[docs] def _parse_response(*, response: httpx.Response) -> Optional[Union[TextToCad, Error]]: if response.status_code == 201: response_201 = TextToCad(**response.json()) return response_201 if response.status_code == 400: response_4XX = Error(**response.json()) return response_4XX if response.status_code == 500: response_5XX = Error(**response.json()) return response_5XX return Error(**response.json())
[docs] def _build_response( *, response: httpx.Response ) -> Response[Optional[Union[TextToCad, Error]]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), )
[docs] def sync_detailed( output_format: FileExportFormat, body: TextToCadCreateBody, *, client: Client, kcl: Optional[bool] = None, ) -> Response[Optional[Union[TextToCad, Error]]]: kwargs = _get_kwargs( output_format=output_format, kcl=kcl, body=body, client=client, ) response = httpx.post( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response)
[docs] def sync( output_format: FileExportFormat, body: TextToCadCreateBody, *, client: Client, kcl: Optional[bool] = None, ) -> Optional[Union[TextToCad, Error]]: """Because our source of truth for the resulting model is a STEP file, you will always have STEP file contents when you list your generated models. Any other formats you request here will also be returned when you list your generated models. This operation is performed asynchronously, the `id` of the operation will be returned. You can use the `id` returned from the request to get status information about the async operation from the `/async/operations/{id}` endpoint. One thing to note, if you hit the cache, this endpoint will return right away. So you only have to wait if the status is not `Completed` or `Failed`. """ # noqa: E501 return sync_detailed( output_format=output_format, kcl=kcl, body=body, client=client, ).parsed
[docs] async def asyncio_detailed( output_format: FileExportFormat, body: TextToCadCreateBody, *, client: Client, kcl: Optional[bool] = None, ) -> Response[Optional[Union[TextToCad, Error]]]: kwargs = _get_kwargs( output_format=output_format, kcl=kcl, body=body, client=client, ) async with httpx.AsyncClient(verify=client.verify_ssl) as _client: response = await _client.post(**kwargs) return _build_response(response=response)
[docs] async def asyncio( output_format: FileExportFormat, body: TextToCadCreateBody, *, client: Client, kcl: Optional[bool] = None, ) -> Optional[Union[TextToCad, Error]]: """Because our source of truth for the resulting model is a STEP file, you will always have STEP file contents when you list your generated models. Any other formats you request here will also be returned when you list your generated models. This operation is performed asynchronously, the `id` of the operation will be returned. You can use the `id` returned from the request to get status information about the async operation from the `/async/operations/{id}` endpoint. One thing to note, if you hit the cache, this endpoint will return right away. So you only have to wait if the status is not `Completed` or `Failed`. """ # noqa: E501 return ( await asyncio_detailed( output_format=output_format, kcl=kcl, body=body, client=client, ) ).parsed