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