From 9c412a5fd3c346b5b69eb1118dd42ad035c53fe0 Mon Sep 17 00:00:00 2001 From: Marshal Date: Wed, 15 Jan 2020 11:14:55 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=20=D0=BC=D0=B5=D1=82=D0=BE=D0=B4=20=D0=B4=D0=BB=D1=8F=20?= =?UTF-8?q?=D0=B8=D0=B7=D0=BC=D0=B5=D0=BD=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=B2?= =?UTF-8?q?=D0=B8=D0=B4=D0=B8=D0=BC=D0=BE=D1=81=D1=82=D0=B8=20=D0=BF=D0=BB?= =?UTF-8?q?=D0=B5=D0=B9=D0=BB=D0=B8=D1=81=D1=82=D0=B0=20#179?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- yandex_music/client.py | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/yandex_music/client.py b/yandex_music/client.py index 9071efb..921f4d7 100644 --- a/yandex_music/client.py +++ b/yandex_music/client.py @@ -750,6 +750,38 @@ class Client(YandexMusicObject): return Playlist.de_json(result, self) + @log + def users_playlists_visibility(self, kind: Union[str, int], visibility: str, user_id: str = None, + timeout: Union[int, float] = None, *args, **kwargs) -> Optional[Playlist]: + """Изменение видимости плейлиста. + + Видимость (visibility) может быть задана только одним из двух значений: private, public. + + Args: + kind (:obj:`str` | :obj:`int`): Уникальный идентификатор плейлиста. + visibility (:obj:`str`): Новое название. + user_id: (:obj:`int`, optional): Уникальный идентификатор пользователя владеющим плейлистом. + timeout (:obj:`int` | :obj:`float`, optional): Если это значение указано, используется как время ожидания + ответа от сервера вместо указанного при создании пула. + **kwargs (:obj:`dict`, optional): Произвольные аргументы (будут переданы в запрос). + + Returns: + :obj:`yandex_music.Playlist`: Объекта класса :class:`yandex_music.Playlist` + представляющий изменённый плейлист, иначе :obj:`None`. + + Raises: + :class:`yandex_music.YandexMusicError` + """ + + if user_id is None and self.me is not None: + user_id = self.me.account.uid + + url = f'{self.base_url}/users/{user_id}/playlists/{kind}/visibility' + + result = self._request.post(url, {'value': visibility}, timeout=timeout, *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: str = None, timeout: Union[int, float] = None, *args, **kwargs) -> Optional[Playlist]: