1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605 |
- import functools
- import logging
- from datetime import datetime
- from typing import TYPE_CHECKING, Any, Callable, List, Optional, TypeVar, Union, cast
- from yandex_music import (
- Album,
- Artist,
- ArtistAlbums,
- ArtistTracks,
- BriefInfo,
- ChartInfo,
- Dashboard,
- DownloadInfo,
- Experiments,
- Feed,
- Genre,
- Landing,
- LandingList,
- Like,
- PermissionAlerts,
- Playlist,
- PlaylistRecommendations,
- PromoCodeStatus,
- Queue,
- QueueItem,
- Search,
- Settings,
- ShotEvent,
- SimilarTracks,
- StationResult,
- StationTracksResult,
- Status,
- Suggestions,
- Supplement,
- TagResult,
- Track,
- TrackLyrics,
- TracksList,
- UserSettings,
- YandexMusicObject,
- __copyright__,
- __license__,
- __version__,
- )
- if TYPE_CHECKING:
- from yandex_music.base import JSONType
- from yandex_music.exceptions import BadRequestError
- from yandex_music.utils.difference import Difference
- from yandex_music.utils.request import Request
- from yandex_music.utils.sign_request import get_sign_request
- de_list = {
- 'artist': Artist.de_list,
- 'album': Album.de_list,
- 'track': Track.de_list,
- 'playlist': Playlist.de_list,
- }
- logging.getLogger(__name__).addHandler(logging.NullHandler())
- F = TypeVar('F', bound=Callable[..., Any])
- UserIdType = Optional[Union[str, int]]
- TimestampType = Optional[Union[str, float, int]]
- def log(method: F) -> F:
- logger = logging.getLogger(method.__module__)
- @functools.wraps(method)
- def wrapper(*args: Any, **kwargs: Any) -> Any: # noqa: ANN401:
- logger.debug(f'Entering: {method.__name__}')
- result = method(*args, **kwargs)
- logger.debug(result)
- logger.debug(f'Exiting: {method.__name__}')
- return result
- return wrapper
- class Client(YandexMusicObject):
- """Класс, представляющий клиент Yandex Music.
- Note:
- Доступные языки: en, uz, uk, us, ru, kk, hy.
- Поле `device` используется только при работе с очередью прослушивания.
- Attributes:
- logger (:obj:`logging.Logger`): Объект логгера.
- token (:obj:`str`): Уникальный ключ для аутентификации.
- base_url (:obj:`str`): Ссылка на API Yandex Music.
- me (:obj:`yandex_music.Status`): Информация об аккаунте.
- device (:obj:`str`): Строка, содержащая сведения об устройстве, с которого выполняются запросы.
- report_unknown_fields (:obj:`bool`): Включены ли предупреждения о неизвестных полях от API,
- которых нет в библиотеке.
- Args:
- token (:obj:`str`, optional): Уникальный ключ для аутентификации.
- base_url (:obj:`str`, optional): Ссылка на API Yandex Music.
- request (:obj:`yandex_music.utils.request.Request`, optional): Пре-инициализация
- :class:`yandex_music.utils.request.Request`.
- language (:obj:`str`, optional): Язык, на котором будут приходить ответы от API. По умолчанию русский.
- report_unknown_fields (:obj:`bool`, optional): Включить предупреждения о неизвестных полях от API,
- которых нет в библиотеке.
- """
- __notice_displayed = True # больше не используется
- def __init__(
- self,
- token: Optional[str] = None,
- base_url: Optional[str] = None,
- request: Optional[Request] = None,
- language: str = 'ru',
- report_unknown_fields: bool = False,
- ) -> None:
- if not Client.__notice_displayed:
- print(f'Yandex Music API v{__version__}, {__copyright__}')
- print(f'Licensed under the terms of the {__license__}', end='\n\n')
- Client.__notice_displayed = True
- self.logger = logging.getLogger(__name__)
- self.token = token
- if base_url is None:
- base_url = 'https://api.music.yandex.net'
- self.base_url = base_url
- self.report_unknown_fields = report_unknown_fields
- if request:
- self._request = request
- self._request.set_and_return_client(self)
- else:
- self._request = Request(self)
- self.language = language
- self._request.set_language(self.language)
- self.device = (
- 'os=Python; os_version=; manufacturer=Marshal; '
- 'model=Yandex Music API; clid=; device_id=random; uuid=random'
- )
- self.me: Optional['Status'] = None
- self.account_uid: Optional[str] = None
- @property
- def request(self) -> Request:
- """:obj:`yandex_music.utils.request.Request`: Объект вспомогательного класса для отправки запросов."""
- return self._request
- @log
- def init(self) -> 'Client':
- """Получение информацию об аккаунте использующихся в других запросах."""
- self.me = self.account_status()
- if self.me and self.me.account:
- self.account_uid = self.me.account.uid
- return self
- @log
- def account_status(self, *args: Any, **kwargs: Any) -> Optional[Status]:
- """Получение статуса аккаунта. Нет обязательных параметров.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Status` | :obj:`None`: Информация об аккаунте если он валиден, иначе :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/account/status'
- result = self._request.get(url, *args, **kwargs)
- return Status.de_json(result, self)
- @log
- def account_settings(self, *args: Any, **kwargs: Any) -> Optional[UserSettings]:
- """Получение настроек текущего пользователя.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.UserSettings` | :obj:`None`: Настройки пользователя если аккаунт валиден,
- иначе :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/account/settings'
- result = self._request.get(url, *args, **kwargs)
- return UserSettings.de_json(result, self)
- @log
- def account_settings_set(
- self,
- param: Optional[str] = None,
- value: Optional[Union[str, int, bool]] = None,
- data: Optional['JSONType'] = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[UserSettings]:
- """Изменение настроек текущего пользователя.
- Note:
- Доступные названия параметров есть поля в классе :class:`yandex_music.UserSettings`, только в CamelCase.
- Args:
- param (:obj:`str`): Название параметра для изменения.
- value (:obj:`str` | :obj:`int` | :obj:`bool`): Значение параметра.
- data (:obj:`dict`): Словарь параметров и значений для множественного изменения.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.UserSettings` | :obj:`None`: Настройки пользователя или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/account/settings'
- if not data and param:
- data = {param: str(value)}
- result = self._request.post(url, data, *args, **kwargs)
- return UserSettings.de_json(result, self)
- @log
- def settings(self, *args: Any, **kwargs: Any) -> Optional[Settings]:
- """Получение предложений по покупке. Нет обязательных параметров.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Settings` | :obj:`None`: Информацию о предлагаемых продуктах если аккаунт валиден
- или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/settings'
- result = self._request.get(url, *args, **kwargs)
- return Settings.de_json(result, self)
- @log
- def permission_alerts(self, *args: Any, **kwargs: Any) -> Optional[PermissionAlerts]:
- """Получение оповещений. Нет обязательных параметров.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.PermissionAlerts` | :obj:`None`: Оповещения если аккаунт валиден или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/permission-alerts'
- result = self._request.get(url, *args, **kwargs)
- return PermissionAlerts.de_json(result, self)
- @log
- def account_experiments(self, *args: Any, **kwargs: Any) -> Optional[Experiments]:
- """Получение значений экспериментальных функций аккаунта.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Experiments` | :obj:`None`: Состояние экспериментальных функций или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/account/experiments'
- result = self._request.get(url, *args, **kwargs)
- return Experiments.de_json(result, self)
- @log
- def consume_promo_code(
- self, code: str, language: Optional[str] = None, *args, **kwargs
- ) -> Optional[PromoCodeStatus]:
- """Активация промо-кода.
- Note:
- Доступные языки: en, uz, uk, us, ru, kk, hy.
- Args:
- code (:obj:`str`): Промо-код.
- language (:obj:`str`, optional): Язык ответа API в ISO 639-1. По умолчанию язык клиента.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.PromoCodeStatus` | :obj:`None`: Информация об активации промо-кода или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/account/consume-promo-code'
- if not language:
- language = self.language
- result = self._request.post(url, {'code': code, 'language': language}, *args, **kwargs)
- return PromoCodeStatus.de_json(result, self)
- @log
- def feed(self, *args: Any, **kwargs: Any) -> Optional[Feed]:
- """Получение потока информации (фида) подобранного под пользователя. Содержит умные плейлисты.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Feed` | :obj:`None`: Умные плейлисты пользователя или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/feed'
- result = self._request.get(url, *args, **kwargs)
- return Feed.de_json(result, self)
- @log
- def feed_wizard_is_passed(self, *args: Any, **kwargs: Any) -> bool:
- """Получение информации о прохождении визарда.
- Note:
- Временное событие на хэллоуин.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: Прошел ли пользователь визард или нет.
- """
- url = f'{self.base_url}/feed/wizard/is-passed'
- result = self._request.get(url, *args, **kwargs)
- return result.get('is_wizard_passed') or False
- @log
- def landing(self, blocks: Union[str, List[str]], *args: Any, **kwargs: Any) -> Optional[Landing]:
- """Получение лендинг-страницы содержащий блоки с новыми релизами, чартами, плейлистами с новинками и т.д.
- Note:
- Поддерживаемые типы блоков: `personalplaylists`, `promotions`, `new-releases`, `new-playlists`, `mixes`,
- `chart`, `artists`, `albums`, `playlists`, `play_contexts`.
- Args:
- blocks (:obj:`str` | :obj:`list` из :obj:`str`): Блок или список блоков необходимых для выдачи.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Landing` | :obj:`None`: Лендинг-страница или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/landing3'
- params = cast('JSONType', {'blocks': blocks, 'eitherUserId': '10254713668400548221'})
- result = self._request.get(url, params, *args, **kwargs)
- # TODO (MarshalX) что тут делает константа с чьим-то User ID
- # https://github.com/MarshalX/yandex-music-api/issues/553
- return Landing.de_json(result, self)
- @log
- def chart(self, chart_option: str = '', *args: Any, **kwargs: Any) -> Optional[ChartInfo]:
- """Получение чарта.
- Note:
- `chart_option` - это постфикс к запросу из поля `menu` чарта.
- Например, на сайте можно выбрать глобальный (world) чарт или российский (russia).
- Args:
- chart_option (:obj:`str` optional): Параметры чарта.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.ChartInfo`: Чарт.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/landing3/chart'
- if chart_option:
- url = f'{url}/{chart_option}'
- result = self._request.get(url, *args, **kwargs)
- return ChartInfo.de_json(result, self)
- @log
- def new_releases(self, *args: Any, **kwargs: Any) -> Optional[LandingList]:
- """Получение полного списка всех новых релизов (альбомов).
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.LandingList`: Список новых альбомов.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/landing3/new-releases'
- result = self._request.get(url, *args, **kwargs)
- return LandingList.de_json(result, self)
- @log
- def new_playlists(self, *args: Any, **kwargs: Any) -> Optional[LandingList]:
- """Получение полного списка всех новых плейлистов.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.LandingList`: Список новых плейлистов.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/landing3/new-playlists'
- result = self._request.get(url, *args, **kwargs)
- return LandingList.de_json(result, self)
- @log
- def podcasts(self, *args: Any, **kwargs: Any) -> Optional[LandingList]:
- """Получение подкастов с лендинга.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.LandingList`: Список подкастов.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/landing3/podcasts'
- result = self._request.get(url, *args, **kwargs)
- return LandingList.de_json(result, self)
- @log
- def genres(self, *args: Any, **kwargs: Any) -> List[Genre]:
- """Получение жанров музыки.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Genre` | :obj:`None`: Жанры музыки или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/genres'
- result = self._request.get(url, *args, **kwargs)
- return Genre.de_list(result, self)
- @log
- def tags(self, tag_id: str, *args: Any, **kwargs: Any) -> Optional[TagResult]:
- """Получение тега (подборки).
- Note:
- Теги есть в `MixLink` у `Landing`, а также плейлистов в `.tags`.
- У `MixLink` есть `URL`, но `tag_id` только его последняя часть.
- Например, `/tag/belarus/`. `Tag` - `belarus`.
- Args:
- tag_id (:obj:`str`): Уникальный идентификатор тега.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.TagResult`: Тег с плейлистами.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/tags/{tag_id}/playlist-ids'
- result = self._request.get(url, *args, **kwargs)
- return TagResult.de_json(result, self)
- @log
- def tracks_download_info(
- self,
- track_id: Union[str, int],
- get_direct_links: bool = False,
- *args: Any,
- **kwargs: Any,
- ) -> List[DownloadInfo]:
- """Получение информации о доступных вариантах загрузки трека.
- Args:
- track_id (:obj:`str` | :obj:`list` из :obj:`str`): Уникальный идентификатор трека или треков.
- get_direct_links (:obj:`bool`, optional): Получить ли при вызове метода прямую ссылку на загрузку.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.DownloadInfo` | :obj:`None`: Варианты загрузки трека или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/tracks/{track_id}/download-info'
- result = self._request.get(url, *args, **kwargs)
- return DownloadInfo.de_list(result, self, get_direct_links)
- @log
- def track_supplement(self, track_id: Union[str, int], *args: Any, **kwargs: Any) -> Optional[Supplement]:
- """Получение дополнительной информации о треке.
- Warning:
- Получение текста из дополнительной информации устарело. Используйте
- :func:`yandex_music.Client.tracks_lyrics`.
- Args:
- track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор трека.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Supplement`: Дополнительная информация о треке.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/tracks/{track_id}/supplement'
- result = self._request.get(url, *args, **kwargs)
- return Supplement.de_json(result, self)
- @log
- def tracks_lyrics(
- self,
- track_id: Union[str, int],
- format_: str = 'TEXT',
- **kwargs: Any,
- ) -> Optional[TrackLyrics]:
- """Получение текста трека.
- Note:
- Для работы с методом необходима авторизация.
- Известные значения для аргумента format:
- - `LRC` - формат с временными метками.
- - `TEXT` - простой текст.
- Args:
- track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор трека.
- format_ (:obj:`str`): Формат текста.
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.TrackLyrics` | :obj:`None`: Информация о тексте трека.
- Raises:
- :class:`yandex_music.exceptions.UnauthorizedError`: Метод вызван без авторизации.
- :class:`yandex_music.exceptions.NotFoundError`: Текст у трека отсутствует.
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/tracks/{track_id}/lyrics'
- sign = get_sign_request(track_id)
- params = {
- 'format': format_,
- 'timeStamp': sign.timestamp,
- 'sign': sign.value,
- }
- result = self._request.get(url, params=params, **kwargs)
- return TrackLyrics.de_json(result, self)
- @log
- def tracks_similar(self, track_id: Union[str, int], *args: Any, **kwargs: Any) -> Optional[SimilarTracks]:
- """Получение похожих треков.
- Args:
- track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор трека.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.SimilarTracks`: Похожие треки на другой трек.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/tracks/{track_id}/similar'
- result = self._request.get(url, *args, **kwargs)
- return SimilarTracks.de_json(result, self)
- @log
- def play_audio(
- self,
- track_id: Union[str, int],
- from_: str,
- album_id: Union[str, int],
- playlist_id: Optional[str] = None,
- from_cache: bool = False,
- play_id: Optional[str] = None,
- uid: Optional[int] = None,
- timestamp: Optional[str] = None,
- track_length_seconds: int = 0,
- total_played_seconds: int = 0,
- end_position_seconds: int = 0,
- client_now: Optional[str] = None,
- *args: Any,
- **kwargs: Any,
- ) -> bool:
- """Метод для отправки текущего состояния прослушиваемого трека.
- Args:
- track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор трека.
- from_ (:obj:`str`): Наименования клиента с которого происходит прослушивание.
- album_id (:obj:`str` | :obj:`int`): Уникальный идентификатор альбома.
- playlist_id (:obj:`str`, optional): Уникальный идентификатор плейлиста, если таковой прослушивается.
- from_cache (:obj:`bool`, optional): Проигрывается ли трек с кеша.
- play_id (:obj:`str`, optional): Уникальный идентификатор проигрывания.
- uid (:obj:`int`, optional): Уникальный идентификатор пользователя.
- timestamp (:obj:`str`, optional): Текущая дата и время в ISO.
- track_length_seconds (:obj:`int`, optional): Продолжительность трека в секундах.
- total_played_seconds (:obj:`int`, optional): Сколько было всего воспроизведено трека в секундах.
- end_position_seconds (:obj:`int`, optional): Окончательное значение воспроизведенных секунд.
- client_now (:obj:`str`, optional): Текущая дата и время клиента в ISO.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if uid is None and self.account_uid is not None:
- uid = self.account_uid
- url = f'{self.base_url}/play-audio'
- data = {
- 'track-id': track_id,
- 'from-cache': str(from_cache),
- 'from': from_,
- 'play-id': play_id or '',
- 'uid': uid,
- 'timestamp': timestamp or f'{datetime.now().isoformat()}Z',
- 'track-length-seconds': track_length_seconds,
- 'total-played-seconds': total_played_seconds,
- 'end-position-seconds': end_position_seconds,
- 'album-id': album_id,
- 'playlist-id': playlist_id,
- 'client-now': client_now or f'{datetime.now().isoformat()}Z',
- }
- result = self._request.post(url, data, *args, **kwargs)
- return result == 'ok'
- @log
- def albums_with_tracks(self, album_id: Union[str, int], *args: Any, **kwargs: Any) -> Optional[Album]:
- """Получение альбома по его уникальному идентификатору вместе с треками.
- Args:
- album_id (:obj:`str` | :obj:`int`): Уникальный идентификатор альбома.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Album` | :obj:`None`: Альбом или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/albums/{album_id}/with-tracks'
- result = self._request.get(url, *args, **kwargs)
- return Album.de_json(result, self)
- @log
- def search(
- self,
- text: str,
- nocorrect: bool = False,
- type_: str = 'all',
- page: int = 0,
- playlist_in_best: bool = True,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Search]:
- """Осуществление поиска по запросу и типу, получение результатов.
- Note:
- Известные значения для поля `type_`: `all`, `artist`, `user`, `album`, `playlist`, `track`, `podcast`,
- `podcast_episode`.
- При поиске `type=all` не возвращаются подкасты и эпизоды. Указывайте конкретный тип для поиска.
- Args:
- text (:obj:`str`): Текст запроса.
- nocorrect (:obj:`bool`): Если :obj:`False`, то ошибочный запрос будет исправлен. Например, запрос
- "Гражданская абарона" будет исправлен на "Гражданская оборона".
- type_ (:obj:`str`): Среди какого типа искать (трек, плейлист, альбом, исполнитель, пользователь, подкаст).
- page (:obj:`int`): Номер страницы.
- playlist_in_best (:obj:`bool`): Выдавать ли плейлисты лучшим вариантом поиска.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Search` | :obj:`None`: Результаты поиска или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/search'
- params = {
- 'text': text,
- 'nocorrect': str(nocorrect),
- 'type': type_,
- 'page': page,
- 'playlist-in-best': str(playlist_in_best),
- }
- result = self._request.get(url, params, *args, **kwargs)
- if isinstance(result, str):
- raise BadRequestError(result)
- return Search.de_json(result, self)
- @log
- def search_suggest(self, part: str, *args: Any, **kwargs: Any) -> Optional[Suggestions]:
- """Получение подсказок по введенной части поискового запроса.
- Args:
- part (:obj:`str`): Часть поискового запроса.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Suggestions` | :obj:`None`: Подсказки для запроса или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/search/suggest'
- result = self._request.get(url, {'part': part}, *args, **kwargs)
- return Suggestions.de_json(result, self)
- @log
- def users_settings(self, user_id: UserIdType = None, *args: Any, **kwargs: Any) -> Optional[UserSettings]:
- """Получение настроек пользователя.
- Note:
- Для получения настроек пользователя нужно быть авторизованным или владеть `user_id`.
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя чьи настройки хотим
- получить.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.UserSettings` | :obj:`None`: Настройки пользователя или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/settings'
- result = self._request.get(url, *args, **kwargs)
- return UserSettings.de_json(result.get('user_settings'), self)
- @log
- def users_playlists(
- self,
- kind: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Union[Playlist, List[Playlist], None]:
- """Получение плейлиста или списка плейлистов по уникальным идентификаторам.
- Note:
- Если передан один `kind`, то вернётся не список плейлистов, а один плейлист.
- Args:
- kind (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста
- или их список.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Playlist` | :obj:`yandex_music.Playlist` | :obj:`None`:
- Список плейлистов или плейлист, иначе :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- if isinstance(kind, list):
- url = f'{self.base_url}/users/{user_id}/playlists'
- data = {'kinds': kind}
- result = self._request.post(url, data, *args, **kwargs)
- return Playlist.de_list(result, self)
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}'
- result = self._request.get(url, *args, **kwargs)
- return Playlist.de_json(result, self)
- @log
- def users_playlists_recommendations(
- self, kind: Union[str, int], user_id: UserIdType = None, *args: Any, **kwargs: Any
- ) -> Optional[PlaylistRecommendations]:
- """Получение рекомендаций для плейлиста.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- user_id (:obj:`str` | :obj:`int`): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.PlaylistRecommendations` | :obj:`None`: Рекомендации для плейлиста или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}/recommendations'
- result = self._request.get(url, *args, **kwargs)
- return PlaylistRecommendations.de_json(result, self)
- @log
- def users_playlists_create(
- self,
- title: str,
- visibility: str = 'public',
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Создание плейлиста.
- Args:
- title (:obj:`str`): Название.
- visibility (:obj:`str`, optional): Модификатор доступа.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist` | :obj:`None`: Созданный плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/create'
- data = {'title': title, 'visibility': visibility}
- result = self._request.post(url, data, *args, **kwargs)
- return Playlist.de_json(result, self)
- @log
- def users_playlists_delete(
- self, kind: Union[str, int], user_id: UserIdType = None, *args: Any, **kwargs: Any
- ) -> bool:
- """Удаление плейлиста.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}/delete'
- result = self._request.post(url, *args, **kwargs)
- return result == 'ok'
- @log
- def users_playlists_name(
- self,
- kind: Union[str, int],
- name: str,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Изменение названия плейлиста.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- name (:obj:`str`): Новое название.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist` | :obj:`None`: Изменённый плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}/name'
- result = self._request.post(url, {'value': name}, *args, **kwargs)
- return Playlist.de_json(result, self)
- @log
- def users_playlists_visibility(
- self,
- kind: Union[str, int],
- visibility: str,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Изменение видимости плейлиста.
- Note:
- Видимость (`visibility`) может быть задана только одним из двух значений: `private`, `public`.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- visibility (:obj:`str`): Новое название.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist` | :obj:`None`: Изменённый плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}/visibility'
- result = self._request.post(url, {'value': visibility}, *args, **kwargs)
- return Playlist.de_json(result, self)
- @log
- def users_playlists_change(
- self,
- kind: Union[str, int],
- diff: str,
- revision: int = 1,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Изменение плейлиста.
- Note:
- Для получения отличий есть вспомогательный класс :class:`yandex_music.utils.difference.Difference`.
- Так же существуют уже готовые методы-обёртки над операциями.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- revision (:obj:`int`): TODO.
- diff (:obj:`str`): JSON представления отличий старого и нового плейлиста.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist`: Изменённый плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/{kind}/change'
- data = {'kind': kind, 'revision': revision, 'diff': diff}
- result = self._request.post(url, data, *args, **kwargs)
- return Playlist.de_json(result, self)
- @log
- def users_playlists_insert_track(
- self,
- kind: Union[str, int],
- track_id: Union[str, int],
- album_id: Union[str, int],
- at: int = 0,
- revision: int = 1,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Добавление трека в плейлист.
- Note:
- Трек можно вставить с любое место плейлиста задав индекс вставки (аргумент `at`).
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор трека.
- album_id (:obj:`str` | :obj:`int`): Уникальный идентификатор альбома.
- at (:obj:`int`): Индекс для вставки.
- revision (:obj:`int`): TODO.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist`: Изменённый плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- diff = Difference().add_insert(at, {'id': track_id, 'album_id': album_id})
- return self.users_playlists_change(kind, diff.to_json(), revision, user_id, *args, **kwargs)
- @log
- def users_playlists_delete_track(
- self,
- kind: Union[str, int],
- from_: int,
- to: int,
- revision: int = 1,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[Playlist]:
- """Удаление треков из плейлиста.
- Note:
- Для удаление необходимо указать границы с какого по какой элемент (трек) удалить.
- Args:
- kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста.
- from_ (:obj:`int`): С какого индекса.
- to (:obj:`int`): По какой индекс.
- revision (:obj:`int`): TODO.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Playlist` | :obj:`None`: Изменённый плейлист или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- diff = Difference().add_delete(from_, to)
- return self.users_playlists_change(kind, diff.to_json(), revision, user_id, *args, **kwargs)
- @log
- def rotor_account_status(self, *args: Any, **kwargs: Any) -> Optional[Status]:
- """Получение статуса пользователя с дополнительными полями.
- Note:
- Данный статус отличается от обычного наличием дополнительных полей, например, `skips_per_hour`.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Status` | :obj:`None`: Статус пользователя с дополнительными полями от радио или
- :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/account/status'
- result = self._request.get(url, *args, **kwargs)
- return Status.de_json(result, self)
- @log
- def rotor_stations_dashboard(self, *args: Any, **kwargs: Any) -> Optional[Dashboard]:
- """Получение рекомендованных станций текущего пользователя.
- Args:
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Dashboard` | :obj:`None`: Рекомендованные станции или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/stations/dashboard'
- result = self._request.get(url, *args, **kwargs)
- return Dashboard.de_json(result, self)
- @log
- def rotor_stations_list(self, language: Optional[str] = None, *args: Any, **kwargs: Any) -> List[StationResult]:
- """Получение всех радиостанций с настройками пользователя.
- Note:
- Доступные языки: en, uz, uk, us, ru, kk, hy.
- Чтобы определить что за тип станции (жанры, настроения, занятие и т.д.) необходимо смотреть в поле
- `id_for_from`.
- Args:
- language (:obj:`str`, optional): Язык, на котором будет информация о станциях. По умолчанию язык клиента.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.StationResult`: Список станций.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/stations/list'
- if not language:
- language = self.language
- result = self._request.get(url, {'language': language}, *args, **kwargs)
- return StationResult.de_list(result, self)
- @log
- def rotor_station_feedback(
- self,
- station: str,
- type_: str,
- timestamp: TimestampType = None,
- from_: Optional[str] = None,
- batch_id: Optional[str] = None,
- total_played_seconds: Optional[Union[int, float]] = None,
- track_id: Optional[Union[str, int]] = None,
- **kwargs: Any,
- ) -> bool:
- """Отправка обратной связи на действия при прослушивании радио.
- Note:
- Сообщения о начале прослушивания радио, начале и конце трека, его пропуска.
- Известные типы обратной связи: `radioStarted`, `trackStarted`, `trackFinished`, `skip`.
- Пример `station`: `user:onyourwave`, `genre:allrock`.
- Пример `from_`: `mobile-radio-user-123456789`.
- Args:
- station (:obj:`str`): Станция.
- type_ (:obj:`str`): Тип отправляемого отзыва.
- timestamp (:obj:`str` | :obj:`float` | :obj:`int`, optional): Текущее время и дата.
- from_ (:obj:`str`, optional): Откуда начато воспроизведение радио.
- batch_id (:obj:`str`, optional): Уникальный идентификатор партии треков. Возвращается при получении треков.
- total_played_seconds (:obj:`int` |:obj:`float`, optional): Сколько было проиграно секунд трека
- перед действием.
- track_id (:obj:`int` | :obj:`str`, optional): Уникальной идентификатор трека.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if timestamp is None:
- timestamp = datetime.now().timestamp()
- url = f'{self.base_url}/rotor/station/{station}/feedback'
- params = {}
- data = {'type': type_, 'timestamp': timestamp}
- if batch_id:
- params = {'batch-id': batch_id}
- if track_id:
- data.update({'trackId': track_id})
- if from_:
- data.update({'from': from_})
- if total_played_seconds:
- data.update({'totalPlayedSeconds': total_played_seconds})
- result = self._request.post(url, params=params, json=data, **kwargs)
- return result == 'ok'
- @log
- def rotor_station_feedback_radio_started(
- self,
- station: str,
- from_: str,
- batch_id: Optional[str] = None,
- timestamp: TimestampType = None,
- **kwargs: Any,
- ) -> bool:
- """Сокращение для::
- client.rotor_station_feedback(station, 'radioStarted', timestamp, from, batch_id, **kwargs)
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self.rotor_station_feedback(station, 'radioStarted', timestamp, from_=from_, batch_id=batch_id, **kwargs)
- @log
- def rotor_station_feedback_track_started(
- self,
- station: str,
- track_id: Union[str, int],
- batch_id: Optional[str] = None,
- timestamp: TimestampType = None,
- **kwargs: Any,
- ) -> bool:
- """Сокращение для::
- client.rotor_station_feedback(station, 'trackStarted', timestamp, track_id=track_id,
- batch_id=batch_id, **kwargs)
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self.rotor_station_feedback(
- station, 'trackStarted', timestamp, track_id=track_id, batch_id=batch_id, **kwargs
- )
- @log
- def rotor_station_feedback_track_finished(
- self,
- station: str,
- track_id: Union[str, int],
- total_played_seconds: float,
- batch_id: Optional[str] = None,
- timestamp: TimestampType = None,
- **kwargs: Any,
- ) -> bool:
- """Сокращение для::
- client.rotor_station_feedback(station, 'trackFinished', timestamp,
- track_id=track_id, total_played_seconds=total_played_seconds, batch_id=batch_id, **kwargs)
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self.rotor_station_feedback(
- station,
- 'trackFinished',
- timestamp,
- track_id=track_id,
- total_played_seconds=total_played_seconds,
- batch_id=batch_id,
- **kwargs,
- )
- @log
- def rotor_station_feedback_skip(
- self,
- station: str,
- track_id: Union[str, int],
- total_played_seconds: float,
- batch_id: Optional[str] = None,
- timestamp: TimestampType = None,
- **kwargs: Any,
- ) -> bool:
- """Сокращение для::
- client.rotor_station_feedback(station, 'skip', timestamp, track_id=track_id,
- total_played_seconds=total_played_seconds, batch_id=batch_id, **kwargs)
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self.rotor_station_feedback(
- station,
- 'skip',
- timestamp,
- track_id=track_id,
- total_played_seconds=total_played_seconds,
- batch_id=batch_id,
- **kwargs,
- )
- @log
- def rotor_station_info(self, station: str, *args: Any, **kwargs: Any) -> List[StationResult]:
- """Получение информации о станции и пользовательских настроек на неё.
- Args:
- station (:obj:`str`): Станция.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.StationResult` | :obj:`None`: Информация о станции или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/station/{station}/info'
- result = self._request.get(url, *args, **kwargs)
- return StationResult.de_list(result, self)
- @log
- def rotor_station_settings2(
- self,
- station: str,
- mood_energy: str,
- diversity: str,
- language: str = 'not-russian', # TODO(#555): заменить на any
- type_: str = 'rotor',
- **kwargs: Any,
- ) -> bool:
- """Изменение настроек определённой станции.
- Note:
- Доступные значения для `mood_energy`: `fun`, `active`, `calm`, `sad`, `all`.
- Доступные значения для `diversity`: `favorite`, `popular`, `discover`, `default`.
- Доступные значения для `language`: `not-russian`, `russian`, `any`.
- Доступные значения для `type_`: `rotor`, `generative`.
- У станций в `restrictions` есть Enum'ы, а в них `possible_values` - доступные значения для поля.
- Args:
- station (:obj:`str`): Станция.
- mood_energy (:obj:`str`): Настроение.
- diversity (:obj:`str`): Треки.
- language (:obj:`str`): Язык.
- type_ (:obj:`str`): Тип.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/station/{station}/settings3'
- data = {'moodEnergy': mood_energy, 'diversity': diversity, 'type': type_}
- if language:
- data.update({'language': language})
- result = self._request.post(url, json=data, **kwargs)
- return result == 'ok'
- @log
- def rotor_station_tracks(
- self,
- station: str,
- settings2: bool = True,
- queue: Optional[Union[str, int]] = None,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[StationTracksResult]:
- """Получение цепочки треков определённой станции.
- Note:
- Запуск потока по сущности сервиса осуществляется через станцию `<type>:<id>`.
- Например, станцией для запуска потока по треку будет `track:1234`.
- Для продолжения цепочки треков необходимо:
- 1. Передавать `ID` трека, что был до этого (первый в цепочки).
- 2. Отправить фидбек о конце или скипе трека, что был передан в `queue`.
- 3. Отправить фидбек о начале следующего трека (второй в цепочки).
- 4. Выполнить запрос получения треков. В ответе придёт новые треки или произойдёт сдвиг цепочки на 1 элемент.
- Проход по цепочке до конца не изучен. Часто встречаются дубликаты.
- Все официальные клиенты выполняют запросы с `settings2 = True`.
- Args:
- station (:obj:`str`): Станция.
- settings2 (:obj:`bool`, optional): Использовать ли второй набор настроек.
- queue (:obj:`str` | :obj:`int`, optional): Уникальной идентификатор трека, который только что был.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.StationTracksResult` | :obj:`None`: Последовательность треков станции или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/rotor/station/{station}/tracks'
- params = {}
- if settings2:
- params = {'settings2': str(True)}
- if queue:
- params = {'queue': queue}
- result = self._request.get(url, params, *args, **kwargs)
- return StationTracksResult.de_json(result, self)
- @log
- def artists_brief_info(self, artist_id: Union[str, int], *args: Any, **kwargs: Any) -> Optional[BriefInfo]:
- """Получение информации об артисте.
- Args:
- artist_id (:obj:`str` | :obj:`int`): Уникальный идентификатор исполнителя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.BriefInfo` | :obj:`None`: Информация об артисте или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/artists/{artist_id}/brief-info'
- result = self._request.get(url, *args, **kwargs)
- return BriefInfo.de_json(result, self)
- @log
- def artists_tracks(
- self,
- artist_id: Union[str, int],
- page: int = 0,
- page_size: int = 20,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[ArtistTracks]:
- """Получение треков артиста.
- Args:
- artist_id (:obj:`str` | :obj:`int`): Уникальный идентификатор артиста.
- page (:obj:`int`, optional): Номер страницы.
- page_size (:obj:`int`, optional): Количество треков на странице.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.ArtistsTracks` | :obj:`None`: Страница списка треков артиста или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/artists/{artist_id}/tracks'
- params = {'page': page, 'page-size': page_size}
- result = self._request.get(url, params, *args, **kwargs)
- return ArtistTracks.de_json(result, self)
- @log
- def artists_direct_albums(
- self,
- artist_id: Union[str, int],
- page: int = 0,
- page_size: int = 20,
- sort_by: str = 'year',
- *args: Any,
- **kwargs: Any,
- ) -> Optional[ArtistAlbums]:
- """Получение альбомов артиста.
- Note:
- Известные значения для `sort_by`: `year`, `rating`.
- Args:
- artist_id (:obj:`str` | :obj:`int`): Уникальный идентификатор артиста.
- page (:obj:`int`, optional): Номер страницы.
- page_size (:obj:`int`, optional): Количество альбомов на странице.
- sort_by (:obj:`str`, optional): Параметр для сортировки.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.ArtistAlbums` | :obj:`None`: Страница списка альбомов артиста или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/artists/{artist_id}/direct-albums'
- params = {'sort-by': sort_by, 'page': page, 'page-size': page_size}
- result = self._request.get(url, params, *args, **kwargs)
- return ArtistAlbums.de_json(result, self)
- def _like_action(
- self,
- object_type: str,
- ids: Union[List[Union[str, int]], str, int],
- remove: bool = False,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> bool:
- """Действия с отметкой "Мне нравится".
- Note:
- Типы объектов: `track` - трек, `artist` - исполнитель, `playlist` - плейлист, `album` - альбом.
- Идентификатор плейлиста указывается в формате `owner_id:playlist_id`. Где `playlist_id` - идентификатор
- плейлиста, `owner_id` - уникальный идентификатор владельца плейлиста.
- Args:
- object_type (:obj:`str`): Тип объекта.
- ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор объекта или объектов.
- remove (:obj:`bool`, optional): Если :obj:`True` то снимает отметку, иначе ставит.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- action = 'remove' if remove else 'add-multiple'
- url = f'{self.base_url}/users/{user_id}/likes/{object_type}s/{action}'
- result = self._request.post(url, {f'{object_type}-ids': ids}, *args, **kwargs)
- if object_type == 'track':
- return 'revision' in result
- return result == 'ok'
- @log
- def users_likes_tracks_add(
- self,
- track_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Поставить отметку "Мне нравится" треку/трекам.
- Note:
- Так же снимает отметку "Не рекомендовать" если она есть.
- Args:
- track_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор трека или треков.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('track', track_ids, remove=False, user_id=user_id, **kwargs)
- @log
- def users_likes_tracks_remove(
- self,
- track_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Снять отметку "Мне нравится" у трека/треков.
- Args:
- track_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор трека или треков.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('track', track_ids, remove=True, user_id=user_id, **kwargs)
- @log
- def users_likes_artists_add(
- self,
- artist_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Поставить отметку "Мне нравится" исполнителю/исполнителям.
- Args:
- artist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор артиста или артистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('artist', artist_ids, remove=False, user_id=user_id, **kwargs)
- @log
- def users_likes_artists_remove(
- self,
- artist_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Снять отметку "Мне нравится" у исполнителя/исполнителей.
- Args:
- artist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор артиста или артистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('artist', artist_ids, remove=True, user_id=user_id, **kwargs)
- @log
- def users_likes_playlists_add(
- self,
- playlist_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Поставить отметку "Мне нравится" плейлисту/плейлистам.
- Note:
- Идентификатор плейлиста указывается в формате `owner_id:playlist_id`. Где `playlist_id` - идентификатор
- плейлиста, `owner_id` - уникальный идентификатор владельца плейлиста.
- Args:
- playlist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор плейлиста или плейлистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('playlist', playlist_ids, remove=False, user_id=user_id, **kwargs)
- @log
- def users_likes_playlists_remove(
- self,
- playlist_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Снять отметку "Мне нравится" у плейлиста/плейлистов.
- Note:
- Идентификатор плейлиста указывается в формате `owner_id:playlist_id`. Где `playlist_id` - идентификатор
- плейлиста, `owner_id` - уникальный идентификатор владельца плейлиста.
- Args:
- playlist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор плейлиста или плейлистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('playlist', playlist_ids, remove=True, user_id=user_id, **kwargs)
- @log
- def users_likes_albums_add(
- self,
- album_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Поставить отметку "Мне нравится" альбому/альбомам.
- Args:
- album_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор артиста или артистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('album', album_ids, remove=False, user_id=user_id, **kwargs)
- @log
- def users_likes_albums_remove(
- self,
- album_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Снять отметку "Мне нравится" у альбома/альбомов.
- Args:
- album_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор артиста или артистов.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._like_action('album', album_ids, remove=True, user_id=user_id, **kwargs)
- def _get_list(
- self,
- object_type: str,
- ids: Union[List[Union[str, int]], int, str],
- params: Optional['JSONType'] = None,
- *args: Any,
- **kwargs: Any,
- ) -> List[Union[Artist, Album, Track, Playlist]]:
- """Получение объекта/объектов.
- Args:
- object_type (:obj:`str`): Тип объекта.
- ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор объекта или объектов.
- params (:obj:`dict`, optional): Параметры, которые будут переданы в запрос.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Artist` | :obj:`list` из :obj:`yandex_music.Album` |
- :obj:`list` из :obj:`yandex_music.Track` | :obj:`list` из :obj:`yandex_music.Playlist`: Запрошенный
- объект.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if params is None:
- params = {}
- params.update({f'{object_type}-ids': ids})
- url = f'{self.base_url}/{object_type}s' + ('/list' if object_type == 'playlist' else '')
- result = self._request.post(url, params, *args, **kwargs)
- return de_list[object_type](result, self)
- @log
- def artists(self, artist_ids: Union[List[Union[str, int]], int, str], *args: Any, **kwargs: Any) -> List[Artist]:
- """Получение исполнителя/исполнителей.
- Args:
- artist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор исполнителя или исполнителей.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Artist`: Исполнитель или исполнители.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_list('artist', artist_ids, *args, **kwargs)
- @log
- def albums(self, album_ids: Union[List[Union[str, int]], int, str], *args: Any, **kwargs: Any) -> List[Album]:
- """Получение альбома/альбомов.
- Args:
- album_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор альбома или альбомов.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Album`: Альбом или альбомы.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_list('album', album_ids, *args, **kwargs)
- @log
- def tracks(
- self,
- track_ids: Union[List[str], List[int], List[Union[str, int]], int, str],
- with_positions: bool = True,
- *args: Any,
- **kwargs: Any,
- ) -> List[Track]:
- """Получение трека/треков.
- Args:
- track_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор трека или треков.
- with_positions (:obj:`bool`, optional): С позициями TODO.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Track`: Трек или Треки.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_list('track', track_ids, {'with-positions': str(with_positions)}, *args, **kwargs)
- @log
- def playlists_list(
- self, playlist_ids: Union[List[Union[str, int]], int, str], *args: Any, **kwargs: Any
- ) -> List[Playlist]:
- """Получение плейлиста/плейлистов.
- Note:
- Идентификатор плейлиста указывается в формате `owner_id:playlist_id`. Где `playlist_id` - идентификатор
- плейлиста, `owner_id` - уникальный идентификатор владельца плейлиста.
- Данный метод возвращает сокращенную модель плейлиста для отображения больших список.
- Warning:
- Данный метод не возвращает список треков у плейлиста! Для получения объекта :obj:`yandex_music.Playlist` c
- заполненным полем `tracks` используйте метод :func:`yandex_music.Client.users_playlists` или
- метод :func:`yandex_music.Playlist.fetch_tracks`.
- Args:
- playlist_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор плейлиста или плейлистов.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Playlist`: Плейлист или плейлисты.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_list('playlist', playlist_ids, *args, **kwargs)
- @log
- def playlists_collective_join(self, user_id: int, token: str, **kwargs: Any) -> bool:
- """Присоединение к плейлисту как соавтор.
- Note:
- В качестве `user_id` принимается исключительно числовой уникальный идентификатор пользователя, не username.
- Токен можно получить в Web-версии. Для этого, на странице плейлиста нужно нажать на
- "Добавить соавтора". В полученной ссылке GET параметр `token` и будет токеном для присоединения.
- Args:
- user_id (:obj:`int`): Владелец плейлиста.
- token (:obj:`str`): Токен для присоединения.
- **kwargs: Произвольные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/playlists/collective/join'
- params = {'uid': user_id, 'token': token}
- result = self._request.post(url, params=params, **kwargs)
- return result == 'ok'
- @log
- def users_playlists_list(self, user_id: UserIdType = None, *args: Any, **kwargs: Any) -> List[Playlist]:
- """Получение списка плейлистов пользователя.
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Playlist`: Плейлисты пользователя.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/playlists/list'
- result = self._request.get(url, *args, **kwargs)
- return Playlist.de_list(result, self)
- def _get_likes(
- self,
- object_type: str,
- user_id: UserIdType = None,
- params: Optional['JSONType'] = None,
- *args: Any,
- **kwargs: Any,
- ) -> Union[List[Like], Optional[TracksList]]:
- """Получение объектов с отметкой "Мне нравится".
- Args:
- object_type (:obj:`str`): Тип объекта.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- params (:obj:`dict`, optional): Параметры, которые будут переданы в запрос.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Like` | :obj:`yandex_music.TracksList`: Объекты с отметкой "Мне нравится".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/likes/{object_type}s'
- result = self._request.get(url, params, *args, **kwargs)
- if object_type == 'track':
- return TracksList.de_json(result.get('library'), self)
- return Like.de_list(result, self, object_type)
- @log
- def users_likes_tracks(
- self,
- user_id: UserIdType = None,
- if_modified_since_revision: int = 0,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[TracksList]:
- """Получение треков с отметкой "Мне нравится".
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- if_modified_since_revision (:obj:`int`, optional): TODO.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.TracksList`: Треки с отметкой "Мне нравится".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_likes(
- 'track', user_id, {'if-modified-since-revision': if_modified_since_revision}, *args, **kwargs
- )
- @log
- def users_likes_albums(
- self, user_id: UserIdType = None, rich: bool = True, *args: Any, **kwargs: Any
- ) -> List[Like]:
- """Получение альбомов с отметкой "Мне нравится".
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- rich (:obj:`bool`, optional): Если False, то приходит укороченная версия.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Like`: Альбомы с отметкой "Мне нравится".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_likes('album', user_id, {'rich': str(rich)}, *args, **kwargs)
- @log
- def users_likes_artists(
- self,
- user_id: UserIdType = None,
- with_timestamps: bool = True,
- *args: Any,
- **kwargs: Any,
- ) -> List[Like]:
- """Получение артистов с отметкой "Мне нравится".
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- with_timestamps (:obj:`bool`, optional): С временными метками TODO.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Like`: Артисты с отметкой "Мне нравится".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_likes('artist', user_id, {'with-timestamps': str(with_timestamps)}, *args, **kwargs)
- @log
- def users_likes_playlists(self, user_id: UserIdType = None, *args: Any, **kwargs: Any) -> List[Like]:
- """Получение плейлистов с отметкой "Мне нравится".
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.Like`: Плейлисты с отметкой "Мне нравится".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._get_likes('playlist', user_id, *args, **kwargs)
- @log
- def users_dislikes_tracks(
- self,
- user_id: UserIdType = None,
- if_modified_since_revision: int = 0,
- *args: Any,
- **kwargs: Any,
- ) -> Optional[TracksList]:
- """Получение треков с отметкой "Не рекомендовать".
- Args:
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- if_modified_since_revision (:obj:`bool`, optional): TODO.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.TracksList`: Треки с отметкой "Не рекомендовать".
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- url = f'{self.base_url}/users/{user_id}/dislikes/tracks'
- result = self._request.get(url, {'if_modified_since_revision': if_modified_since_revision}, *args, **kwargs)
- return TracksList.de_json(result.get('library'), self)
- def _dislike_action(
- self,
- ids: Union[List[Union[str, int]], str, int],
- remove: bool = False,
- user_id: UserIdType = None,
- *args: Any,
- **kwargs: Any,
- ) -> bool:
- """Действия с отметкой "Не рекомендовать".
- Args:
- ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор объекта или объектов.
- remove (:obj:`bool`, optional): Если :obj:`True`, то снимает отметку, иначе ставит.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if user_id is None and self.account_uid is not None:
- user_id = self.account_uid
- action = 'remove' if remove else 'add-multiple'
- url = f'{self.base_url}/users/{user_id}/dislikes/tracks/{action}'
- result = self._request.post(url, {'track-ids': ids}, *args, **kwargs)
- return 'revision' in result
- @log
- def users_dislikes_tracks_add(
- self,
- track_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Поставить отметку "Не рекомендовать" треку/трекам.
- Note:
- Так же снимает отметку "Мне нравится" если она есть.
- Args:
- track_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор трека или треков.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._dislike_action(track_ids, remove=False, user_id=user_id, **kwargs)
- @log
- def users_dislikes_tracks_remove(
- self,
- track_ids: Union[List[Union[str, int]], str, int],
- user_id: UserIdType = None,
- **kwargs: Any,
- ) -> bool:
- """Снять отметку "Не рекомендовать" у трека/треков.
- Args:
- track_ids (:obj:`str` | :obj:`int` | :obj:`list` из :obj:`str` | :obj:`list` из :obj:`int`): Уникальный
- идентификатор трека или треков.
- user_id (:obj:`str` | :obj:`int`, optional): Уникальный идентификатор пользователя. Если не указан
- используется ID текущего пользователя.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- return self._dislike_action(track_ids, remove=True, user_id=user_id, **kwargs)
- @log
- def after_track(
- self,
- next_track_id: Union[str, int],
- context_item: str,
- prev_track_id: Optional[Union[str, int]] = None,
- context: str = 'playlist',
- types: str = 'shot',
- from_: str = 'mobile-landing-origin-default',
- *args: Any,
- **kwargs: Any,
- ) -> Optional[ShotEvent]:
- """Получение рекламы или шота от Алисы после трека.
- Note:
- При получения шота от Алисы `prev_track_id` можно не указывать.
- Если `context = 'playlist'`, то в `context_item` необходимо передать `{OWNER_PLAYLIST}:{ID_PLAYLIST}`.
- Плейлист с Алисой имеет владельца с `id = 940441070`.
- ID плейлиста можно получить из блоков landing'a. Получить шот чужого плейлиста нельзя.
- Известные значения `context`: `playlist`.
- Известные значения `types`: `shot`, `ad`.
- Args:
- prev_track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор предыдущего трека.
- next_track_id (:obj:`str` | :obj:`int`): Уникальный идентификатор следующего трека.
- context_item (:obj:`str`): Уникальный идентификатор контекста.
- context (:obj:`str`, optional): Место, откуда было вызвано получение.
- types (:obj:`str`, optional): Тип того, что вернуть после трека.
- from_ (:obj:`str`, optional): Место, с которого попали в контекст.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.ShotEvent`: Шот от Алисы или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/after-track'
- params = {
- 'from': from_,
- 'prevTrackId': prev_track_id,
- 'nextTrackId': next_track_id,
- 'context': context,
- 'contextItem': context_item,
- 'types': types,
- }
- result = self._request.get(url, params, *args, **kwargs)
- # TODO (MarshalX) судя по всему ручка ещё возвращает рекламу после треков для пользователей без подписки.
- # https://github.com/MarshalX/yandex-music-api/issues/557
- return ShotEvent.de_json(result.get('shot_event'), self)
- @log
- def queues_list(self, device: Optional[str] = None, *args: Any, **kwargs: Any) -> List[QueueItem]:
- """Получение всех очередей треков с разных устройств для синхронизации между ними.
- Note:
- Именно к `device` привязывается очередь. На одном устройстве может быть создана одна очередь.
- Аргумент `device` имеет следующий формат: `ключ=значение; ключ2=значение2`. Обязательные паля указы в
- значении по умолчанию.
- Args:
- device (:obj:`str`, optional): Содержит информацию об устройстве с которого выполняется запрос.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`list` из :obj:`yandex_music.QueueItem`: Элементы очереди всех устройств.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if not device:
- device = self.device
- url = f'{self.base_url}/queues'
- self._request.headers['X-Yandex-Music-Device'] = device
- result = self._request.get(url, *args, **kwargs)
- return QueueItem.de_list(result.get('queues'), self)
- @log
- def queue(self, queue_id: str, *args: Any, **kwargs: Any) -> Optional[Queue]:
- """Получение информации об очереди треков и самих треков в ней.
- Args:
- queue_id (:obj:`str`): Уникальный идентификатор очереди.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`yandex_music.Queue`: Очередь или :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- url = f'{self.base_url}/queues/{queue_id}'
- result = self._request.get(url, *args, **kwargs)
- return Queue.de_json(result, self)
- @log
- def queue_update_position(self, queue_id: str, current_index: int, device: Optional[str] = None, **kwargs) -> bool:
- """Установка текущего индекса проигрываемого трека в очереди треков.
- Note:
- Изменить можно только у той очереди, которая была создана с переданного `device`!
- Args:
- queue_id (:obj:`str`): Уникальный идентификатор очереди.
- current_index (:obj:`int`): Текущий индекс.
- device (:obj:`str`, optional): Содержит информацию об устройстве с которого выполняется запрос.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`bool`: :obj:`True` при успешном выполнении запроса, иначе :obj:`False`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if not device:
- device = self.device
- url = f'{self.base_url}/queues/{queue_id}/update-position'
- self._request.headers['X-Yandex-Music-Device'] = device
- result = self._request.post(url, {'isInteractive': False}, params={'currentIndex': current_index}, **kwargs)
- return result.get('status') == 'ok'
- @log
- def queue_create(
- self, queue: Union[Queue, str], device: Optional[str] = None, *args: Any, **kwargs: Any
- ) -> Optional[str]:
- """Создание новой очереди треков.
- Args:
- queue (:obj:`yandex_music.Queue` | :obj:`str`): Объект очереди или JSON строка с этим объектом.
- device (:obj:`str`, optional): Содержит информацию об устройстве с которого выполняется запрос.
- *args: Произвольные аргументы (будут переданы в запрос).
- **kwargs: Произвольные именованные аргументы (будут переданы в запрос).
- Returns:
- :obj:`str`: Вернёт уникальный идентификатор созданной очереди, иначе :obj:`None`.
- Raises:
- :class:`yandex_music.exceptions.YandexMusicError`: Базовое исключение библиотеки.
- """
- if not device:
- device = self.device
- if isinstance(queue, Queue):
- queue = queue.to_json(True)
- url = f'{self.base_url}/queues'
- self._request.headers['X-Yandex-Music-Device'] = device
- result = self._request.post(url, queue, *args, **kwargs)
- return result.get('id')
- # camelCase псевдонимы
- #: Псевдоним для :attr:`account_status`
- accountStatus = account_status
- #: Псевдоним для :attr:`account_settings`
- accountSettings = account_settings
- #: Псевдоним для :attr:`account_settings_set`
- accountSettingsSet = account_settings_set
- #: Псевдоним для :attr:`permission_alerts`
- permissionAlerts = permission_alerts
- #: Псевдоним для :attr:`account_experiments`
- accountExperiments = account_experiments
- #: Псевдоним для :attr:`consume_promo_code`
- consumePromoCode = consume_promo_code
- #: Псевдоним для :attr:`feed_wizard_is_passed`
- feedWizardIsPassed = feed_wizard_is_passed
- #: Псевдоним для :attr:`new_releases`
- newReleases = new_releases
- #: Псевдоним для :attr:`new_playlists`
- newPlaylists = new_playlists
- #: Псевдоним для :attr:`tracks_download_info`
- tracksDownloadInfo = tracks_download_info
- #: Псевдоним для :attr:`track_supplement`
- trackSupplement = track_supplement
- #: Псевдоним для :attr:`tracks_lyrics`
- tracksLyrics = tracks_lyrics
- #: Псевдоним для :attr:`tracks_similar`
- tracksSimilar = tracks_similar
- #: Псевдоним для :attr:`play_audio`
- playAudio = play_audio
- #: Псевдоним для :attr:`albums_with_tracks`
- albumsWithTracks = albums_with_tracks
- #: Псевдоним для :attr:`search_suggest`
- searchSuggest = search_suggest
- #: Псевдоним для :attr:`users_settings`
- usersSettings = users_settings
- #: Псевдоним для :attr:`users_playlists`
- usersPlaylists = users_playlists
- #: Псевдоним для :attr:`users_playlists_recommendations`
- usersPlaylistsRecommendations = users_playlists_recommendations
- #: Псевдоним для :attr:`users_playlists_create`
- usersPlaylistsCreate = users_playlists_create
- #: Псевдоним для :attr:`users_playlists_delete`
- usersPlaylistsDelete = users_playlists_delete
- #: Псевдоним для :attr:`users_playlists_name`
- usersPlaylistsName = users_playlists_name
- #: Псевдоним для :attr:`users_playlists_visibility`
- usersPlaylistsVisibility = users_playlists_visibility
- #: Псевдоним для :attr:`users_playlists_change`
- usersPlaylistsChange = users_playlists_change
- #: Псевдоним для :attr:`users_playlists_insert_track`
- usersPlaylistsInsertTrack = users_playlists_insert_track
- #: Псевдоним для :attr:`users_playlists_delete_track`
- usersPlaylistsDeleteTrack = users_playlists_delete_track
- #: Псевдоним для :attr:`rotor_account_status`
- rotorAccountStatus = rotor_account_status
- #: Псевдоним для :attr:`rotor_stations_dashboard`
- rotorStationsDashboard = rotor_stations_dashboard
- #: Псевдоним для :attr:`rotor_stations_list`
- rotorStationsList = rotor_stations_list
- #: Псевдоним для :attr:`rotor_station_feedback`
- rotorStationFeedback = rotor_station_feedback
- #: Псевдоним для :attr:`rotor_station_feedback_radio_started`
- rotorStationFeedbackRadioStarted = rotor_station_feedback_radio_started
- #: Псевдоним для :attr:`rotor_station_feedback_track_started`
- rotorStationFeedbackTrackStarted = rotor_station_feedback_track_started
- #: Псевдоним для :attr:`rotor_station_feedback_track_finished`
- rotorStationFeedbackTrackFinished = rotor_station_feedback_track_finished
- #: Псевдоним для :attr:`rotor_station_feedback_skip`
- rotorStationFeedbackSkip = rotor_station_feedback_skip
- #: Псевдоним для :attr:`rotor_station_info`
- rotorStationInfo = rotor_station_info
- #: Псевдоним для :attr:`rotor_station_settings2`
- rotorStationSettings2 = rotor_station_settings2
- #: Псевдоним для :attr:`rotor_station_tracks`
- rotorStationTracks = rotor_station_tracks
- #: Псевдоним для :attr:`artists_brief_info`
- artistsBriefInfo = artists_brief_info
- #: Псевдоним для :attr:`artists_tracks`
- artistsTracks = artists_tracks
- #: Псевдоним для :attr:`artists_direct_albums`
- artistsDirectAlbums = artists_direct_albums
- #: Псевдоним для :attr:`users_likes_tracks_add`
- usersLikesTracksAdd = users_likes_tracks_add
- #: Псевдоним для :attr:`users_likes_tracks_remove`
- usersLikesTracksRemove = users_likes_tracks_remove
- #: Псевдоним для :attr:`users_likes_artists_add`
- usersLikesArtistsAdd = users_likes_artists_add
- #: Псевдоним для :attr:`users_likes_artists_remove`
- usersLikesArtistsRemove = users_likes_artists_remove
- #: Псевдоним для :attr:`users_likes_playlists_add`
- usersLikesPlaylistsAdd = users_likes_playlists_add
- #: Псевдоним для :attr:`users_likes_playlists_remove`
- usersLikesPlaylistsRemove = users_likes_playlists_remove
- #: Псевдоним для :attr:`users_likes_albums_add`
- usersLikesAlbumsAdd = users_likes_albums_add
- #: Псевдоним для :attr:`users_likes_albums_remove`
- usersLikesAlbumsRemove = users_likes_albums_remove
- #: Псевдоним для :attr:`playlists_list`
- playlistsList = playlists_list
- #: Псевдоним для :attr:`playlists_collective_join`
- playlistsCollectiveJoin = playlists_collective_join
- #: Псевдоним для :attr:`users_playlists_list`
- usersPlaylistsList = users_playlists_list
- #: Псевдоним для :attr:`users_likes_tracks`
- usersLikesTracks = users_likes_tracks
- #: Псевдоним для :attr:`users_likes_albums`
- usersLikesAlbums = users_likes_albums
- #: Псевдоним для :attr:`users_likes_artists`
- usersLikesArtists = users_likes_artists
- #: Псевдоним для :attr:`users_likes_playlists`
- usersLikesPlaylists = users_likes_playlists
- #: Псевдоним для :attr:`users_dislikes_tracks`
- usersDislikesTracks = users_dislikes_tracks
- #: Псевдоним для :attr:`users_dislikes_tracks_add`
- usersDislikesTracksAdd = users_dislikes_tracks_add
- #: Псевдоним для :attr:`users_dislikes_tracks_remove`
- usersDislikesTracksRemove = users_dislikes_tracks_remove
- #: Псевдоним для :attr:`after_track`
- afterTrack = after_track
- #: Псевдоним для :attr:`queues_list`
- queuesList = queues_list
- #: Псевдоним для :attr:`queue_update_position`
- queueUpdatePosition = queue_update_position
- #: Псевдоним для :attr:`queue_create`
- queueCreate = queue_create
|