2019-12-28 22:25:09 +09:00
|
|
|
|
from typing import TYPE_CHECKING, Optional, List, Union
|
2019-12-27 18:14:51 +09:00
|
|
|
|
|
2020-01-26 21:19:22 +09:00
|
|
|
|
from yandex_music import YandexMusicObject
|
2020-02-24 18:01:26 +09:00
|
|
|
|
from yandex_music.exceptions import InvalidBitrate
|
2020-01-26 21:19:22 +09:00
|
|
|
|
|
2019-12-27 18:14:51 +09:00
|
|
|
|
if TYPE_CHECKING:
|
2020-06-06 23:06:23 +09:00
|
|
|
|
from yandex_music import Client, Normalization, Major, Album, Artist, Supplement, DownloadInfo, User, MetaData
|
2019-12-27 18:14:51 +09:00
|
|
|
|
|
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
|
|
|
|
|
|
|
|
|
class Track(YandexMusicObject):
|
2020-03-22 23:43:25 +09:00
|
|
|
|
"""Класс, представляющий трек.
|
|
|
|
|
|
|
|
|
|
Note:
|
|
|
|
|
Известные значения поля `content_warning`: `explicit`.
|
|
|
|
|
|
|
|
|
|
Известные значения поля `type`: `music`.
|
2020-01-26 23:50:54 +09:00
|
|
|
|
|
2020-06-06 23:06:23 +09:00
|
|
|
|
Поля `can_publish`, `state`, `desired_visibility`, `filename`, `user_info` доступны только у треков что были
|
|
|
|
|
загружены пользователем.
|
|
|
|
|
|
2020-01-26 23:50:54 +09:00
|
|
|
|
Attributes:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
id (:obj:`int` | :obj:`str`): Уникальный идентификатор.
|
|
|
|
|
title (:obj:`str`): Название.
|
|
|
|
|
available (:obj:`bool`): Доступен ли для прослушивания.
|
|
|
|
|
artists (:obj:`list` из :obj:`yandex_music.Artist`): Исполнители.
|
|
|
|
|
albums (:obj:`list` из :obj:`yandex_music.Album`): Альбомы.
|
|
|
|
|
available_for_premium_users (:obj:`bool`): Доступен ли для пользователей с подпиской.
|
|
|
|
|
lyrics_available (:obj:`bool`): Доступен ли текст песни.
|
2020-04-17 04:27:48 +09:00
|
|
|
|
best (:obj:`bool`): Лучшей ли трек TODO.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
real_id (:obj:`int` | :obj:`str`): TODO.
|
|
|
|
|
og_image (:obj:`str`): Ссылка на превью Open Graph.
|
|
|
|
|
type (:obj:`str`): Тип.
|
|
|
|
|
cover_uri (:obj:`str`): Ссылка на изображение с обложкой.
|
|
|
|
|
major (:obj:`yandex_music.Major` | :obj:`None`): Мейджор-лейбл.
|
|
|
|
|
duration_ms (:obj:`int`): Длительность трека в миллисекундах.
|
|
|
|
|
storage_dir (:obj:`str`): В какой папке на сервере хранится файл TODO.
|
|
|
|
|
file_size (:obj:`int`): Размер файла. TODO добавить единицу измерения.
|
2020-06-06 23:06:23 +09:00
|
|
|
|
substituted (:obj:`yandex_music.Track`): Замещённый трек.
|
|
|
|
|
matched_track (:obj:`yandex_music.Track`): Соответствующий трек TODO.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
normalization (:obj:`list` из :obj:`yandex_music.Normalization`): Значения для нормализации трека.
|
|
|
|
|
error (:obj:`str`): Сообщение об ошибке.
|
2020-06-06 23:06:23 +09:00
|
|
|
|
can_publish (:obj:`bool`): Может ли быть опубликован.
|
|
|
|
|
state (:obj:`str`): Состояние, например, playable.
|
|
|
|
|
desired_visibility (:obj:`str`): Видимость трека.
|
|
|
|
|
filename (:obj:`str`): Название файла.
|
|
|
|
|
user_info (:obj:`yandex_music.User`): Информация о пользователе, который загрузил трек.
|
|
|
|
|
meta_data (:obj:`yandex_music.MetaData`): Информация о метаданных трека.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
regions (:obj:`list` из :obj:`str`): Регион TODO.
|
|
|
|
|
available_as_rbt (:obj:`bool`): TODO.
|
|
|
|
|
content_warning (:obj:`str`): Тип откровенного контента.
|
|
|
|
|
explicit (:obj:`bool`): Содержит ли откровенный контент.
|
|
|
|
|
preview_duration_ms (:obj:`int`): TODO.
|
|
|
|
|
available_full_without_permission (:obj:`bool`): Доступен ли без подписки.
|
|
|
|
|
version (:obj:`str`): Версия.
|
|
|
|
|
remember_position (:obj:`bool`): TODO.
|
|
|
|
|
download_info (:obj:`list` из :obj:`yandex_music.DownloadInfo`): Информация о вариантах загрузки трека
|
2020-03-22 08:04:39 +09:00
|
|
|
|
client (:obj:`yandex_music.Client`): Клиент Yandex Music.
|
2020-01-26 23:50:54 +09:00
|
|
|
|
|
|
|
|
|
Args:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
id_ (:obj:`int` | :obj:`str`): Уникальный идентификатор.
|
|
|
|
|
title (:obj:`str`, optional): Название.
|
|
|
|
|
available (:obj:`bool`, optional): Доступен ли для прослушивания.
|
|
|
|
|
artists (:obj:`list` из :obj:`yandex_music.Artist`, optional): Исполнители.
|
|
|
|
|
albums (:obj:`list` из :obj:`yandex_music.Album`, optional): Альбомы.
|
|
|
|
|
available_for_premium_users (:obj:`bool`, optional): Доступен ли для пользователей с подпиской.
|
|
|
|
|
lyrics_available (:obj:`bool`, optional): Доступен ли текст песни.
|
2020-04-17 04:27:48 +09:00
|
|
|
|
best (:obj:`bool`, optional): Лучшей ли трек TODO.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
real_id (:obj:`int` | :obj:`str`, optional): TODO.
|
|
|
|
|
og_image (:obj:`str`, optional): Ссылка на превью Open Graph.
|
|
|
|
|
type_ (:obj:`str`, optional): Тип.
|
|
|
|
|
cover_uri (:obj:`str`, optional): Ссылка на изображение с обложкой.
|
|
|
|
|
major (:obj:`yandex_music.Major`, optional): Мейджор-лейбл.
|
|
|
|
|
duration_ms (:obj:`int`, optional): Длительность трека в миллисекундах.
|
|
|
|
|
storage_dir (:obj:`str`, optional): В какой папке на сервере хранится файл TODO.
|
|
|
|
|
file_size (:obj:`int`, optional): Размер файла. TODO добавить единицу измерения.
|
2020-06-06 23:06:23 +09:00
|
|
|
|
substituted (:obj:`yandex_music.Track`, optional): Замещённый трек.
|
|
|
|
|
matched_track (:obj:`yandex_music.Track`, optional): Соответствующий трек TODO.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
normalization (:obj:`list` из :obj:`yandex_music.Normalization`, optional): Значения для нормализации трека.
|
|
|
|
|
error (:obj:`str`, optional): Сообщение об ошибке.
|
2020-06-06 23:06:23 +09:00
|
|
|
|
can_publish (:obj:`bool`, optional): Может ли быть опубликован.
|
|
|
|
|
state (:obj:`str`, optional): Состояние, например, playable.
|
|
|
|
|
desired_visibility (:obj:`str`, optional): Видимость трека.
|
|
|
|
|
filename (:obj:`str`, optional): Название файла.
|
|
|
|
|
user_info (:obj:`yandex_music.User`, optional): Информация о пользователе, который загрузил трек.
|
|
|
|
|
meta_data (:obj:`yandex_music.MetaData`, optional): Информация о метаданных трека.
|
2020-03-22 23:43:25 +09:00
|
|
|
|
regions (:obj:`list` из :obj:`str`, optional): Регион TODO.
|
|
|
|
|
available_as_rbt (:obj:`bool`, optional): TODO.
|
|
|
|
|
content_warning (:obj:`str`, optional): Тип откровенного контента.
|
|
|
|
|
explicit (:obj:`bool`, optional): Содержит ли откровенный контент.
|
|
|
|
|
preview_duration_ms (:obj:`int`, optional): TODO.
|
|
|
|
|
available_full_without_permission (:obj:`bool`, optional): Доступен ли без подписки.
|
|
|
|
|
version (:obj:`str`, optional): Версия.
|
|
|
|
|
remember_position (:obj:`bool`, optional): TODO.
|
|
|
|
|
client (:obj:`yandex_music.Client`): Клиент Yandex Music.
|
2020-01-26 23:50:54 +09:00
|
|
|
|
**kwargs: Произвольные ключевые аргументы полученные от API.
|
|
|
|
|
"""
|
|
|
|
|
|
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
|
|
|
|
def __init__(self,
|
2019-12-28 22:25:09 +09:00
|
|
|
|
id_: Union[str, int],
|
2020-03-22 23:43:25 +09:00
|
|
|
|
title: Optional[str] = None,
|
|
|
|
|
available: Optional[bool] = None,
|
|
|
|
|
artists: List['Artist'] = None,
|
|
|
|
|
albums: List['Album'] = None,
|
2019-12-28 22:25:09 +09:00
|
|
|
|
available_for_premium_users: Optional[bool] = None,
|
|
|
|
|
lyrics_available: Optional[bool] = None,
|
2020-04-17 04:27:48 +09:00
|
|
|
|
best: Optional[bool] = None,
|
2019-12-28 22:25:09 +09:00
|
|
|
|
real_id: Optional[Union[str, int]] = None,
|
|
|
|
|
og_image: Optional[str] = None,
|
|
|
|
|
type_: Optional[str] = None,
|
|
|
|
|
cover_uri: Optional[str] = None,
|
|
|
|
|
major: Optional['Major'] = None,
|
|
|
|
|
duration_ms: Optional[int] = None,
|
|
|
|
|
storage_dir: Optional[str] = None,
|
|
|
|
|
file_size: Optional[int] = None,
|
2020-06-06 23:06:23 +09:00
|
|
|
|
substituted: Optional['Track'] = None,
|
|
|
|
|
matched_track: Optional['Track'] = None,
|
2019-12-28 22:25:09 +09:00
|
|
|
|
normalization: Optional['Normalization'] = None,
|
2020-03-22 23:43:25 +09:00
|
|
|
|
error: Optional[str] = None,
|
2020-06-06 23:06:23 +09:00
|
|
|
|
can_publish: Optional[bool] = None,
|
|
|
|
|
state: Optional[str] = None,
|
|
|
|
|
desired_visibility: Optional[str] = None,
|
|
|
|
|
filename: Optional[str] = None,
|
|
|
|
|
user_info: Optional['User'] = None,
|
|
|
|
|
meta_data: Optional['MetaData'] = None,
|
2020-03-22 23:43:25 +09:00
|
|
|
|
regions: Optional[List[str]] = None,
|
|
|
|
|
available_as_rbt: Optional[bool] = None,
|
|
|
|
|
content_warning: Optional[str] = None,
|
|
|
|
|
explicit: Optional[bool] = None,
|
2019-12-28 22:25:09 +09:00
|
|
|
|
preview_duration_ms: Optional[int] = None,
|
|
|
|
|
available_full_without_permission: Optional[bool] = None,
|
2020-03-11 07:13:14 +09:00
|
|
|
|
version: Optional[str] = None,
|
|
|
|
|
remember_position: Optional[bool] = None,
|
2019-12-27 18:14:51 +09:00
|
|
|
|
client: Optional['Client'] = None,
|
|
|
|
|
**kwargs) -> None:
|
2019-12-27 04:51:29 +09:00
|
|
|
|
self.id = id_
|
2020-04-17 04:27:48 +09:00
|
|
|
|
|
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.title = title
|
|
|
|
|
self.available = available
|
|
|
|
|
self.artists = artists
|
|
|
|
|
self.albums = albums
|
2019-12-01 20:25:09 +09:00
|
|
|
|
self.available_for_premium_users = available_for_premium_users
|
|
|
|
|
self.lyrics_available = lyrics_available
|
2020-04-17 04:27:48 +09:00
|
|
|
|
self.best = best
|
New supported objects: Search, Suggestions, Video, Best, AlbumSearchResult, ArtistSearchResult, PlaylistSearchResult, TrackSearchResult, VideoSearchResult,
The following methods are wrapped:
- /search
- /search/suggest
The following classes received optional fields instead of required ones: Album, Artist, Playlist, Track
Added "params" arg to the GET request
Code refactoring
2019-05-18 01:20:34 +09:00
|
|
|
|
self.real_id = real_id
|
|
|
|
|
self.og_image = og_image
|
2019-12-27 04:51:29 +09:00
|
|
|
|
self.type = type_
|
2019-08-18 23:44:46 +09:00
|
|
|
|
self.cover_uri = cover_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.major = major
|
|
|
|
|
self.duration_ms = duration_ms
|
|
|
|
|
self.storage_dir = storage_dir
|
|
|
|
|
self.file_size = file_size
|
2020-06-06 23:06:23 +09:00
|
|
|
|
self.substituted = substituted
|
|
|
|
|
self.matched_track = matched_track
|
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.normalization = normalization
|
|
|
|
|
self.error = error
|
2020-06-06 23:06:23 +09:00
|
|
|
|
self.can_publish = can_publish
|
|
|
|
|
self.state = state
|
|
|
|
|
self.desired_visibility = desired_visibility
|
|
|
|
|
self.filename = filename
|
|
|
|
|
self.user_info = user_info
|
|
|
|
|
self.meta_data = meta_data
|
New supported objects: Search, Suggestions, Video, Best, AlbumSearchResult, ArtistSearchResult, PlaylistSearchResult, TrackSearchResult, VideoSearchResult,
The following methods are wrapped:
- /search
- /search/suggest
The following classes received optional fields instead of required ones: Album, Artist, Playlist, Track
Added "params" arg to the GET request
Code refactoring
2019-05-18 01:20:34 +09:00
|
|
|
|
self.regions = regions
|
|
|
|
|
self.available_as_rbt = available_as_rbt
|
|
|
|
|
self.content_warning = content_warning
|
|
|
|
|
self.explicit = explicit
|
New supported objects: Station, StationResult, StationTrackResult, Value, Sequence, RotorSettings, Restrictions, Id, Enum, DiscreteScale, DashBoard, AdParams
The following methods are wrapped:
- /rotor/account/status
- /rotor/stations/dashboard
- /rotor/stations/list
- /rotor/station/genre:{genre}/feedback
- /rotor/station/genre:{genre}/info
- /rotor/station/genre:{genre}/tracks
The following fields are now optional: Account[region, passport_phones], Status[cache_limit, subeditor, subeditor_level, plus], Subscription[auto_renewable, can_start_trial, mcdonalds]
Added new fields: Subscription.end, Status[skips_per_hour, station_exists, premium_region], Track..preview_duration_ms
Fixed downloading the cover of the track
2019-06-03 22:16:24 +09:00
|
|
|
|
self.preview_duration_ms = preview_duration_ms
|
Добавлен метод получения информации об артисте (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
|
|
|
|
self.available_full_without_permission = available_full_without_permission
|
2020-03-11 07:13:14 +09:00
|
|
|
|
self.version = version
|
|
|
|
|
self.remember_position = remember_position
|
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
|
|
|
|
|
2019-05-23 18:10:14 +09:00
|
|
|
|
self.download_info = 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
|
|
|
|
self.client = client
|
2020-04-17 04:27:48 +09:00
|
|
|
|
self._id_attrs = (self.id,)
|
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
|
|
|
|
|
2020-05-16 04:14:44 +09:00
|
|
|
|
super().handle_unknown_kwargs(self, **kwargs)
|
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def get_download_info(self, get_direct_links=False) -> List['DownloadInfo']:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
"""Сокращение для::
|
|
|
|
|
|
|
|
|
|
client.tracks_download_info(self.track_id, get_direct_links)
|
|
|
|
|
"""
|
2019-05-23 18:10:14 +09:00
|
|
|
|
self.download_info = self.client.tracks_download_info(self.track_id, get_direct_links)
|
|
|
|
|
|
|
|
|
|
return self.download_info
|
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def get_supplement(self, *args, **kwargs) -> Optional['Supplement']:
|
2019-10-17 12:35:24 +09:00
|
|
|
|
"""Сокращение для::
|
|
|
|
|
|
2019-10-19 05:44:17 +09:00
|
|
|
|
client.track_supplement(track.id, *args, **kwargs)
|
2019-10-17 12:35:24 +09:00
|
|
|
|
"""
|
2019-10-19 05:44:17 +09:00
|
|
|
|
return self.client.track_supplement(self.id, *args, **kwargs)
|
2019-10-17 05:10:52 +09:00
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def download_cover(self, filename: str, size: str = '200x200') -> None:
|
2019-08-18 23:44:46 +09:00
|
|
|
|
"""Загрузка обложки.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
filename (:obj:`str`): Путь для сохранения файла с названием и расширением.
|
|
|
|
|
size (:obj:`str`, optional): Размер обложки.
|
|
|
|
|
"""
|
|
|
|
|
self.client.request.download(f'https://{self.cover_uri.replace("%%", size)}', filename)
|
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def download_og_image(self, filename: str, size: str = '200x200') -> None:
|
2019-08-18 23:44:46 +09:00
|
|
|
|
"""Загрузка обложки.
|
|
|
|
|
|
2020-01-26 21:19:22 +09:00
|
|
|
|
Предпочтительнее использовать `self.download_cover()`.
|
2019-08-18 23:44:46 +09:00
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
filename (:obj:`str`): Путь для сохранения файла с названием и расширением.
|
|
|
|
|
size (:obj:`str`, optional): Размер обложки.
|
|
|
|
|
"""
|
2019-11-08 04:52:26 +09:00
|
|
|
|
self.client.request.download(f'https://{self.og_image.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-12-28 22:25:09 +09:00
|
|
|
|
def download(self, filename: str, codec: str = 'mp3', bitrate_in_kbps: int = 192) -> None:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
"""Загрузка трека.
|
|
|
|
|
|
|
|
|
|
Note:
|
|
|
|
|
Известные значения `codec`: `mp3`, `aac`.
|
|
|
|
|
|
|
|
|
|
Известные значения `bitrate_in_kbps`: `64`, `128`, `192`, `320`.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
filename (:obj:`str`): Путь для сохранения файла с названием и расширением.
|
|
|
|
|
codec (:obj:`str`, optional): Кодек из доступных в `self.download_info`.
|
|
|
|
|
bitrate_in_kbps (:obj:`int`, optional): Битрейт из доступных в `self.download_info` для данного кодека.
|
|
|
|
|
|
|
|
|
|
Raises:
|
|
|
|
|
:class:`yandex_music.exceptions.InvalidBitrate`: Если в `self.download_info` не найден подходящий трек.
|
|
|
|
|
"""
|
2019-05-23 18:10:14 +09:00
|
|
|
|
if self.download_info is None:
|
|
|
|
|
self.get_download_info()
|
|
|
|
|
|
|
|
|
|
for info in self.download_info:
|
|
|
|
|
if info.codec == codec and info.bitrate_in_kbps == bitrate_in_kbps:
|
|
|
|
|
info.download(filename)
|
2020-02-24 18:01:26 +09:00
|
|
|
|
break
|
|
|
|
|
else:
|
|
|
|
|
raise InvalidBitrate('Unavailable bitrate')
|
2019-05-23 18:10:14 +09:00
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def like(self, *args, **kwargs) -> bool:
|
2019-10-07 02:06:28 +09:00
|
|
|
|
"""Сокращение для::
|
|
|
|
|
|
2019-10-19 05:44:17 +09:00
|
|
|
|
client.users_likes_tracks_add(track.id, user.id, *args, **kwargs)
|
2019-10-07 02:06:28 +09:00
|
|
|
|
"""
|
2019-12-24 06:20:07 +09:00
|
|
|
|
return self.client.users_likes_tracks_add(self.track_id, self.client.me.account.uid, *args, **kwargs)
|
2019-10-07 02:06:28 +09:00
|
|
|
|
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def dislike(self, *args, **kwargs) -> bool:
|
2019-10-07 02:06:28 +09:00
|
|
|
|
"""Сокращение для::
|
|
|
|
|
|
|
|
|
|
client.users_likes_tracks_remove(track.id, user.id *args, **kwargs)
|
|
|
|
|
"""
|
2019-12-24 06:20:07 +09:00
|
|
|
|
return self.client.users_likes_tracks_remove(self.track_id, self.client.me.account.uid, *args, **kwargs)
|
2019-10-07 02:06:28 +09:00
|
|
|
|
|
2019-05-19 05:59:14 +09:00
|
|
|
|
@property
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def track_id(self) -> str:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
""":obj:`str`: Уникальный идентификатор трека состоящий из его номера и номера альбома или просто из номера."""
|
2020-01-23 00:08:08 +09:00
|
|
|
|
if self.albums:
|
|
|
|
|
return f'{self.id}:{self.albums[0].id}'
|
2019-05-19 05:59:14 +09:00
|
|
|
|
return f'{self.id}'
|
|
|
|
|
|
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
|
|
|
|
@classmethod
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def de_json(cls, data: dict, client: 'Client') -> Optional['Track']:
|
2020-01-26 22:17:09 +09:00
|
|
|
|
"""Десериализация объекта.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
data (:obj:`dict`): Поля и значения десериализуемого объекта.
|
Удаление избыточной информации (#247)
Классы: Account, AutoRenewable, PassportPhone, Permissions, Plus, Price,
Product, Status, Subscription, UserSettings, Album, Label,
TrackPosition, Playlist
У всех классов изменено описание атрибута client
2020-03-22 04:49:20 +09:00
|
|
|
|
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
|
2020-01-26 22:17:09 +09:00
|
|
|
|
|
|
|
|
|
Returns:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
:obj:`yandex_music.Track`: Трек.
|
2020-01-26 22:17:09 +09:00
|
|
|
|
"""
|
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
|
|
|
|
if not data:
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
data = super(Track, cls).de_json(data, client)
|
2020-06-06 23:06:23 +09:00
|
|
|
|
from yandex_music import Normalization, Major, Album, Artist, User, MetaData
|
2019-10-27 23:14:11 +09:00
|
|
|
|
data['albums'] = Album.de_list(data.get('albums'), client)
|
|
|
|
|
data['artists'] = Artist.de_list(data.get('artists'), client)
|
2019-06-03 01:23:29 +09:00
|
|
|
|
data['normalization'] = Normalization.de_json(data.get('normalization'), client)
|
|
|
|
|
data['major'] = Major.de_json(data.get('major'), client)
|
2020-06-06 23:06:23 +09:00
|
|
|
|
data['substituted'] = Track.de_json(data.get('substituted'), client)
|
|
|
|
|
data['matched_track'] = Track.de_json(data.get('matched_track'), client)
|
|
|
|
|
data['user_info'] = User.de_json(data.get('user_info'), client)
|
|
|
|
|
data['meta_data'] = MetaData.de_json(data.get('meta_data'), client)
|
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
|
|
|
|
|
|
|
|
|
return cls(client=client, **data)
|
|
|
|
|
|
|
|
|
|
@classmethod
|
2019-12-28 22:25:09 +09:00
|
|
|
|
def de_list(cls, data: dict, client: 'Client') -> List['Track']:
|
2020-01-26 22:17:09 +09:00
|
|
|
|
"""Десериализация списка объектов.
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
data (:obj:`list`): Список словарей с полями и значениями десериализуемого объекта.
|
Удаление избыточной информации (#247)
Классы: Account, AutoRenewable, PassportPhone, Permissions, Plus, Price,
Product, Status, Subscription, UserSettings, Album, Label,
TrackPosition, Playlist
У всех классов изменено описание атрибута client
2020-03-22 04:49:20 +09:00
|
|
|
|
client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
|
2020-01-26 22:17:09 +09:00
|
|
|
|
|
|
|
|
|
Returns:
|
2020-03-22 23:43:25 +09:00
|
|
|
|
:obj:`list` из :obj:`yandex_music.Track`: Треки.
|
2020-01-26 22:17:09 +09:00
|
|
|
|
"""
|
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
|
|
|
|
if not data:
|
|
|
|
|
return []
|
|
|
|
|
|
2020-06-06 23:06:23 +09:00
|
|
|
|
return [cls.de_json(track, client) for track in data]
|
2019-08-18 18:54:13 +09:00
|
|
|
|
|
|
|
|
|
# camelCase псевдонимы
|
|
|
|
|
|
2019-10-19 17:55:45 +09:00
|
|
|
|
#: Псевдоним для :attr:`get_download_info`
|
2019-08-18 18:54:13 +09:00
|
|
|
|
getDownloadInfo = get_download_info
|
2019-10-19 17:55:45 +09:00
|
|
|
|
#: Псевдоним для :attr:`get_supplement`
|
2019-10-19 05:44:17 +09:00
|
|
|
|
getSupplement = get_supplement
|
2019-10-19 17:55:45 +09:00
|
|
|
|
#: Псевдоним для :attr:`download_cover`
|
2019-08-18 18:54:13 +09:00
|
|
|
|
downloadCover = download_cover
|
2019-10-19 17:55:45 +09:00
|
|
|
|
#: Псевдоним для :attr:`download_og_image`
|
2019-08-18 23:44:46 +09:00
|
|
|
|
downloadOgImage = download_og_image
|
2019-10-19 17:55:45 +09:00
|
|
|
|
#: Псевдоним для :attr:`track_id`
|
2019-08-18 18:54:13 +09:00
|
|
|
|
trackId = track_id
|