Skip to content

Commit

Permalink
PyroFork: Add AddStickerToSet Methods
Browse files Browse the repository at this point in the history
Signed-off-by: wulan17 <wulan17@nusantararom.org>
  • Loading branch information
wulan17 committed Apr 10, 2023
1 parent 7a58c86 commit f38d90c
Show file tree
Hide file tree
Showing 2 changed files with 87 additions and 0 deletions.
2 changes: 2 additions & 0 deletions pyrogram/methods/stickers/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
# You should have received a copy of the GNU Lesser General Public License
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.

from .add_sticker_to_set import AddStickerToSet
from .create_sticker_set import CreateStickerSet
from .get_sticker_set import GetStickerSet

class Stickers(
AddStickerToSet,
CreateStickerSet,
GetStickerSet
):
Expand Down
85 changes: 85 additions & 0 deletions pyrogram/methods/stickers/add_sticker_to_set.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
# Pyrogram - Telegram MTProto API Client Library for Python
# Copyright (C) 2017-present Dan <https://github.com/delivrance>
#
# This file is part of Pyrogram.
#
# Pyrogram 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.
#
# Pyrogram 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 Pyrogram. If not, see <http://www.gnu.org/licenses/>.

import os
import re
from typing import Union

import pyrogram
from pyrogram import raw
from pyrogram import types

class AddStickerToSet:
async def add_sticker_to_set(
self: "pyrogram.Client",
set_short_name: str,
sticker: str,
emoji: str = "🤔",
) -> "types.StickerSet":
"""Get info about a stickerset.
.. include:: /_includes/usable-by/bot.rst
Parameters:
set_short_name (``str``):
Stickerset shortname.
sticker (``str``):
sticker to add.
Pass a file_id as string to send a file that exists on the Telegram servers.
emoji (``str``, *optional*):
Associated emoji.
default to "🤔"
Returns:
:obj:`~pyrogram.types.StickerSet`: On success, the StickerSet information is returned.
Example:
.. code-block:: python
await app.add_sticker_to_set("mypack1", "AsJiasp")
"""
file = None

if isinstance(sticker, str):
if os.path.isfile(sticker) or re.match("^https?://", sticker):
raise ValueError(f"file_id is invalid!")
else:
decoded = FileId.decode(sticker)
media = raw.types.InputDocument(
id=decoded.media_id,
access_hash=decoded.access_hash,
file_reference=decoded.file_reference
)
else:
raise ValueError(f"file_id is invalid!")

r = await self.invoke(
raw.functions.stickers.AddStickerToSet(
stickerset=raw.types.InputStickerSetShortName(short_name=set_short_name),
sticker=[
raw.types.InputStickerSetItem(
document=media,
emoji=emoji
)
]
)
)

return types.StickerSet._parse(r.set)

0 comments on commit f38d90c

Please sign in to comment.