Files
attune/tests/generated_client/models/queue_stats_response.py
2026-02-04 17:46:30 -06:00

175 lines
5.1 KiB
Python

from __future__ import annotations
from collections.abc import Mapping
from typing import Any, TypeVar, BinaryIO, TextIO, TYPE_CHECKING, Generator
from attrs import define as _attrs_define
from attrs import field as _attrs_field
from ..types import UNSET, Unset
from ..types import UNSET, Unset
from dateutil.parser import isoparse
from typing import cast
import datetime
T = TypeVar("T", bound="QueueStatsResponse")
@_attrs_define
class QueueStatsResponse:
""" Response DTO for queue statistics
Attributes:
action_id (int): Action ID Example: 1.
action_ref (str): Action reference Example: slack.post_message.
active_count (int): Number of currently running executions Example: 2.
last_updated (datetime.datetime): Timestamp of last statistics update Example: 2024-01-13T10:30:00Z.
max_concurrent (int): Maximum concurrent executions allowed Example: 3.
queue_length (int): Number of executions waiting in queue Example: 5.
total_completed (int): Total executions completed since queue creation Example: 95.
total_enqueued (int): Total executions enqueued since queue creation Example: 100.
oldest_enqueued_at (datetime.datetime | None | Unset): Timestamp of oldest queued execution (if any) Example:
2024-01-13T10:30:00Z.
"""
action_id: int
action_ref: str
active_count: int
last_updated: datetime.datetime
max_concurrent: int
queue_length: int
total_completed: int
total_enqueued: int
oldest_enqueued_at: datetime.datetime | None | Unset = UNSET
additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
def to_dict(self) -> dict[str, Any]:
action_id = self.action_id
action_ref = self.action_ref
active_count = self.active_count
last_updated = self.last_updated.isoformat()
max_concurrent = self.max_concurrent
queue_length = self.queue_length
total_completed = self.total_completed
total_enqueued = self.total_enqueued
oldest_enqueued_at: None | str | Unset
if isinstance(self.oldest_enqueued_at, Unset):
oldest_enqueued_at = UNSET
elif isinstance(self.oldest_enqueued_at, datetime.datetime):
oldest_enqueued_at = self.oldest_enqueued_at.isoformat()
else:
oldest_enqueued_at = self.oldest_enqueued_at
field_dict: dict[str, Any] = {}
field_dict.update(self.additional_properties)
field_dict.update({
"action_id": action_id,
"action_ref": action_ref,
"active_count": active_count,
"last_updated": last_updated,
"max_concurrent": max_concurrent,
"queue_length": queue_length,
"total_completed": total_completed,
"total_enqueued": total_enqueued,
})
if oldest_enqueued_at is not UNSET:
field_dict["oldest_enqueued_at"] = oldest_enqueued_at
return field_dict
@classmethod
def from_dict(cls: type[T], src_dict: Mapping[str, Any]) -> T:
d = dict(src_dict)
action_id = d.pop("action_id")
action_ref = d.pop("action_ref")
active_count = d.pop("active_count")
last_updated = isoparse(d.pop("last_updated"))
max_concurrent = d.pop("max_concurrent")
queue_length = d.pop("queue_length")
total_completed = d.pop("total_completed")
total_enqueued = d.pop("total_enqueued")
def _parse_oldest_enqueued_at(data: object) -> datetime.datetime | None | Unset:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, str):
raise TypeError()
oldest_enqueued_at_type_0 = isoparse(data)
return oldest_enqueued_at_type_0
except (TypeError, ValueError, AttributeError, KeyError):
pass
return cast(datetime.datetime | None | Unset, data)
oldest_enqueued_at = _parse_oldest_enqueued_at(d.pop("oldest_enqueued_at", UNSET))
queue_stats_response = cls(
action_id=action_id,
action_ref=action_ref,
active_count=active_count,
last_updated=last_updated,
max_concurrent=max_concurrent,
queue_length=queue_length,
total_completed=total_completed,
total_enqueued=total_enqueued,
oldest_enqueued_at=oldest_enqueued_at,
)
queue_stats_response.additional_properties = d
return queue_stats_response
@property
def additional_keys(self) -> list[str]:
return list(self.additional_properties.keys())
def __getitem__(self, key: str) -> Any:
return self.additional_properties[key]
def __setitem__(self, key: str, value: Any) -> None:
self.additional_properties[key] = value
def __delitem__(self, key: str) -> None:
del self.additional_properties[key]
def __contains__(self, key: str) -> bool:
return key in self.additional_properties