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.api_response_trigger_response import ApiResponseTriggerResponse from ...models.update_trigger_request import UpdateTriggerRequest from typing import cast def _get_kwargs( ref: str, *, body: UpdateTriggerRequest, ) -> dict[str, Any]: headers: dict[str, Any] = {} _kwargs: dict[str, Any] = { "method": "put", "url": "/api/v1/triggers/{ref}".format(ref=quote(str(ref), safe=""),), } _kwargs["json"] = body.to_dict() headers["Content-Type"] = "application/json" _kwargs["headers"] = headers return _kwargs def _parse_response(*, client: AuthenticatedClient | Client, response: httpx.Response) -> Any | ApiResponseTriggerResponse | None: if response.status_code == 200: response_200 = ApiResponseTriggerResponse.from_dict(response.json()) return response_200 if response.status_code == 400: response_400 = cast(Any, None) return response_400 if response.status_code == 404: response_404 = cast(Any, None) return response_404 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 | ApiResponseTriggerResponse]: return Response( status_code=HTTPStatus(response.status_code), content=response.content, headers=response.headers, parsed=_parse_response(client=client, response=response), ) def sync_detailed( ref: str, *, client: AuthenticatedClient | Client, body: UpdateTriggerRequest, ) -> Response[Any | ApiResponseTriggerResponse]: """ Update an existing trigger Args: ref (str): body (UpdateTriggerRequest): Request DTO for updating a trigger 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 | ApiResponseTriggerResponse] """ kwargs = _get_kwargs( ref=ref, body=body, ) response = client.get_httpx_client().request( **kwargs, ) return _build_response(client=client, response=response) def sync( ref: str, *, client: AuthenticatedClient | Client, body: UpdateTriggerRequest, ) -> Any | ApiResponseTriggerResponse | None: """ Update an existing trigger Args: ref (str): body (UpdateTriggerRequest): Request DTO for updating a trigger 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 | ApiResponseTriggerResponse """ return sync_detailed( ref=ref, client=client, body=body, ).parsed async def asyncio_detailed( ref: str, *, client: AuthenticatedClient | Client, body: UpdateTriggerRequest, ) -> Response[Any | ApiResponseTriggerResponse]: """ Update an existing trigger Args: ref (str): body (UpdateTriggerRequest): Request DTO for updating a trigger 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 | ApiResponseTriggerResponse] """ kwargs = _get_kwargs( ref=ref, body=body, ) response = await client.get_async_httpx_client().request( **kwargs ) return _build_response(client=client, response=response) async def asyncio( ref: str, *, client: AuthenticatedClient | Client, body: UpdateTriggerRequest, ) -> Any | ApiResponseTriggerResponse | None: """ Update an existing trigger Args: ref (str): body (UpdateTriggerRequest): Request DTO for updating a trigger 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 | ApiResponseTriggerResponse """ return (await asyncio_detailed( ref=ref, client=client, body=body, )).parsed