110 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from typing import Any, Dict, Optional, Union, cast
 | |
| 
 | |
| import httpx
 | |
| 
 | |
| from ...client import Client
 | |
| from ...models.api_token import ApiToken
 | |
| from ...models.error import Error
 | |
| from ...types import Response
 | |
| 
 | |
| def _get_kwargs(
 | |
| 	token: str,
 | |
| 	*,
 | |
| 	client: Client,
 | |
| ) -> Dict[str, Any]:
 | |
| 	url = "{}/user/api-tokens/{token}".format(client.base_url, token=token)
 | |
| 
 | |
| 	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, ApiToken, Error]]:
 | |
| 	if response.status_code == 200:
 | |
| 		response_200 = ApiToken.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 None
 | |
| 
 | |
| 
 | |
| def _build_response(*, response: httpx.Response) -> Response[Union[Any, ApiToken, Error]]:
 | |
| 	return Response(
 | |
| 		status_code=response.status_code,
 | |
| 		content=response.content,
 | |
| 		headers=response.headers,
 | |
| 		parsed=_parse_response(response=response),
 | |
| 	)
 | |
| 
 | |
| 
 | |
| def sync_detailed(
 | |
| 	token: str,
 | |
| 	*,
 | |
| 	client: Client,
 | |
| ) -> Response[Union[Any, ApiToken, Error]]:
 | |
| 	kwargs = _get_kwargs(
 | |
| 		token=token,
 | |
| 		client=client,
 | |
| 	)
 | |
| 
 | |
| 	response = httpx.get(
 | |
| 		verify=client.verify_ssl,
 | |
| 		**kwargs,
 | |
| 	)
 | |
| 
 | |
| 	return _build_response(response=response)
 | |
| 
 | |
| 
 | |
| def sync(
 | |
| 	token: str,
 | |
| 	*,
 | |
| 	client: Client,
 | |
| ) -> Optional[Union[Any, ApiToken, Error]]:
 | |
| 	""" This endpoint requires authentication by any KittyCAD user. It returns details of the requested API token for the user. """
 | |
| 
 | |
| 	return sync_detailed(
 | |
| 		token=token,
 | |
| 		client=client,
 | |
| 	).parsed
 | |
| 
 | |
| 
 | |
| async def asyncio_detailed(
 | |
| 	token: str,
 | |
| 	*,
 | |
| 	client: Client,
 | |
| ) -> Response[Union[Any, ApiToken, Error]]:
 | |
| 	kwargs = _get_kwargs(
 | |
| 		token=token,
 | |
| 		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(
 | |
| 	token: str,
 | |
| 	*,
 | |
| 	client: Client,
 | |
| ) -> Optional[Union[Any, ApiToken, Error]]:
 | |
| 	""" This endpoint requires authentication by any KittyCAD user. It returns details of the requested API token for the user. """
 | |
| 
 | |
| 	return (
 | |
| 		await asyncio_detailed(
 | |
| 		token=token,
 | |
| 			client=client,
 | |
| 		)
 | |
| 	).parsed
 |