from typing import Any, Dict, List, Type, TypeVar, Union
from attrs import define as _attrs_define
from attrs import field as _attrs_field
from ..models.member_role import MemberRole
from ..types import UNSET, Unset
T = TypeVar("T", bound="TeamMember")
[docs]@_attrs_define
class TeamMember:
"""
Attributes:
email (Union[Unset, str]):
id (Union[Unset, str]):
name (Union[Unset, str]):
role (Union[Unset, MemberRole]):
"""
email: Union[Unset, str] = UNSET
id: Union[Unset, str] = UNSET
name: Union[Unset, str] = UNSET
role: Union[Unset, MemberRole] = UNSET
additional_properties: Dict[str, Any] = _attrs_field(init=False, factory=dict)
def to_dict(self) -> Dict[str, Any]:
email = self.email
id = self.id
name = self.name
role: Union[Unset, str] = UNSET
if not isinstance(self.role, Unset):
role = self.role.value
field_dict: Dict[str, Any] = {}
field_dict.update(self.additional_properties)
field_dict.update({})
if email is not UNSET:
field_dict["email"] = email
if id is not UNSET:
field_dict["id"] = id
if name is not UNSET:
field_dict["name"] = name
if role is not UNSET:
field_dict["role"] = role
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
email = d.pop("email", UNSET)
id = d.pop("id", UNSET)
name = d.pop("name", UNSET)
_role = d.pop("role", UNSET)
role: Union[Unset, MemberRole]
if isinstance(_role, Unset):
role = UNSET
else:
role = MemberRole(_role)
team_member = cls(
email=email,
id=id,
name=name,
role=role,
)
team_member.additional_properties = d
return team_member
@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