Files
attune/tests/generated_client/api/executions/list_executions.py
2026-02-04 17:46:30 -06:00

319 lines
8.7 KiB
Python

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.execution_status import ExecutionStatus
from ...models.paginated_response_execution_summary import PaginatedResponseExecutionSummary
from ...types import UNSET, Unset
from typing import cast
def _get_kwargs(
*,
status: ExecutionStatus | None | Unset = UNSET,
action_ref: None | str | Unset = UNSET,
pack_name: None | str | Unset = UNSET,
result_contains: None | str | Unset = UNSET,
enforcement: int | None | Unset = UNSET,
parent: int | None | Unset = UNSET,
page: int | Unset = UNSET,
per_page: int | Unset = UNSET,
) -> dict[str, Any]:
params: dict[str, Any] = {}
json_status: None | str | Unset
if isinstance(status, Unset):
json_status = UNSET
elif isinstance(status, ExecutionStatus):
json_status = status.value
else:
json_status = status
params["status"] = json_status
json_action_ref: None | str | Unset
if isinstance(action_ref, Unset):
json_action_ref = UNSET
else:
json_action_ref = action_ref
params["action_ref"] = json_action_ref
json_pack_name: None | str | Unset
if isinstance(pack_name, Unset):
json_pack_name = UNSET
else:
json_pack_name = pack_name
params["pack_name"] = json_pack_name
json_result_contains: None | str | Unset
if isinstance(result_contains, Unset):
json_result_contains = UNSET
else:
json_result_contains = result_contains
params["result_contains"] = json_result_contains
json_enforcement: int | None | Unset
if isinstance(enforcement, Unset):
json_enforcement = UNSET
else:
json_enforcement = enforcement
params["enforcement"] = json_enforcement
json_parent: int | None | Unset
if isinstance(parent, Unset):
json_parent = UNSET
else:
json_parent = parent
params["parent"] = json_parent
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/executions",
"params": params,
}
return _kwargs
def _parse_response(*, client: AuthenticatedClient | Client, response: httpx.Response) -> PaginatedResponseExecutionSummary | None:
if response.status_code == 200:
response_200 = PaginatedResponseExecutionSummary.from_dict(response.json())
return response_200
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[PaginatedResponseExecutionSummary]:
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,
status: ExecutionStatus | None | Unset = UNSET,
action_ref: None | str | Unset = UNSET,
pack_name: None | str | Unset = UNSET,
result_contains: None | str | Unset = UNSET,
enforcement: int | None | Unset = UNSET,
parent: int | None | Unset = UNSET,
page: int | Unset = UNSET,
per_page: int | Unset = UNSET,
) -> Response[PaginatedResponseExecutionSummary]:
""" List all executions with pagination and optional filters
Args:
status (ExecutionStatus | None | Unset):
action_ref (None | str | Unset):
pack_name (None | str | Unset):
result_contains (None | str | Unset):
enforcement (int | None | Unset):
parent (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[PaginatedResponseExecutionSummary]
"""
kwargs = _get_kwargs(
status=status,
action_ref=action_ref,
pack_name=pack_name,
result_contains=result_contains,
enforcement=enforcement,
parent=parent,
page=page,
per_page=per_page,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: AuthenticatedClient,
status: ExecutionStatus | None | Unset = UNSET,
action_ref: None | str | Unset = UNSET,
pack_name: None | str | Unset = UNSET,
result_contains: None | str | Unset = UNSET,
enforcement: int | None | Unset = UNSET,
parent: int | None | Unset = UNSET,
page: int | Unset = UNSET,
per_page: int | Unset = UNSET,
) -> PaginatedResponseExecutionSummary | None:
""" List all executions with pagination and optional filters
Args:
status (ExecutionStatus | None | Unset):
action_ref (None | str | Unset):
pack_name (None | str | Unset):
result_contains (None | str | Unset):
enforcement (int | None | Unset):
parent (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:
PaginatedResponseExecutionSummary
"""
return sync_detailed(
client=client,
status=status,
action_ref=action_ref,
pack_name=pack_name,
result_contains=result_contains,
enforcement=enforcement,
parent=parent,
page=page,
per_page=per_page,
).parsed
async def asyncio_detailed(
*,
client: AuthenticatedClient,
status: ExecutionStatus | None | Unset = UNSET,
action_ref: None | str | Unset = UNSET,
pack_name: None | str | Unset = UNSET,
result_contains: None | str | Unset = UNSET,
enforcement: int | None | Unset = UNSET,
parent: int | None | Unset = UNSET,
page: int | Unset = UNSET,
per_page: int | Unset = UNSET,
) -> Response[PaginatedResponseExecutionSummary]:
""" List all executions with pagination and optional filters
Args:
status (ExecutionStatus | None | Unset):
action_ref (None | str | Unset):
pack_name (None | str | Unset):
result_contains (None | str | Unset):
enforcement (int | None | Unset):
parent (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[PaginatedResponseExecutionSummary]
"""
kwargs = _get_kwargs(
status=status,
action_ref=action_ref,
pack_name=pack_name,
result_contains=result_contains,
enforcement=enforcement,
parent=parent,
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,
status: ExecutionStatus | None | Unset = UNSET,
action_ref: None | str | Unset = UNSET,
pack_name: None | str | Unset = UNSET,
result_contains: None | str | Unset = UNSET,
enforcement: int | None | Unset = UNSET,
parent: int | None | Unset = UNSET,
page: int | Unset = UNSET,
per_page: int | Unset = UNSET,
) -> PaginatedResponseExecutionSummary | None:
""" List all executions with pagination and optional filters
Args:
status (ExecutionStatus | None | Unset):
action_ref (None | str | Unset):
pack_name (None | str | Unset):
result_contains (None | str | Unset):
enforcement (int | None | Unset):
parent (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:
PaginatedResponseExecutionSummary
"""
return (await asyncio_detailed(
client=client,
status=status,
action_ref=action_ref,
pack_name=pack_name,
result_contains=result_contains,
enforcement=enforcement,
parent=parent,
page=page,
per_page=per_page,
)).parsed