lenticular_cloud2/libs/ory-hydra-client/ory_hydra_client/api/public/discover_open_id_configurat...

198 lines
4.9 KiB
Python
Raw Normal View History

2023-01-13 14:52:38 +00:00
from typing import Any, Dict, List, Optional, Union, cast
import httpx
2023-01-13 14:52:38 +00:00
from ...client import AuthenticatedClient, Client
from ...types import Response, UNSET
from ...models.generic_error import GenericError
2023-01-13 14:52:38 +00:00
from typing import Dict
from typing import cast
from ...models.well_known import WellKnown
2023-01-13 14:52:38 +00:00
def _get_kwargs(
*,
_client: Client,
2023-01-13 14:52:38 +00:00
) -> Dict[str, Any]:
2023-01-13 14:52:38 +00:00
url = "{}/.well-known/openid-configuration".format(
_client.base_url)
headers: Dict[str, str] = _client.get_headers()
cookies: Dict[str, Any] = _client.get_cookies()
2023-01-13 14:52:38 +00:00
return {
2023-01-13 14:52:38 +00:00
"method": "get",
"url": url,
"headers": headers,
"cookies": cookies,
"timeout": _client.get_timeout(),
}
def _parse_response(*, response: httpx.Response) -> Optional[Union[GenericError, WellKnown]]:
2023-01-13 14:52:38 +00:00
if response.status_code == HTTPStatus.OK:
response_200 = WellKnown.from_dict(response.json())
2023-01-13 14:52:38 +00:00
return response_200
2023-01-13 14:52:38 +00:00
if response.status_code == HTTPStatus.UNAUTHORIZED:
response_401 = GenericError.from_dict(response.json())
2023-01-13 14:52:38 +00:00
return response_401
2023-01-13 14:52:38 +00:00
if response.status_code == HTTPStatus.INTERNAL_SERVER_ERROR:
response_500 = GenericError.from_dict(response.json())
2023-01-13 14:52:38 +00:00
return response_500
return None
def _build_response(*, response: httpx.Response) -> Response[Union[GenericError, WellKnown]]:
return Response(
status_code=response.status_code,
content=response.content,
headers=response.headers,
parsed=_parse_response(response=response),
)
def sync_detailed(
*,
_client: Client,
2023-01-13 14:52:38 +00:00
) -> Response[Union[GenericError, WellKnown]]:
"""OpenID Connect Discovery
The well known endpoint an be used to retrieve information for OpenID Connect clients. We encourage
you to not roll
your own OpenID Connect client but to use an OpenID Connect client library instead. You can learn
more on this
flow at https://openid.net/specs/openid-connect-discovery-1_0.html .
Popular libraries for OpenID Connect clients include oidc-client-js (JavaScript), go-oidc (Golang),
and others.
For a full list of clients go here: https://openid.net/developers/certified/
Returns:
Response[Union[GenericError, WellKnown]]
"""
2023-01-13 14:52:38 +00:00
kwargs = _get_kwargs(
_client=_client,
2023-01-13 14:52:38 +00:00
)
response = httpx.request(
verify=_client.verify_ssl,
**kwargs,
)
return _build_response(response=response)
def sync(
*,
_client: Client,
2023-01-13 14:52:38 +00:00
) -> Optional[Union[GenericError, WellKnown]]:
"""OpenID Connect Discovery
The well known endpoint an be used to retrieve information for OpenID Connect clients. We encourage
you to not roll
your own OpenID Connect client but to use an OpenID Connect client library instead. You can learn
more on this
flow at https://openid.net/specs/openid-connect-discovery-1_0.html .
Popular libraries for OpenID Connect clients include oidc-client-js (JavaScript), go-oidc (Golang),
and others.
For a full list of clients go here: https://openid.net/developers/certified/
Returns:
Response[Union[GenericError, WellKnown]]
"""
2023-01-13 14:52:38 +00:00
return sync_detailed(
_client=_client,
2023-01-13 14:52:38 +00:00
).parsed
async def asyncio_detailed(
*,
_client: Client,
2023-01-13 14:52:38 +00:00
) -> Response[Union[GenericError, WellKnown]]:
"""OpenID Connect Discovery
The well known endpoint an be used to retrieve information for OpenID Connect clients. We encourage
you to not roll
your own OpenID Connect client but to use an OpenID Connect client library instead. You can learn
more on this
flow at https://openid.net/specs/openid-connect-discovery-1_0.html .
Popular libraries for OpenID Connect clients include oidc-client-js (JavaScript), go-oidc (Golang),
and others.
For a full list of clients go here: https://openid.net/developers/certified/
Returns:
Response[Union[GenericError, WellKnown]]
"""
2023-01-13 14:52:38 +00:00
kwargs = _get_kwargs(
_client=_client,
2023-01-13 14:52:38 +00:00
)
async with httpx.AsyncClient(verify=_client.verify_ssl) as __client:
2023-01-13 14:52:38 +00:00
response = await __client.request(
**kwargs
)
return _build_response(response=response)
async def asyncio(
*,
_client: Client,
2023-01-13 14:52:38 +00:00
) -> Optional[Union[GenericError, WellKnown]]:
"""OpenID Connect Discovery
The well known endpoint an be used to retrieve information for OpenID Connect clients. We encourage
you to not roll
your own OpenID Connect client but to use an OpenID Connect client library instead. You can learn
more on this
flow at https://openid.net/specs/openid-connect-discovery-1_0.html .
Popular libraries for OpenID Connect clients include oidc-client-js (JavaScript), go-oidc (Golang),
and others.
For a full list of clients go here: https://openid.net/developers/certified/
Returns:
Response[Union[GenericError, WellKnown]]
"""
2023-01-13 14:52:38 +00:00
return (await asyncio_detailed(
_client=_client,
)).parsed