2019-05-11 17:37:47 +09:00
|
|
|
|
from yandex_music import YandexMusicObject
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Cover(YandexMusicObject):
|
2019-07-05 02:21:54 +09:00
|
|
|
|
"""Класс представляющий обложку.
|
|
|
|
|
|
|
|
|
|
Attributes:
|
|
|
|
|
type (:obj:`str`): Тип обложки.
|
|
|
|
|
uri (:obj:`str`): Ссылка на изображение.
|
|
|
|
|
items_uri (:obj:`str`): ССписок ссылок на изображения.
|
|
|
|
|
dir (:obj:`str`): Директория хранения изображения на сервере.
|
|
|
|
|
version (:obj:`str`): Версия.
|
|
|
|
|
custom (:obj:`bool`): Является ли обложка пользовательской.
|
|
|
|
|
prefix (:obj:`str`): Уникальный идентификатор.
|
|
|
|
|
error (:obj:`str`): Сообщение об ошибке.
|
|
|
|
|
client (:obj:`yandex_music.Client`): Объект класса :class:`yandex_music.Client` представляющий клиент Yandex
|
|
|
|
|
Music.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
type (:obj:`str`, optional): Тип обложки.
|
|
|
|
|
uri (:obj:`str`, optional): Ссылка на изображение.
|
|
|
|
|
items_uri (:obj:`str`, optional): ССписок ссылок на изображения.
|
|
|
|
|
dir (:obj:`str`, optional): Директория хранения изображения на сервере.
|
|
|
|
|
version (:obj:`str`, optional): Версия.
|
|
|
|
|
custom (:obj:`bool`, optional): Является ли обложка пользовательской.
|
|
|
|
|
prefix (:obj:`str`, optional): Уникальный идентификатор.
|
|
|
|
|
error (:obj:`str`, optional): Сообщение об ошибке.
|
|
|
|
|
client (:obj:`yandex_music.Client`, optional): Объект класса :class:`yandex_music.Client` представляющий клиент
|
|
|
|
|
Yandex Music.
|
|
|
|
|
**kwargs: Произвольные ключевые аргументы полученные от API.
|
|
|
|
|
"""
|
|
|
|
|
|
2019-05-11 17:37:47 +09:00
|
|
|
|
def __init__(self,
|
2019-06-01 15:04:15 +09:00
|
|
|
|
type=None,
|
New supported objects: Album, CaseForms, Label, Library, MadeFor, Major, Normalization, PlayCounter, Playlist, Track, TrackPosition, TrackShort, User
The following methods are wrapped:
- albums;
- playlists/list;
- users/{user_id}/playlists/list;
- tracks;
- users/{user_id}/likes/tracks.
Added property to get full track ID
Cover received more optional fields
Ability to pass arguments to the request
Removed unnecessary type conversions
2019-05-13 02:39:12 +09:00
|
|
|
|
uri=None,
|
|
|
|
|
items_uri=None,
|
|
|
|
|
dir=None,
|
|
|
|
|
version=None,
|
|
|
|
|
custom=None,
|
|
|
|
|
prefix=None,
|
2019-06-01 15:04:15 +09:00
|
|
|
|
error=None,
|
2019-05-11 17:37:47 +09:00
|
|
|
|
client=None,
|
|
|
|
|
**kwargs):
|
|
|
|
|
self.type = type
|
|
|
|
|
self.uri = uri
|
New supported objects: Album, CaseForms, Label, Library, MadeFor, Major, Normalization, PlayCounter, Playlist, Track, TrackPosition, TrackShort, User
The following methods are wrapped:
- albums;
- playlists/list;
- users/{user_id}/playlists/list;
- tracks;
- users/{user_id}/likes/tracks.
Added property to get full track ID
Cover received more optional fields
Ability to pass arguments to the request
Removed unnecessary type conversions
2019-05-13 02:39:12 +09:00
|
|
|
|
self.items_uri = items_uri
|
|
|
|
|
self.prefix = prefix
|
|
|
|
|
self.dir = dir
|
|
|
|
|
self.version = version
|
|
|
|
|
self.custom = custom
|
2019-06-01 15:04:15 +09:00
|
|
|
|
self.error = error
|
2019-05-11 17:37:47 +09:00
|
|
|
|
|
|
|
|
|
self.client = client
|
|
|
|
|
|
New supported objects: Landing, Block, BlockEntity, Chart, ChartItem, MixLink, PersonalPlaylistsData, PlayContext, PlayContextsData, Promotion, TrackId, TrackShorOld (YEAH!)
The following method are wrapped:
- /landing3
Added the ability to download covers
The following field are optional: Playlist.tags
Now, when parsing json, the "client" key is replaced with "client_"
2019-05-25 02:10:39 +09:00
|
|
|
|
def download(self, filename):
|
2019-07-05 02:21:54 +09:00
|
|
|
|
self.client.request.download(self.uri, filename)
|
New supported objects: Landing, Block, BlockEntity, Chart, ChartItem, MixLink, PersonalPlaylistsData, PlayContext, PlayContextsData, Promotion, TrackId, TrackShorOld (YEAH!)
The following method are wrapped:
- /landing3
Added the ability to download covers
The following field are optional: Playlist.tags
Now, when parsing json, the "client" key is replaced with "client_"
2019-05-25 02:10:39 +09:00
|
|
|
|
|
2019-05-11 17:37:47 +09:00
|
|
|
|
@classmethod
|
|
|
|
|
def de_json(cls, data, client):
|
2019-07-05 02:21:54 +09:00
|
|
|
|
"""Десериализация объекта.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
data (:obj:`dict`): Поля и значения десериализуемого объекта.
|
|
|
|
|
client (:obj:`yandex_music.Client`): Объект класса :class:`yandex_music.Client` представляющий клиент Yandex
|
|
|
|
|
Music.
|
|
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
:obj:`yandex_music.Cover`: Объект класса :class:`yandex_music.Cover`.
|
|
|
|
|
"""
|
2019-05-11 17:37:47 +09:00
|
|
|
|
if not data:
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
data = super(Cover, cls).de_json(data, client)
|
|
|
|
|
|
|
|
|
|
return cls(client=client, **data)
|