shot.py 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. from typing import TYPE_CHECKING, Optional
  2. from yandex_music import YandexMusicModel
  3. from yandex_music.utils import model
  4. if TYPE_CHECKING:
  5. from yandex_music import ClientType, JSONType, ShotData
  6. @model
  7. class Shot(YandexMusicModel):
  8. """Класс, представляющий шот от Алисы.
  9. Note:
  10. Известные значения поля `status`: `ready`.
  11. Attributes:
  12. order (:obj:`int`): Порядковый номер при воспроизведении.
  13. played (:obj:`bool`): Был ли проигран шот.
  14. shot_data (:obj:`yandex_music.ShotData`): Основная информация о шоте.
  15. shot_id (:obj:`str`): Уникальный идентификатор шота.
  16. status (:obj:`str`): Статус шота.
  17. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  18. """
  19. order: int
  20. played: bool
  21. shot_data: 'ShotData'
  22. shot_id: str
  23. status: str
  24. client: Optional['ClientType'] = None
  25. def __post_init__(self) -> None:
  26. self._id_attrs = (self.order, self.played, self.shot_data, self.shot_id, self.status)
  27. @classmethod
  28. def de_json(cls, data: 'JSONType', client: 'ClientType') -> Optional['Shot']:
  29. """Десериализация объекта.
  30. Args:
  31. data (:obj:`dict`): Поля и значения десериализуемого объекта.
  32. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  33. Returns:
  34. :obj:`yandex_music.Shot`: Шот от Алисы.
  35. """
  36. if not cls.is_dict_model_data(data):
  37. return None
  38. cls_data = cls.cleanup_data(data, client)
  39. from yandex_music import ShotData
  40. cls_data['shot_data'] = ShotData.de_json(data.get('shot_data'), client)
  41. return cls(client=client, **cls_data) # type: ignore