from http import HTTPStatus from typing import Any, cast from urllib.parse import quote import httpx from ...client import AuthenticatedClient, Client from ...types import Response, UNSET from ... import errors from ...models.paginated_response_event_summary import PaginatedResponseEventSummary from ...types import UNSET, Unset from typing import cast def _get_kwargs( *, trigger: int | None | Unset = UNSET, trigger_ref: None | str | Unset = UNSET, source: int | None | Unset = UNSET, page: int | Unset = UNSET, per_page: int | Unset = UNSET, ) -> dict[str, Any]: params: dict[str, Any] = {} json_trigger: int | None | Unset if isinstance(trigger, Unset): json_trigger = UNSET else: json_trigger = trigger params["trigger"] = json_trigger json_trigger_ref: None | str | Unset if isinstance(trigger_ref, Unset): json_trigger_ref = UNSET else: json_trigger_ref = trigger_ref params["trigger_ref"] = json_trigger_ref json_source: int | None | Unset if isinstance(source, Unset): json_source = UNSET else: json_source = source params["source"] = json_source params["page"] = page params["per_page"] = per_page params = {k: v for k, v in params.items() if v is not UNSET and v is not None} _kwargs: dict[str, Any] = { "method": "get", "url": "/api/v1/events", "params": params, } return _kwargs def _parse_response(*, client: AuthenticatedClient | Client, response: httpx.Response) -> Any | PaginatedResponseEventSummary | None: if response.status_code == 200: response_200 = PaginatedResponseEventSummary.from_dict(response.json()) return response_200 if response.status_code == 401: response_401 = cast(Any, None) return response_401 if response.status_code == 500: response_500 = cast(Any, None) return response_500 if client.raise_on_unexpected_status: raise errors.UnexpectedStatus(response.status_code, response.content) else: return None def _build_response(*, client: AuthenticatedClient | Client, response: httpx.Response) -> Response[Any | PaginatedResponseEventSummary]: return Response( status_code=HTTPStatus(response.status_code), content=response.content, headers=response.headers, parsed=_parse_response(client=client, response=response), ) def sync_detailed( *, client: AuthenticatedClient, trigger: int | None | Unset = UNSET, trigger_ref: None | str | Unset = UNSET, source: int | None | Unset = UNSET, page: int | Unset = UNSET, per_page: int | Unset = UNSET, ) -> Response[Any | PaginatedResponseEventSummary]: """ List all events with pagination and optional filters Args: trigger (int | None | Unset): trigger_ref (None | str | Unset): source (int | None | Unset): page (int | Unset): per_page (int | Unset): 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[Any | PaginatedResponseEventSummary] """ kwargs = _get_kwargs( trigger=trigger, trigger_ref=trigger_ref, source=source, page=page, per_page=per_page, ) response = client.get_httpx_client().request( **kwargs, ) return _build_response(client=client, response=response) def sync( *, client: AuthenticatedClient, trigger: int | None | Unset = UNSET, trigger_ref: None | str | Unset = UNSET, source: int | None | Unset = UNSET, page: int | Unset = UNSET, per_page: int | Unset = UNSET, ) -> Any | PaginatedResponseEventSummary | None: """ List all events with pagination and optional filters Args: trigger (int | None | Unset): trigger_ref (None | str | Unset): source (int | None | Unset): page (int | Unset): per_page (int | Unset): 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: Any | PaginatedResponseEventSummary """ return sync_detailed( client=client, trigger=trigger, trigger_ref=trigger_ref, source=source, page=page, per_page=per_page, ).parsed async def asyncio_detailed( *, client: AuthenticatedClient, trigger: int | None | Unset = UNSET, trigger_ref: None | str | Unset = UNSET, source: int | None | Unset = UNSET, page: int | Unset = UNSET, per_page: int | Unset = UNSET, ) -> Response[Any | PaginatedResponseEventSummary]: """ List all events with pagination and optional filters Args: trigger (int | None | Unset): trigger_ref (None | str | Unset): source (int | None | Unset): page (int | Unset): per_page (int | Unset): 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[Any | PaginatedResponseEventSummary] """ kwargs = _get_kwargs( trigger=trigger, trigger_ref=trigger_ref, source=source, page=page, per_page=per_page, ) response = await client.get_async_httpx_client().request( **kwargs ) return _build_response(client=client, response=response) async def asyncio( *, client: AuthenticatedClient, trigger: int | None | Unset = UNSET, trigger_ref: None | str | Unset = UNSET, source: int | None | Unset = UNSET, page: int | Unset = UNSET, per_page: int | Unset = UNSET, ) -> Any | PaginatedResponseEventSummary | None: """ List all events with pagination and optional filters Args: trigger (int | None | Unset): trigger_ref (None | str | Unset): source (int | None | Unset): page (int | Unset): per_page (int | Unset): 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: Any | PaginatedResponseEventSummary """ return (await asyncio_detailed( client=client, trigger=trigger, trigger_ref=trigger_ref, source=source, page=page, per_page=per_page, )).parsed