mirror of
https://github.com/Mayuri-Chan/pyrofork.git
synced 2025-12-29 20:14:51 +00:00
161 lines
6.4 KiB
Python
161 lines
6.4 KiB
Python
# Pyrofork - Telegram MTProto API Client Library for Python
|
|
# Copyright (C) 2017-present Dan <https://github.com/delivrance>
|
|
# Copyright (C) 2022-present Mayuri-Chan <https://github.com/Mayuri-Chan>
|
|
#
|
|
# This file is part of Pyrofork.
|
|
#
|
|
# Pyrofork is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser General Public License as published
|
|
# by the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Pyrofork is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License
|
|
# along with Pyrofork. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from typing import List, Union
|
|
|
|
import pyrogram
|
|
from pyrogram import enums, raw, types, utils
|
|
|
|
|
|
class UpdateFolder:
|
|
async def update_folder(
|
|
self: "pyrogram.Client",
|
|
folder_id: int,
|
|
title: str,
|
|
title_entities: List["types.MessageEntity"] = None,
|
|
included_chats: Union[Union[int, str], List[Union[int, str]]] = None,
|
|
excluded_chats: Union[Union[int, str], List[Union[int, str]]] = None,
|
|
pinned_chats: Union[Union[int, str], List[Union[int, str]]] = None,
|
|
contacts: bool = None,
|
|
non_contacts: bool = None,
|
|
groups: bool = None,
|
|
channels: bool = None,
|
|
bots: bool = None,
|
|
exclude_muted: bool = None,
|
|
exclude_read: bool = None,
|
|
exclude_archived: bool = None,
|
|
color: "enums.FolderColor" = None,
|
|
emoji: str = None,
|
|
parse_mode: "pyrogram.enums.ParseMode" = pyrogram.enums.ParseMode.DEFAULT
|
|
) -> bool:
|
|
"""Create or update a user's folder.
|
|
|
|
.. include:: /_includes/usable-by/users.rst
|
|
|
|
Parameters:
|
|
folder_id (``int``):
|
|
Unique folder identifier.
|
|
|
|
title (``str``):
|
|
Folder title.
|
|
|
|
title_entities (List of :obj:`~pyrogram.types.MessageEntity`, *optional*):
|
|
Entities for the folder title.
|
|
|
|
included_chats (``int`` | ``str`` | List of ``int`` or ``str``, *optional*):
|
|
Users or chats that should added in the folder
|
|
You can pass an ID (int), username (str) or phone number (str).
|
|
Multiple users can be added by passing a list of IDs, usernames or phone numbers.
|
|
|
|
excluded_chats (``int`` | ``str`` | List of ``int`` or ``str``, *optional*):
|
|
Users or chats that should excluded from the folder
|
|
You can pass an ID (int), username (str) or phone number (str).
|
|
Multiple users can be added by passing a list of IDs, usernames or phone numbers.
|
|
|
|
pinned_chats (``int`` | ``str`` | List of ``int`` or ``str``, *optional*):
|
|
Users or chats that should pinned in the folder
|
|
You can pass an ID (int), username (str) or phone number (str).
|
|
Multiple users can be added by passing a list of IDs, usernames or phone numbers.
|
|
|
|
contacts (``bool``, *optional*):
|
|
Pass True if folder should contain contacts.
|
|
|
|
non_contacts (``bool``, *optional*):
|
|
Pass True if folder should contain non contacts.
|
|
|
|
groups (``bool``, *optional*):
|
|
Pass True if folder should contain groups.
|
|
|
|
channels (``bool``, *optional*):
|
|
Pass True if folder should contain channels.
|
|
|
|
bots (``bool``, *optional*):
|
|
Pass True if folder should contain bots.
|
|
|
|
exclude_muted (``bool``, *optional*):
|
|
Pass True if folder should exclude muted users.
|
|
|
|
exclude_archived (``bool``, *optional*):
|
|
Pass True if folder should exclude archived users.
|
|
|
|
emoji (``str``, *optional*):
|
|
Folder emoji.
|
|
Pass None to leave the folder icon as default.
|
|
|
|
color (:obj:`~pyrogram.enums.FolderColor`, *optional*):
|
|
Color type.
|
|
Pass :obj:`~pyrogram.enums.FolderColor` to set folder color.
|
|
|
|
parse_mode (:obj:`~pyrogram.enums.ParseMode`, *optional*):
|
|
The parse mode to use for the title.
|
|
|
|
Returns:
|
|
``bool``: True, on success.
|
|
|
|
Example:
|
|
.. code-block:: python
|
|
|
|
# Create or update folder
|
|
app.update_folder(folder_id, title="New folder", included_chats="me")
|
|
"""
|
|
title_text, title_entities = (await utils.parse_text_entities(self, title, parse_mode, title_entities)).values()
|
|
|
|
if not isinstance(included_chats, list):
|
|
included_chats = [included_chats] if included_chats else []
|
|
if not isinstance(excluded_chats, list):
|
|
excluded_chats = [excluded_chats] if excluded_chats else []
|
|
if not isinstance(pinned_chats, list):
|
|
pinned_chats = [pinned_chats] if pinned_chats else []
|
|
|
|
r = await self.invoke(
|
|
raw.functions.messages.UpdateDialogFilter(
|
|
id=folder_id,
|
|
filter=raw.types.DialogFilter(
|
|
id=folder_id,
|
|
title=raw.types.TextWithEntities(
|
|
text=title_text,
|
|
entities=title_entities or []
|
|
),
|
|
pinned_peers=[
|
|
await self.resolve_peer(user_id)
|
|
for user_id in pinned_chats
|
|
],
|
|
include_peers=[
|
|
await self.resolve_peer(user_id)
|
|
for user_id in included_chats
|
|
],
|
|
exclude_peers=[
|
|
await self.resolve_peer(user_id)
|
|
for user_id in excluded_chats
|
|
],
|
|
contacts=contacts,
|
|
non_contacts=non_contacts,
|
|
groups=groups,
|
|
broadcasts=channels,
|
|
bots=bots,
|
|
exclude_muted=exclude_muted,
|
|
exclude_read=exclude_read,
|
|
exclude_archived=exclude_archived,
|
|
emoticon=emoji,
|
|
color=color.value if color else None
|
|
)
|
|
)
|
|
)
|
|
|
|
return bool(r)
|