Source code for mgnipy.emgapi_v2_client.models.m_gnify_sample_detail
from __future__ import annotations
import datetime
from collections.abc import Mapping
from typing import (
TYPE_CHECKING,
Any,
TypeVar,
cast,
)
from attrs import define as _attrs_define
from attrs import field as _attrs_field
from dateutil.parser import isoparse
if TYPE_CHECKING:
from ..models.biome import Biome
from ..models.m_gnify_sample_detail_metadata import MGnifySampleDetailMetadata
from ..models.m_gnify_study import MGnifyStudy
T = TypeVar("T", bound="MGnifySampleDetail")
[docs]
@_attrs_define
class MGnifySampleDetail:
"""
Attributes:
accession (str):
ena_accessions (list[str]):
sample_title (None | str):
biome (Biome | None):
updated_at (datetime.datetime):
metadata (MGnifySampleDetailMetadata): Metadata associated with the sample, sourced from the ENA Sample record.
studies (list[MGnifyStudy]):
"""
accession: str
ena_accessions: list[str]
sample_title: None | str
biome: Biome | None
updated_at: datetime.datetime
metadata: MGnifySampleDetailMetadata
studies: list[MGnifyStudy]
additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
[docs]
def to_dict(self) -> dict[str, Any]:
from ..models.biome import Biome
accession = self.accession
ena_accessions = self.ena_accessions
sample_title: None | str
sample_title = self.sample_title
biome: dict[str, Any] | None
if isinstance(self.biome, Biome):
biome = self.biome.to_dict()
else:
biome = self.biome
updated_at = self.updated_at.isoformat()
metadata = self.metadata.to_dict()
studies = []
for studies_item_data in self.studies:
studies_item = studies_item_data.to_dict()
studies.append(studies_item)
field_dict: dict[str, Any] = {}
field_dict.update(self.additional_properties)
field_dict.update(
{
"accession": accession,
"ena_accessions": ena_accessions,
"sample_title": sample_title,
"biome": biome,
"updated_at": updated_at,
"metadata": metadata,
"studies": studies,
}
)
return field_dict
[docs]
@classmethod
def from_dict(cls: type[T], src_dict: Mapping[str, Any]) -> T:
from ..models.biome import Biome
from ..models.m_gnify_sample_detail_metadata import MGnifySampleDetailMetadata
from ..models.m_gnify_study import MGnifyStudy
d = dict(src_dict)
accession = d.pop("accession")
ena_accessions = cast(list[str], d.pop("ena_accessions"))
def _parse_sample_title(data: object) -> None | str:
if data is None:
return data
return cast(None | str, data)
sample_title = _parse_sample_title(d.pop("sample_title"))
def _parse_biome(data: object) -> Biome | None:
if data is None:
return data
try:
if not isinstance(data, dict):
raise TypeError()
biome_type_0 = Biome.from_dict(data)
return biome_type_0
except (TypeError, ValueError, AttributeError, KeyError):
pass
return cast(Biome | None, data)
biome = _parse_biome(d.pop("biome"))
updated_at = isoparse(d.pop("updated_at"))
metadata = MGnifySampleDetailMetadata.from_dict(d.pop("metadata"))
studies = []
_studies = d.pop("studies")
for studies_item_data in _studies:
studies_item = MGnifyStudy.from_dict(studies_item_data)
studies.append(studies_item)
m_gnify_sample_detail = cls(
accession=accession,
ena_accessions=ena_accessions,
sample_title=sample_title,
biome=biome,
updated_at=updated_at,
metadata=metadata,
studies=studies,
)
m_gnify_sample_detail.additional_properties = d
return m_gnify_sample_detail
@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