1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
from collections.abc import Mapping
from typing import TYPE_CHECKING, Any, Literal, TypeVar, Union, cast
from attrs import define as _attrs_define
from attrs import field as _attrs_field
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.text_part_time import TextPartTime
T = TypeVar("T", bound="TextPart")
@_attrs_define
class TextPart:
"""
Attributes:
id (str):
session_id (str):
message_id (str):
type_ (Literal['text']):
text (str):
synthetic (Union[Unset, bool]):
time (Union[Unset, TextPartTime]):
"""
id: str
session_id: str
message_id: str
type_: Literal["text"]
text: str
synthetic: Union[Unset, bool] = UNSET
time: Union[Unset, "TextPartTime"] = UNSET
additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
def to_dict(self) -> dict[str, Any]:
id = self.id
session_id = self.session_id
message_id = self.message_id
type_ = self.type_
text = self.text
synthetic = self.synthetic
time: Union[Unset, dict[str, Any]] = UNSET
if not isinstance(self.time, Unset):
time = self.time.to_dict()
field_dict: dict[str, Any] = {}
field_dict.update(self.additional_properties)
field_dict.update(
{
"id": id,
"sessionID": session_id,
"messageID": message_id,
"type": type_,
"text": text,
}
)
if synthetic is not UNSET:
field_dict["synthetic"] = synthetic
if time is not UNSET:
field_dict["time"] = time
return field_dict
@classmethod
def from_dict(cls: type[T], src_dict: Mapping[str, Any]) -> T:
from ..models.text_part_time import TextPartTime
d = dict(src_dict)
id = d.pop("id")
session_id = d.pop("sessionID")
message_id = d.pop("messageID")
type_ = cast(Literal["text"], d.pop("type"))
if type_ != "text":
raise ValueError(f"type must match const 'text', got '{type_}'")
text = d.pop("text")
synthetic = d.pop("synthetic", UNSET)
_time = d.pop("time", UNSET)
time: Union[Unset, TextPartTime]
if isinstance(_time, Unset):
time = UNSET
else:
time = TextPartTime.from_dict(_time)
text_part = cls(
id=id,
session_id=session_id,
message_id=message_id,
type_=type_,
text=text,
synthetic=synthetic,
time=time,
)
text_part.additional_properties = d
return text_part
@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
|