2022-04-06 23:20:20 -07:00
from typing import Any , Dict , Optional , Union , cast
2022-04-06 20:35:34 -07:00
import httpx
from . . . client import Client
2022-06-11 17:42:00 -07:00
from . . . models . file_conversion import FileConversion
from . . . models . file_mass import FileMass
from . . . models . file_volume import FileVolume
2022-04-06 20:35:34 -07:00
from . . . models . error import Error
from . . . types import Response
def _get_kwargs (
id : str ,
* ,
client : Client ,
) - > Dict [ str , Any ] :
url = " {} /user/file/conversions/ {id} " . format ( client . base_url , id = id )
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 ( ) ,
}
2022-06-11 17:42:00 -07:00
def _parse_response ( * , response : httpx . Response ) - > Optional [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
if response . status_code == 200 :
2022-06-11 17:26:20 -07:00
response_200 = AsyncApiCallOutput . from_dict ( response . json ( ) )
2022-04-06 20:35:34 -07:00
return response_200
2022-04-06 20:48:04 -07:00
if response . status_code == 400 :
2022-04-06 20:35:34 -07:00
response_4XX = Error . from_dict ( response . json ( ) )
return response_4XX
2022-04-06 20:48:04 -07:00
if response . status_code == 500 :
2022-04-06 20:35:34 -07:00
response_5XX = Error . from_dict ( response . json ( ) )
return response_5XX
return None
2022-06-11 17:42:00 -07:00
def _build_response ( * , response : httpx . Response ) - > Response [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
return Response (
status_code = response . status_code ,
content = response . content ,
headers = response . headers ,
parsed = _parse_response ( response = response ) ,
)
def sync_detailed (
id : str ,
* ,
client : Client ,
2022-06-11 17:42:00 -07:00
) - > Response [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
kwargs = _get_kwargs (
id = id ,
client = client ,
)
response = httpx . get (
verify = client . verify_ssl ,
* * kwargs ,
)
return _build_response ( response = response )
def sync (
id : str ,
* ,
client : Client ,
2022-06-11 17:42:00 -07:00
) - > Optional [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
""" Get the status and output of an async file conversion. If completed, the contents of the converted file (`output`) will be returned as a base64 encoded string.
This endpoint requires authentication by any KittyCAD user . It returns details of the requested file conversion for the user . """
return sync_detailed (
id = id ,
client = client ,
) . parsed
async def asyncio_detailed (
id : str ,
* ,
client : Client ,
2022-06-11 17:42:00 -07:00
) - > Response [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
kwargs = _get_kwargs (
id = id ,
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 (
id : str ,
* ,
client : Client ,
2022-06-11 17:42:00 -07:00
) - > Optional [ Union [ Any , FileConversion , FileMass , FileVolume , Error ] ] :
2022-04-06 20:35:34 -07:00
""" Get the status and output of an async file conversion. If completed, the contents of the converted file (`output`) will be returned as a base64 encoded string.
This endpoint requires authentication by any KittyCAD user . It returns details of the requested file conversion for the user . """
return (
await asyncio_detailed (
id = id ,
client = client ,
)
) . parsed