Source code for mgnipy.emgapi_v2_client.models.analysed_run_detail

from __future__ import annotations

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 ..types import (
    UNSET,
    Unset,
)

if TYPE_CHECKING:
    from ..models.m_gnify_sample import MGnifySample
    from ..models.m_gnify_study import MGnifyStudy


T = TypeVar("T", bound="AnalysedRunDetail")


[docs] @_attrs_define class AnalysedRunDetail: """ Attributes: experiment_type (str): Experiment type refers to the type of sequencing data that was analysed, e.g. amplicon reads or a metagenome assembly instrument_model (None | str): instrument_platform (None | str): sample (MGnifySample | None): study (MGnifyStudy | None): accession (None | str | Unset): sample_accession (None | str | Unset): ENA accession of the sample associated with this run study_accession (None | str | Unset): ENA accession of the study associated with this run """ experiment_type: str instrument_model: None | str instrument_platform: None | str sample: MGnifySample | None study: MGnifyStudy | None accession: None | str | Unset = UNSET sample_accession: None | str | Unset = UNSET study_accession: None | str | Unset = UNSET additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
[docs] def to_dict(self) -> dict[str, Any]: from ..models.m_gnify_sample import MGnifySample from ..models.m_gnify_study import MGnifyStudy experiment_type = self.experiment_type instrument_model: None | str instrument_model = self.instrument_model instrument_platform: None | str instrument_platform = self.instrument_platform sample: dict[str, Any] | None if isinstance(self.sample, MGnifySample): sample = self.sample.to_dict() else: sample = self.sample study: dict[str, Any] | None if isinstance(self.study, MGnifyStudy): study = self.study.to_dict() else: study = self.study accession: None | str | Unset if isinstance(self.accession, Unset): accession = UNSET else: accession = self.accession sample_accession: None | str | Unset if isinstance(self.sample_accession, Unset): sample_accession = UNSET else: sample_accession = self.sample_accession study_accession: None | str | Unset if isinstance(self.study_accession, Unset): study_accession = UNSET else: study_accession = self.study_accession field_dict: dict[str, Any] = {} field_dict.update(self.additional_properties) field_dict.update( { "experiment_type": experiment_type, "instrument_model": instrument_model, "instrument_platform": instrument_platform, "sample": sample, "study": study, } ) if accession is not UNSET: field_dict["accession"] = accession if sample_accession is not UNSET: field_dict["sample_accession"] = sample_accession if study_accession is not UNSET: field_dict["study_accession"] = study_accession return field_dict
[docs] @classmethod def from_dict(cls: type[T], src_dict: Mapping[str, Any]) -> T: from ..models.m_gnify_sample import MGnifySample from ..models.m_gnify_study import MGnifyStudy d = dict(src_dict) experiment_type = d.pop("experiment_type") def _parse_instrument_model(data: object) -> None | str: if data is None: return data return cast(None | str, data) instrument_model = _parse_instrument_model(d.pop("instrument_model")) def _parse_instrument_platform(data: object) -> None | str: if data is None: return data return cast(None | str, data) instrument_platform = _parse_instrument_platform(d.pop("instrument_platform")) def _parse_sample(data: object) -> MGnifySample | None: if data is None: return data try: if not isinstance(data, dict): raise TypeError() sample_type_0 = MGnifySample.from_dict(data) return sample_type_0 except (TypeError, ValueError, AttributeError, KeyError): pass return cast(MGnifySample | None, data) sample = _parse_sample(d.pop("sample")) def _parse_study(data: object) -> MGnifyStudy | None: if data is None: return data try: if not isinstance(data, dict): raise TypeError() study_type_0 = MGnifyStudy.from_dict(data) return study_type_0 except (TypeError, ValueError, AttributeError, KeyError): pass return cast(MGnifyStudy | None, data) study = _parse_study(d.pop("study")) def _parse_accession(data: object) -> None | str | Unset: if data is None: return data if isinstance(data, Unset): return data return cast(None | str | Unset, data) accession = _parse_accession(d.pop("accession", UNSET)) def _parse_sample_accession(data: object) -> None | str | Unset: if data is None: return data if isinstance(data, Unset): return data return cast(None | str | Unset, data) sample_accession = _parse_sample_accession(d.pop("sample_accession", UNSET)) def _parse_study_accession(data: object) -> None | str | Unset: if data is None: return data if isinstance(data, Unset): return data return cast(None | str | Unset, data) study_accession = _parse_study_accession(d.pop("study_accession", UNSET)) analysed_run_detail = cls( experiment_type=experiment_type, instrument_model=instrument_model, instrument_platform=instrument_platform, sample=sample, study=study, accession=accession, sample_accession=sample_accession, study_accession=study_accession, ) analysed_run_detail.additional_properties = d return analysed_run_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