2023-08-30 15:59:51 -07:00
|
|
|
from typing import Any, Dict, List, Type, TypeVar, Union
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
import attr
|
2023-11-28 14:16:05 -08:00
|
|
|
from typing_extensions import Self
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
from ..types import UNSET, Unset
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
FF = TypeVar("FF", bound="ice_server_info")
|
|
|
|
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
@attr.s(auto_attribs=True)
|
2023-08-30 15:59:51 -07:00
|
|
|
class ice_server_info:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""Information about the ICE servers.""" # noqa: E501
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "ice_server_info"
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[FF], src_dict: Dict[str, Any]) -> FF:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
ice_server_info = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
ice_server_info.additional_properties = d
|
|
|
|
return ice_server_info
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
YO = TypeVar("YO", bound="trickle_ice")
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-08-17 12:48:13 -07:00
|
|
|
@attr.s(auto_attribs=True)
|
2023-08-30 15:59:51 -07:00
|
|
|
class trickle_ice:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""The trickle ICE candidate response.""" # noqa: E501
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "trickle_ice"
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[YO], src_dict: Dict[str, Any]) -> YO:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
trickle_ice = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
trickle_ice.additional_properties = d
|
|
|
|
return trickle_ice
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
FS = TypeVar("FS", bound="sdp_answer")
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
|
|
|
@attr.s(auto_attribs=True)
|
2023-08-30 15:59:51 -07:00
|
|
|
class sdp_answer:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""The SDP answer response.""" # noqa: E501
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "sdp_answer"
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[FS], src_dict: Dict[str, Any]) -> FS:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
sdp_answer = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
sdp_answer.additional_properties = d
|
|
|
|
return sdp_answer
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
WN = TypeVar("WN", bound="modeling")
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-08-17 12:48:13 -07:00
|
|
|
@attr.s(auto_attribs=True)
|
|
|
|
class modeling:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""The modeling command response.""" # noqa: E501
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "modeling"
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[WN], src_dict: Dict[str, Any]) -> WN:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
modeling = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
modeling.additional_properties = d
|
|
|
|
return modeling
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
EQ = TypeVar("EQ", bound="export")
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
|
|
|
@attr.s(auto_attribs=True)
|
|
|
|
class export:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""The exported files.""" # noqa: E501
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "export"
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[EQ], src_dict: Dict[str, Any]) -> EQ:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
export = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
export.additional_properties = d
|
|
|
|
return export
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-09-29 16:05:40 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-08-17 12:48:13 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-08-17 12:48:13 -07:00
|
|
|
|
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
UW = TypeVar("UW", bound="metrics_request")
|
2023-09-29 15:51:03 -07:00
|
|
|
|
|
|
|
|
|
|
|
@attr.s(auto_attribs=True)
|
|
|
|
class metrics_request:
|
2023-11-27 16:01:20 -08:00
|
|
|
"""Request a collection of metrics, to include WebRTC.""" # noqa: E501
|
|
|
|
|
|
|
|
data: Union[Unset, Any] = UNSET
|
|
|
|
type: str = "metrics_request"
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
additional_properties: Dict[str, Any] = attr.ib(init=False, factory=dict)
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
data = self.data
|
|
|
|
type = self.type
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
field_dict: Dict[str, Any] = {}
|
|
|
|
field_dict.update(self.additional_properties)
|
|
|
|
field_dict.update({})
|
|
|
|
if data is not UNSET:
|
|
|
|
field_dict["data"] = data
|
|
|
|
field_dict["type"] = type
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
return field_dict
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@classmethod
|
|
|
|
def from_dict(cls: Type[UW], src_dict: Dict[str, Any]) -> UW:
|
|
|
|
d = src_dict.copy()
|
|
|
|
data = d.pop("data", UNSET)
|
|
|
|
type = d.pop("type", UNSET)
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
metrics_request = cls(
|
|
|
|
data=data,
|
|
|
|
type=type,
|
|
|
|
)
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
metrics_request.additional_properties = d
|
|
|
|
return metrics_request
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
@property
|
|
|
|
def additional_keys(self) -> List[str]:
|
|
|
|
return list(self.additional_properties.keys())
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __getitem__(self, key: str) -> Any:
|
|
|
|
return self.additional_properties[key]
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __setitem__(self, key: str, value: Any) -> None:
|
|
|
|
self.additional_properties[key] = value
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __delitem__(self, key: str) -> None:
|
|
|
|
del self.additional_properties[key]
|
2023-09-29 15:51:03 -07:00
|
|
|
|
2023-11-27 16:01:20 -08:00
|
|
|
def __contains__(self, key: str) -> bool:
|
|
|
|
return key in self.additional_properties
|
2023-09-29 15:51:03 -07:00
|
|
|
|
|
|
|
|
2023-11-28 14:16:05 -08:00
|
|
|
class OkWebSocketResponseData:
|
|
|
|
|
|
|
|
"""The websocket messages this server sends."""
|
|
|
|
|
|
|
|
type: Union[
|
|
|
|
ice_server_info,
|
|
|
|
trickle_ice,
|
|
|
|
sdp_answer,
|
|
|
|
modeling,
|
|
|
|
export,
|
|
|
|
metrics_request,
|
|
|
|
] = None
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
type: Union[
|
|
|
|
type(ice_server_info),
|
|
|
|
type(trickle_ice),
|
|
|
|
type(sdp_answer),
|
|
|
|
type(modeling),
|
|
|
|
type(export),
|
|
|
|
type(metrics_request),
|
|
|
|
],
|
|
|
|
):
|
|
|
|
self.type = type
|
|
|
|
|
|
|
|
def to_dict(self) -> Dict[str, Any]:
|
|
|
|
if isinstance(self.type, ice_server_info):
|
|
|
|
n: ice_server_info = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
elif isinstance(self.type, trickle_ice):
|
|
|
|
n: trickle_ice = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
elif isinstance(self.type, sdp_answer):
|
|
|
|
n: sdp_answer = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
elif isinstance(self.type, modeling):
|
|
|
|
n: modeling = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
elif isinstance(self.type, export):
|
|
|
|
n: export = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
elif isinstance(self.type, metrics_request):
|
|
|
|
n: metrics_request = self.type
|
|
|
|
return n.to_dict()
|
|
|
|
|
|
|
|
raise Exception("Unknown type")
|
|
|
|
|
|
|
|
def from_dict(self, d) -> Self:
|
|
|
|
if d.get("type") == "ice_server_info":
|
|
|
|
n: ice_server_info = ice_server_info()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return Self
|
|
|
|
elif d.get("type") == "trickle_ice":
|
|
|
|
n: trickle_ice = trickle_ice()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return self
|
|
|
|
elif d.get("type") == "sdp_answer":
|
|
|
|
n: sdp_answer = sdp_answer()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return self
|
|
|
|
elif d.get("type") == "modeling":
|
|
|
|
n: modeling = modeling()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return self
|
|
|
|
elif d.get("type") == "export":
|
|
|
|
n: export = export()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return self
|
|
|
|
elif d.get("type") == "metrics_request":
|
|
|
|
n: metrics_request = metrics_request()
|
|
|
|
n.from_dict(d)
|
|
|
|
self.type = n
|
|
|
|
return self
|
|
|
|
|
|
|
|
raise Exception("Unknown type")
|