Source code for pydelfini.delfini_core.api.auth.auth_new_session
"""Create a new placeholder session ID"""
from http import HTTPStatus
from typing import Any
from typing import Dict
from typing import Union
import httpx
from ... import errors
from ...client import AuthenticatedClient
from ...client import Client
from ...models.server_error import ServerError
from ...models.session_token import SessionToken
from ...types import Response
def _get_kwargs() -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "post",
"url": "/auth/session/new",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Union[ServerError, SessionToken]:
if response.status_code == HTTPStatus.OK:
response_200 = SessionToken.from_dict(response.json())
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = ServerError.from_dict(response.json())
return response_400
if response.status_code == HTTPStatus.INTERNAL_SERVER_ERROR:
response_500 = ServerError.from_dict(response.json())
return response_500
raise errors.UnexpectedStatus(response.status_code, response.content)
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[ServerError, SessionToken]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
[docs]
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[ServerError, SessionToken]]:
"""Create a new placeholder session ID
This is used to create an empty session that can later be
activated using an active session.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[ServerError, SessionToken]]
"""
kwargs = _get_kwargs()
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
[docs]
def sync(
*,
client: Union[AuthenticatedClient, Client],
) -> Union[SessionToken]:
"""Create a new placeholder session ID
This is used to create an empty session that can later be
activated using an active session.
Raises:
errors.UnexpectedStatus: If the server returns a status code greater than or equal to 300.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[SessionToken]
"""
response = sync_detailed(
client=client,
)
if isinstance(response.parsed, ServerError):
raise errors.UnexpectedStatus(response.status_code, response.content)
return response.parsed
[docs]
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[ServerError, SessionToken]]:
"""Create a new placeholder session ID
This is used to create an empty session that can later be
activated using an active session.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[ServerError, SessionToken]]
"""
kwargs = _get_kwargs()
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
[docs]
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
) -> Union[SessionToken]:
"""Create a new placeholder session ID
This is used to create an empty session that can later be
activated using an active session.
Raises:
errors.UnexpectedStatus: If the server returns a status code greater than or equal to 300.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[SessionToken]
"""
response = await asyncio_detailed(
client=client,
)
if isinstance(response.parsed, ServerError):
raise errors.UnexpectedStatus(response.status_code, response.content)
return response.parsed