yandex-music-api/yandex_music/landing/track_id.py

104 行
3.9 KiB
Python
Raw Blame 履歴

このファイルには曖昧(ambiguous)なUnicode文字が含まれています

このファイルには、他の文字と見間違える可能性があるUnicode文字が含まれています。 それが意図的なものと考えられる場合は、この警告を無視して構いません。 それらの文字を表示するにはエスケープボタンを使用します。

from typing import TYPE_CHECKING, Optional, List
from yandex_music import YandexMusicObject
from yandex_music.utils import model
if TYPE_CHECKING:
from yandex_music import Client, Track
@model
class TrackId(YandexMusicObject):
"""Класс, представляющий уникальный идентификатор трека.
Note:
Поле `track_id` используется только у объектах полученных через очередь треков. В остальные случаях `id`.
Поле `from_` есть только у объект, которые используются в очереди треков.
Attributes:
id (:obj:`int`): Уникальный идентификатор трека.
track_id (:obj:`int`): Уникальный идентификатор трека.
album_id (:obj:`int`, optional): Уникальный идентификатор альбома.
from_ (:obj:`str`, optional): Откуда был получен этот объект.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
"""
id: Optional[int] = None
track_id: Optional[int] = None
album_id: Optional[int] = None
from_: Optional[str] = None
client: Optional['Client'] = None
def __post_init__(self):
self._id_attrs = (self.track_id, self.id, self.album_id)
@property
def track_full_id(self) -> str:
""":obj:`str`: ID трека состоящий из его номера и номера альбома."""
track_id = self.id
if self.track_id:
track_id = self.track_id
return f'{track_id}:{self.album_id}'
def fetch_track(self, *args, **kwargs) -> 'Track':
"""Получение полной версии трека.
Returns:
:obj:`yandex_music.Track`: Полная версия.
"""
return self.client.tracks(self.track_full_id, *args, **kwargs)[0]
async def fetch_track_async(self, *args, **kwargs) -> 'Track':
"""Получение полной версии трека.
Returns:
:obj:`yandex_music.Track`: Полная версия.
"""
return (await self.client.tracks(self.track_full_id, *args, **kwargs))[0]
@classmethod
def de_json(cls, data: dict, client: 'Client') -> Optional['TrackId']:
"""Десериализация объекта.
Args:
data (:obj:`dict`): Поля и значения десериализуемого объекта.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
Returns:
:obj:`yandex_music.TrackId`: Уникальный идентификатор трека.
"""
if not data:
return None
data = super(TrackId, cls).de_json(data, client)
return cls(client=client, **data)
@classmethod
def de_list(cls, data: dict, client: 'Client') -> List['TrackId']:
"""Десериализация списка объектов.
Args:
data (:obj:`list`): Список словарей с полями и значениями десериализуемого объекта.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
Returns:
:obj:`list` из :obj:`yandex_music.TrackId`: Уникальные идентификаторы треков.
"""
if not data:
return []
return [cls.de_json(track_id, client) for track_id in data]
# camelCase псевдонимы
#: Псевдоним для :attr:`track_full_id`
trackFullId = track_full_id
#: Псевдоним для :attr:`fetch_track`
fetchTrack = fetch_track
#: Псевдоним для :attr:`fetch_track_async`
fetchTrackAsync = fetch_track_async