PagerMaid_Plugins_Pyro/copy_sticker_set/main.py

110 lines
3.6 KiB
Python
Raw Normal View History

from typing import List
2022-12-15 12:29:52 +00:00
from pyrogram.raw.functions.messages import GetStickerSet
from pyrogram.raw.functions.stickers import CreateStickerSet
2023-07-01 12:18:58 +00:00
from pyrogram.raw.types import (
InputStickerSetShortName,
InputStickerSetItem,
InputDocument,
)
2022-12-15 12:29:52 +00:00
from pyrogram.raw.types.messages import StickerSet
from pagermaid.listener import listener
from pagermaid.services import bot
from pagermaid.enums import Message
class NoStickerSetNameError(Exception):
"""
2023-07-01 12:18:58 +00:00
Occurs when no username is provided
2022-12-15 12:29:52 +00:00
"""
def __init__(self, string: str = "贴纸包不存在"):
2023-07-01 12:18:58 +00:00
super().__init__(string)
2022-12-15 12:29:52 +00:00
async def get_pack(name: str):
try:
2023-07-01 12:18:58 +00:00
return await bot.invoke(
GetStickerSet(stickerset=InputStickerSetShortName(short_name=name), hash=0)
)
2022-12-15 12:29:52 +00:00
except Exception as e: # noqa
raise NoStickerSetNameError() from e
2023-07-01 12:18:58 +00:00
async def create_sticker_set(
sticker_set: str, title: str, is_animated: bool, is_video: bool, stickers
):
2022-12-15 12:29:52 +00:00
try:
await bot.invoke(
CreateStickerSet(
user_id=await bot.resolve_peer((await bot.get_me()).id),
title=title,
short_name=sticker_set,
stickers=stickers,
animated=is_animated,
videos=is_video,
software="pagermaid-pyro",
)
)
except Exception as e:
raise NoStickerSetNameError("贴纸包名称或者链接非法或者已被占用,请换一个") from e
async def process_old_sticker_set(sticker_sets: List[str]):
is_animated = False
is_video = False
stickers = []
for idx, sticker_set in enumerate(sticker_sets):
pack: StickerSet = await get_pack(sticker_set)
if idx == 0:
is_animated = pack.set.animated
is_video = pack.set.videos
else:
if pack.set.animated != is_animated:
raise NoStickerSetNameError("贴纸包类型不一致")
if pack.set.videos != is_video:
raise NoStickerSetNameError("贴纸包类型不一致")
hash_map = {}
for i in pack.packs:
for j in i.documents:
hash_map[j] = i.emoticon
_stickers = [
InputStickerSetItem(
document=InputDocument(
id=i.id,
access_hash=i.access_hash,
file_reference=i.file_reference,
),
emoji=hash_map.get(i.id, "👀"),
)
for i in pack.documents
]
if len(stickers) + len(_stickers) > 120:
raise NoStickerSetNameError("贴纸包过多")
stickers.extend(_stickers)
2022-12-15 12:29:52 +00:00
return stickers, is_animated, is_video
@listener(
command="copy_sticker_set",
parameters="旧的贴纸包用户名1,旧的贴纸包用户名2 贴纸包用户名 贴纸包名称",
2022-12-15 12:29:52 +00:00
description="复制某个贴纸包",
)
async def copy_sticker_set(message: Message):
if len(message.parameter) < 3:
2023-07-01 12:18:58 +00:00
return await message.edit(
"请指定贴纸包链接和贴纸包名称,例如 <code>xxx xxxx_sticker xxxx 的贴纸包</code>"
2023-07-01 12:18:58 +00:00
)
old_set_names = message.parameter[0].split(",")
set_name = message.parameter[1]
name = " ".join(message.parameter[2:])
2022-12-15 12:29:52 +00:00
try:
stickers, is_animated, is_video = await process_old_sticker_set(old_set_names)
2022-12-15 12:29:52 +00:00
await create_sticker_set(set_name, name, is_animated, is_video, stickers)
except Exception as e:
return await message.edit(f"复制贴纸包失败:{e}")
2023-07-01 12:18:58 +00:00
await message.edit(
f'复制贴纸包成功 <a href="https://t.me/addstickers/{set_name}">{name}</a>'
)