Source code for kittycad.api.orgs.create_org_member

from typing import Any, Dict, Optional, Union

import httpx

from ...client import Client
from ...models.add_org_member import AddOrgMember
from ...models.error import Error
from ...models.org_member import OrgMember
from ...types import Response


[docs] def _get_kwargs( body: AddOrgMember, *, client: Client, ) -> Dict[str, Any]: url = "{}/org/members".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(), "content": body.model_dump_json(), }
[docs] def _parse_response(*, response: httpx.Response) -> Optional[Union[OrgMember, Error]]: if response.status_code == 201: response_201 = OrgMember(**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[OrgMember, Error]]]: return Response( status_code=response.status_code, content=response.content, headers=response.headers, parsed=_parse_response(response=response), )
[docs] def sync_detailed( body: AddOrgMember, *, client: Client, ) -> Response[Optional[Union[OrgMember, Error]]]: kwargs = _get_kwargs( body=body, client=client, ) response = httpx.post( verify=client.verify_ssl, **kwargs, ) return _build_response(response=response)
[docs] def sync( body: AddOrgMember, *, client: Client, ) -> Optional[Union[OrgMember, Error]]: """If the user exists, this will add them to your org. If they do not exist, this will create a new user and add them to your org. In both cases the user gets an email that they have been added to the org. If the user is already in your org, this will return a 400 and a message. If the user is already in a different org, this will return a 400 and a message. This endpoint requires authentication by an org admin. It adds the specified member to the authenticated user's org.""" # noqa: E501 return sync_detailed( body=body, client=client, ).parsed
[docs] async def asyncio_detailed( body: AddOrgMember, *, client: Client, ) -> Response[Optional[Union[OrgMember, Error]]]: kwargs = _get_kwargs( 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( body: AddOrgMember, *, client: Client, ) -> Optional[Union[OrgMember, Error]]: """If the user exists, this will add them to your org. If they do not exist, this will create a new user and add them to your org. In both cases the user gets an email that they have been added to the org. If the user is already in your org, this will return a 400 and a message. If the user is already in a different org, this will return a 400 and a message. This endpoint requires authentication by an org admin. It adds the specified member to the authenticated user's org.""" # noqa: E501 return ( await asyncio_detailed( body=body, client=client, ) ).parsed