Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
277 changes: 277 additions & 0 deletions robosystems_client/api/extensions_robo_ledger/op_file_report.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,277 @@
from http import HTTPStatus
from typing import Any
from urllib.parse import quote

import httpx

from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.error_response import ErrorResponse
from ...models.file_report_request import FileReportRequest
from ...models.http_validation_error import HTTPValidationError
from ...models.operation_envelope import OperationEnvelope
from ...types import UNSET, Response, Unset


def _get_kwargs(
graph_id: str,
*,
body: FileReportRequest,
idempotency_key: None | str | Unset = UNSET,
) -> dict[str, Any]:
headers: dict[str, Any] = {}
if not isinstance(idempotency_key, Unset):
headers["Idempotency-Key"] = idempotency_key

_kwargs: dict[str, Any] = {
"method": "post",
"url": "/extensions/roboledger/{graph_id}/operations/file-report".format(
graph_id=quote(str(graph_id), 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
) -> ErrorResponse | HTTPValidationError | OperationEnvelope | None:
if response.status_code == 200:
response_200 = OperationEnvelope.from_dict(response.json())

return response_200

if response.status_code == 400:
response_400 = ErrorResponse.from_dict(response.json())

return response_400

if response.status_code == 401:
response_401 = ErrorResponse.from_dict(response.json())

return response_401

if response.status_code == 403:
response_403 = ErrorResponse.from_dict(response.json())

return response_403

if response.status_code == 404:
response_404 = ErrorResponse.from_dict(response.json())

return response_404

if response.status_code == 409:
response_409 = ErrorResponse.from_dict(response.json())

return response_409

if response.status_code == 422:
response_422 = HTTPValidationError.from_dict(response.json())

return response_422

if response.status_code == 429:
response_429 = ErrorResponse.from_dict(response.json())

return response_429

if response.status_code == 500:
response_500 = ErrorResponse.from_dict(response.json())

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[ErrorResponse | HTTPValidationError | OperationEnvelope]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)


def sync_detailed(
graph_id: str,
*,
client: AuthenticatedClient,
body: FileReportRequest,
idempotency_key: None | str | Unset = UNSET,
) -> Response[ErrorResponse | HTTPValidationError | OperationEnvelope]:
"""File Report

Transitions the Report's filing_status to 'filed' — locks the package. Allowed from 'draft' or
'under_review'. Stamps filed_at + filed_by.

**Idempotency**: supply an `Idempotency-Key` header to make safe retries; replays within 24 hours
return the same envelope. Reusing the key with a different body returns HTTP 409 Conflict.

Args:
graph_id (str):
idempotency_key (None | str | Unset):
body (FileReportRequest): Transition a Report to ``filed`` — locks the package.

Acceptable from ``draft`` or ``under_review``. ``filed_by`` and
``filed_at`` are stamped from the auth context + server clock; the
request itself carries no fields today (kept as a model for OpenAPI
shape consistency and to avoid breaking changes if we add fields).

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[ErrorResponse | HTTPValidationError | OperationEnvelope]
"""

kwargs = _get_kwargs(
graph_id=graph_id,
body=body,
idempotency_key=idempotency_key,
)

response = client.get_httpx_client().request(
**kwargs,
)

return _build_response(client=client, response=response)


def sync(
graph_id: str,
*,
client: AuthenticatedClient,
body: FileReportRequest,
idempotency_key: None | str | Unset = UNSET,
) -> ErrorResponse | HTTPValidationError | OperationEnvelope | None:
"""File Report

Transitions the Report's filing_status to 'filed' — locks the package. Allowed from 'draft' or
'under_review'. Stamps filed_at + filed_by.

**Idempotency**: supply an `Idempotency-Key` header to make safe retries; replays within 24 hours
return the same envelope. Reusing the key with a different body returns HTTP 409 Conflict.

Args:
graph_id (str):
idempotency_key (None | str | Unset):
body (FileReportRequest): Transition a Report to ``filed`` — locks the package.

Acceptable from ``draft`` or ``under_review``. ``filed_by`` and
``filed_at`` are stamped from the auth context + server clock; the
request itself carries no fields today (kept as a model for OpenAPI
shape consistency and to avoid breaking changes if we add fields).

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:
ErrorResponse | HTTPValidationError | OperationEnvelope
"""

return sync_detailed(
graph_id=graph_id,
client=client,
body=body,
idempotency_key=idempotency_key,
).parsed


async def asyncio_detailed(
graph_id: str,
*,
client: AuthenticatedClient,
body: FileReportRequest,
idempotency_key: None | str | Unset = UNSET,
) -> Response[ErrorResponse | HTTPValidationError | OperationEnvelope]:
"""File Report

Transitions the Report's filing_status to 'filed' — locks the package. Allowed from 'draft' or
'under_review'. Stamps filed_at + filed_by.

**Idempotency**: supply an `Idempotency-Key` header to make safe retries; replays within 24 hours
return the same envelope. Reusing the key with a different body returns HTTP 409 Conflict.

Args:
graph_id (str):
idempotency_key (None | str | Unset):
body (FileReportRequest): Transition a Report to ``filed`` — locks the package.

Acceptable from ``draft`` or ``under_review``. ``filed_by`` and
``filed_at`` are stamped from the auth context + server clock; the
request itself carries no fields today (kept as a model for OpenAPI
shape consistency and to avoid breaking changes if we add fields).

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[ErrorResponse | HTTPValidationError | OperationEnvelope]
"""

kwargs = _get_kwargs(
graph_id=graph_id,
body=body,
idempotency_key=idempotency_key,
)

response = await client.get_async_httpx_client().request(**kwargs)

return _build_response(client=client, response=response)


async def asyncio(
graph_id: str,
*,
client: AuthenticatedClient,
body: FileReportRequest,
idempotency_key: None | str | Unset = UNSET,
) -> ErrorResponse | HTTPValidationError | OperationEnvelope | None:
"""File Report

Transitions the Report's filing_status to 'filed' — locks the package. Allowed from 'draft' or
'under_review'. Stamps filed_at + filed_by.

**Idempotency**: supply an `Idempotency-Key` header to make safe retries; replays within 24 hours
return the same envelope. Reusing the key with a different body returns HTTP 409 Conflict.

Args:
graph_id (str):
idempotency_key (None | str | Unset):
body (FileReportRequest): Transition a Report to ``filed`` — locks the package.

Acceptable from ``draft`` or ``under_review``. ``filed_by`` and
``filed_at`` are stamped from the auth context + server clock; the
request itself carries no fields today (kept as a model for OpenAPI
shape consistency and to avoid breaking changes if we add fields).

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:
ErrorResponse | HTTPValidationError | OperationEnvelope
"""

return (
await asyncio_detailed(
graph_id=graph_id,
client=client,
body=body,
idempotency_key=idempotency_key,
)
).parsed
Loading
Loading