tracks_list.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. from typing import TYPE_CHECKING, Iterator, List, 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, Track, TrackShort
  6. @model
  7. class TracksList(YandexMusicModel):
  8. """Класс, представляющий список треков.
  9. Attributes:
  10. uid (:obj:`int`): Уникальный идентификатор пользователя.
  11. revision (:obj:`int`): Актуальность данных TODO.
  12. tracks (:obj:`list` из :obj:`yandex_music.TrackShort`): Список треков в укороченной версии.
  13. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  14. """
  15. uid: int
  16. revision: int
  17. tracks: List['TrackShort']
  18. client: Optional['ClientType'] = None
  19. def __post_init__(self) -> None:
  20. self._id_attrs = (self.uid, self.tracks)
  21. def __getitem__(self, item: int) -> 'TrackShort':
  22. return self.tracks[item]
  23. def __iter__(self) -> Iterator['TrackShort']:
  24. return iter(self.tracks)
  25. def __len__(self) -> int:
  26. return len(self.tracks)
  27. @property
  28. def tracks_ids(self) -> List[str]:
  29. """:obj:`list` из :obj:`str`: Список уникальных идентификаторов треков."""
  30. return [track.track_id for track in self.tracks]
  31. def fetch_tracks(self) -> List['Track']:
  32. """Получение полных версии треков.
  33. Returns:
  34. :obj:`list` из :obj:`yandex_music.Track`: Полная версия трека.
  35. """
  36. assert self.valid_client(self.client)
  37. return self.client.tracks(self.tracks_ids)
  38. async def fetch_tracks_async(self) -> List['Track']:
  39. """Получение полных версии треков.
  40. Returns:
  41. :obj:`list` из :obj:`yandex_music.Track`: Полная версия трека.
  42. """
  43. assert self.valid_async_client(self.client)
  44. return await self.client.tracks(self.tracks_ids)
  45. @classmethod
  46. def de_json(cls, data: 'JSONType', client: 'ClientType') -> Optional['TracksList']:
  47. """Десериализация объекта.
  48. Args:
  49. data (:obj:`dict`): Поля и значения десериализуемого объекта.
  50. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  51. Returns:
  52. :obj:`yandex_music.TracksList`: Список треков.
  53. """
  54. if not cls.is_dict_model_data(data):
  55. return None
  56. cls_data = cls.cleanup_data(data, client)
  57. from yandex_music import TrackShort
  58. cls_data['tracks'] = TrackShort.de_list(data.get('tracks'), client)
  59. return cls(client=client, **cls_data) # type: ignore
  60. # camelCase псевдонимы
  61. #: Псевдоним для :attr:`tracks_ids`
  62. tracksIds = tracks_ids
  63. #: Псевдоним для :attr:`fetch_tracks`
  64. fetchTracks = fetch_tracks
  65. #: Псевдоним для :attr:`fetch_tracks_async`
  66. fetchTracksAsync = fetch_tracks_async