Source code for kittycad.api.apps.apps_github_callback

from typing import Any, Dict, Optional

import httpx

from ...client import Client
from ...models.error import Error
from ...types import Response


[docs]def _get_kwargs( *, client: Client, ) -> Dict[str, Any]: url = "{}/apps/github/callback".format( client.base_url, ) # noqa: E501 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[Error]: return None 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[Error]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), )
[docs]def sync_detailed( *, client: Client, ) -> Response[Optional[Error]]: kwargs = _get_kwargs( client=client, ) response = httpx.get( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response)
[docs]def sync( *, client: Client, ) -> Optional[Error]: """This is different than OAuth 2.0 authentication for users. This endpoint grants access for KittyCAD to access user's repos. The user doesn't need KittyCAD OAuth authorization for this endpoint, this is purely for the GitHub permissions to access repos. """ # noqa: E501 return sync_detailed( client=client, ).parsed
[docs]async def asyncio_detailed( *, client: Client, ) -> Response[Optional[Error]]: kwargs = _get_kwargs( 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( *, client: Client, ) -> Optional[Error]: """This is different than OAuth 2.0 authentication for users. This endpoint grants access for KittyCAD to access user's repos. The user doesn't need KittyCAD OAuth authorization for this endpoint, this is purely for the GitHub permissions to access repos. """ # noqa: E501 return ( await asyncio_detailed( client=client, ) ).parsed