yandex-music-api/yandex_music/feed/event.py

125 行
5.6 KiB
Python
Raw Blame 履歴

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

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

from typing import TYPE_CHECKING, Optional, List
from yandex_music import YandexMusicObject
if TYPE_CHECKING:
from yandex_music import Client, Track, AlbumEvent, ArtistEvent
class Event(YandexMusicObject):
"""Класс, представляющий событие фида.
Note:
Известные значения поля `type_`: `tracks`, `artists`, `albums`, `notification`.
Поле `message` заполнено только когда `type` равен `notification`.
Примером значения поля `type_for_from` может служить `recommended-similar-artists`.
Наличие данных в `tracks`, `albums`, `artists` напрямую зависит от `type_`.
Attributes:
id_ (:obj:`str`): Уникальный идентификатор события.
type_ (:obj:`str`): Тип события.
type_for_from (:obj:`str`): Откуда пришло событие.
title (:obj:`str`): Заголовок.
tracks (:obj:`list` из :obj:`yandex_music.Track`): Список треков.
artists (:obj:`list` из :obj:`yandex_music.ArtistEvent`): Список артистов с похожими и популярными треками.
albums (:obj:`list` из :obj:`yandex_music.AlbumEvent`): Список альбомов с треками.
message (:obj:`str`): Сообщение уведомления.
device (:obj:`str`): Устройство, с которого пришло уведомление.
tracks_count (:obj:`int`): Количество треков (возможно, уже не используется).
genre (:obj:`str`): Жанр треков.
client (:obj:`yandex_music.Client`): Клиент Yandex Music.
Args:
id_ (:obj:`str`): Уникальный идентификатор события.
type_ (:obj:`str`): Тип события.
type_for_from (:obj:`str`, optional): Откуда пришло событие.
title (:obj:`str`, optional): Заголовок.
tracks (:obj:`list` из :obj:`yandex_music.Track`, optional): Список треков.
artists (:obj:`list` из :obj:`yandex_music.ArtistEvent`, optional): Список артистов с похожими и популярными
треками.
albums (:obj:`list` из :obj:`yandex_music.AlbumEvent`, optional): Список альбомов с треками.
message (:obj:`str`, optional): Сообщение уведомления.
device (:obj:`str`, optional): Устройство, с которого пришло уведомление.
tracks_count (:obj:`int`, optional): Количество треков (возможно, уже не используется).
genre (:obj:`str`, optional): Жанр треков.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
**kwargs: Произвольные ключевые аргументы полученные от API.
"""
def __init__(self,
id_: str,
type_: str,
type_for_from: Optional[str] = None,
title: Optional[str] = None,
tracks: List['Track'] = None,
artists: List['ArtistEvent'] = None,
albums: List['AlbumEvent'] = None,
message=None,
device=None,
tracks_count: Optional[int] = None,
genre: Optional[str] = None,
client: Optional['Client'] = None,
**kwargs) -> None:
self.id = id_
self.type = type_
self.type_for_from = type_for_from
self.title = title
self.tracks = tracks
self.albums = albums
self.artists = artists
self.message = message
self.device = device
self.tracks_count = tracks_count
self.genre = genre
self.client = client
self._id_attrs = (self.id, self.type)
super().handle_unknown_kwargs(self, **kwargs)
@classmethod
def de_json(cls, data: dict, client: 'Client') -> Optional['Event']:
"""Десериализация объекта.
Args:
data (:obj:`dict`): Поля и значения десериализуемого объекта.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
Returns:
:obj:`yandex_music.Event`: Событие фида.
"""
if not data:
return None
data = super(Event, cls).de_json(data, client)
from yandex_music import Track, AlbumEvent, ArtistEvent
data['tracks'] = Track.de_list(data.get('tracks'), client)
data['albums'] = AlbumEvent.de_list(data.get('albums'), client)
data['artists'] = ArtistEvent.de_list(data.get('artists'), client)
return cls(client=client, **data)
@classmethod
def de_list(cls, data: dict, client: 'Client') -> List['Event']:
"""Десериализация списка объектов.
Args:
data (:obj:`list`): Список словарей с полями и значениями десериализуемого объекта.
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
Returns:
:obj:`list` из :obj:`yandex_music.Event`: События фида.
"""
if not data:
return []
events = list()
for event in data:
events.append(cls.de_json(event, client))
return events