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): Ссылка на изображение.
|
2019-08-18 23:44:46 +09:00
|
|
|
|
items_uri (:obj:`str`, optional): Список ссылок на изображения.
|
2019-07-05 02:21:54 +09:00
|
|
|
|
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
|
2019-08-18 23:44:46 +09:00
|
|
|
|
self._id_attrs = (self.prefix, )
|
2019-05-11 17:37:47 +09:00
|
|
|
|
|
2019-08-18 23:44:46 +09:00
|
|
|
|
def download(self, filename, index=0, size='200x200'):
|
|
|
|
|
"""Загрузка обложки.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
filename (:obj:`str`): Путь для сохранения файла с названием и расширением.
|
|
|
|
|
index (:obj:`int`, optional): Индекс элемента в списке ссылок на обложки если нет self.uri.
|
|
|
|
|
size (:obj:`str`, optional): Размер изображения.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
uri = self.uri or self.items_uri[index]
|
|
|
|
|
|
|
|
|
|
self.client.request.download(f'https://{uri.replace("%%", size)}', 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)
|
Добавлен метод получения информации об артисте (Brief Info https://github.com/MarshalX/yandex-music-api/issues/9).
Добавлены следующие классы: BriefInfo, Description, Vinyl, PlaylistId.
Класс Video вынесен из пакета Search в корень.
Добавлен de_list в Cover.
Добавлены следующие поля в класс Artist: likes_count, full_names, description, countries, en_wikipedia_link, db_aliases, aliases, init_date, end_date.
Добавлено поле track_id в класс Chart.
Добавлено поле available_full_without_permission в класс Track.
Класс Video расширен для поддержки второго типа (используется в brief info, спасибо яндух) видео (добавлены необязательные поля cover, embed_url, provider, provider_video_id).
Обновлена документация.
2019-09-13 00:32:43 +09:00
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
|
def de_list(cls, data, client):
|
|
|
|
|
"""Десериализация списка объектов.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
data (:obj:`list`): Список словарей с полями и значениями десериализуемого объекта.
|
|
|
|
|
client (:obj:`yandex_music.Client`): Объект класса :class:`yandex_music.Client` представляющий клиент Yandex
|
|
|
|
|
Music.
|
|
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
:obj:`list` из :obj:`yandex_music.Cover`: Список объектов класса :class:`yandex_music.Cover`.
|
|
|
|
|
"""
|
|
|
|
|
if not data:
|
|
|
|
|
return []
|
|
|
|
|
|
|
|
|
|
covers = list()
|
|
|
|
|
for cover in data:
|
|
|
|
|
covers.append(cls.de_json(cover, client))
|
|
|
|
|
|
|
|
|
|
return covers
|