Spaces:
Paused
Paused
| import asyncio | |
| import base64 | |
| import math | |
| import os | |
| import shlex | |
| import textwrap | |
| from time import time | |
| from typing import List, Tuple | |
| import requests | |
| from PIL import Image, ImageDraw, ImageFont | |
| from pyrogram import errors, raw | |
| from pyrogram.file_id import FileId | |
| from pyrogram.types import InlineKeyboardButton as ikb | |
| from pyrogram.types import InlineKeyboardMarkup as ikm | |
| from pyrogram.types import Message | |
| from unidecode import unidecode | |
| from Powers import scrap_dir | |
| from Powers.bot_class import Gojo | |
| from Powers.utils.string import encode_decode | |
| def quotify(msg_info: List[dict]) -> Tuple[bool, str]: | |
| json = { | |
| "type": "quote", | |
| "format": "webp", | |
| "backgroundColor": "#000000", | |
| "width": 512, | |
| "height": 768, | |
| "scale": 2, | |
| "messages": msg_info, | |
| } | |
| try: | |
| response = requests.post("https://bot.lyo.su/quote/generate", json=json).json() | |
| image = base64.b64decode(str(response["result"]["image"]).encode("utf-8")) | |
| file_name = f"Quote_{int(time())}.webp" | |
| with open(file_name, "wb") as f: | |
| f.write(image) | |
| return True, file_name | |
| except Exception as e: | |
| return False, str(e) | |
| def get_msg_entities(m: Message) -> List[dict]: | |
| entities = [] | |
| if m.entities: | |
| entities.extend( | |
| { | |
| "type": entity.type.name.lower(), | |
| "offset": entity.offset, | |
| "length": entity.length, | |
| } | |
| for entity in m.entities | |
| ) | |
| return entities | |
| async def get_all_sticker_packs(c: Gojo, user_id: int, offset: int = 1, limit: int = 25): | |
| packnum = 25 * (offset - 1) | |
| txt = f"Here is your stickers pack that I have created:\nPage: {offset}\n\nNOTE: I may have kanged more sticker sets for you, but since last update I will no longer add stickers in those packs due to recent telegram update in bot api sorry." | |
| while True: | |
| packname = f"CE{user_id}{packnum}_by_{c.me.username}" | |
| sticker_set = await get_sticker_set_by_name(c, packname) | |
| if not sticker_set and packnum == 0: | |
| txt, kb = None, None | |
| break | |
| elif sticker_set and packnum <= (packnum + limit - 1): | |
| base_ = f"t.me/addstickers/{packname}" | |
| txt += f"`{packnum}`. [{sticker_set.set.name}]({base_})\n" | |
| packnum += 1 | |
| else: | |
| page = await encode_decode(f"1_{user_id}") | |
| b64_next = await encode_decode(f"{offset + 1}_{user_id}") | |
| b64_prev = await encode_decode(f"{offset - 1}_{user_id}") | |
| if (packnum > (packnum + limit - 1)) and offset >= 2: | |
| kb = [ | |
| [ | |
| ikb("Previous", f"stickers_{b64_prev}"), | |
| ikb("Next", f"stickers_{b64_next}") | |
| ], | |
| ] | |
| elif offset >= 2: | |
| kb = [ | |
| [ | |
| ikb("Previous", f"stickers_{b64_prev}") | |
| ], | |
| ] | |
| elif packnum > (packnum + limit - 1) and offset == 1: | |
| kb = [ | |
| [ | |
| ikb("Next", f"stickers_{b64_next}") | |
| ], | |
| ] | |
| else: | |
| kb = [ | |
| [ | |
| ikb( | |
| "Close ❌", | |
| callback_data="f_close" | |
| ) | |
| ] | |
| ] | |
| kb = ikm(kb) | |
| break | |
| return txt, kb | |
| async def runcmd(cmd: str) -> Tuple[str, str, int, int]: | |
| args = shlex.split(cmd) | |
| process = await asyncio.create_subprocess_exec( | |
| *args, stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.PIPE | |
| ) | |
| stdout, stderr = await process.communicate() | |
| return ( | |
| stdout.decode("utf-8", "replace").strip(), | |
| stderr.decode("utf-8", "replace").strip(), | |
| process.returncode, | |
| process.pid, | |
| ) | |
| async def get_sticker_set_by_name( | |
| client: Gojo, name: str | |
| ) -> raw.base.messages.StickerSet: | |
| try: | |
| return await client.invoke( | |
| raw.functions.messages.GetStickerSet( | |
| stickerset=raw.types.InputStickerSetShortName(short_name=name), | |
| hash=0, | |
| ) | |
| ) | |
| except errors.exceptions.not_acceptable_406.StickersetInvalid: | |
| return None | |
| async def create_sticker_set( | |
| client: Gojo, | |
| owner: int, | |
| title: str, | |
| short_name: str, | |
| stickers: List[raw.base.InputStickerSetItem], | |
| animated: bool = False, | |
| video: bool = False | |
| ) -> raw.base.messages.StickerSet: | |
| return await client.invoke( | |
| raw.functions.stickers.CreateStickerSet( | |
| user_id=await client.resolve_peer(owner), | |
| title=title, | |
| short_name=short_name, | |
| stickers=stickers | |
| ) | |
| ) | |
| async def add_sticker_to_set( | |
| client: Gojo, | |
| stickerset: raw.base.messages.StickerSet, | |
| sticker: raw.base.InputStickerSetItem, | |
| ) -> raw.base.messages.StickerSet: | |
| return await client.invoke( | |
| raw.functions.stickers.AddStickerToSet( | |
| stickerset=raw.types.InputStickerSetShortName( | |
| short_name=stickerset.set.short_name | |
| ), | |
| sticker=sticker, | |
| ) | |
| ) | |
| async def create_sticker( | |
| sticker: raw.base.InputDocument, emoji: str | |
| ) -> raw.base.InputStickerSetItem: | |
| return raw.types.InputStickerSetItem(document=sticker, emoji=emoji) | |
| async def resize_file_to_sticker_size(file_path: str, length: int = 512, width: int = 512) -> str: | |
| im = Image.open(file_path) | |
| STICKER_DIMENSIONS = (length, width) | |
| if (im.width, im.height) < STICKER_DIMENSIONS: | |
| size1 = im.width | |
| size2 = im.height | |
| if im.width > im.height: | |
| scale = length / size1 | |
| size1new = length | |
| size2new = size2 * scale | |
| else: | |
| scale = width / size2 | |
| size1new = size1 * scale | |
| size2new = width | |
| size1new = math.floor(size1new) | |
| size2new = math.floor(size2new) | |
| sizenew = (size1new, size2new) | |
| im = im.resize(sizenew) | |
| else: | |
| im.thumbnail(STICKER_DIMENSIONS) | |
| file_pathh = f"{scrap_dir}r{str(time()).replace('.', '_')}.png" | |
| im.save(file_pathh) | |
| os.remove(file_path) | |
| return file_pathh | |
| async def tgs_to_gif(file, tgs=False, video=False): | |
| if tgs: | |
| cmd = f"lottie_convert.py '{file}' 'gojo_satoru.gif'" | |
| elif video: | |
| cmd = f"ffmpeg -i '{file}' -c copy 'gojo_satoru.gif'" | |
| await runcmd(cmd) | |
| os.remove(file) | |
| return 'gojo_satoru.gif' | |
| async def webm_to_gif(file): | |
| cmd = f"ffmpeg -i '{file}' 'goJo.gif'" | |
| await runcmd(cmd) | |
| os.remove(file) | |
| return "goJo.gif" | |
| async def Vsticker(c: Gojo, file: Message): | |
| if file.animation: | |
| file = file.animation | |
| elif file.video: | |
| file = file.video | |
| _width_ = file.width | |
| _height_ = file.height | |
| _height_, _width_ = (512, -1) if _height_ > _width_ else (-1, 512) | |
| file = await c.download_media(file) | |
| await runcmd( | |
| f"ffmpeg -to 00:00:02.900 -i '{file}' -vf scale={_width_}:{_height_} -c:v libvpx-vp9 -crf 30 -b:v 560k -maxrate 560k -bufsize 256k -an 'VideoSticker.webm'" | |
| ) | |
| os.remove(file) | |
| return "VideoSticker.webm" | |
| async def upload_document( | |
| client: Gojo, file_path: str, chat_id: int | |
| ) -> raw.base.InputDocument: | |
| media = await client.invoke( | |
| raw.functions.messages.UploadMedia( | |
| peer=await client.resolve_peer(chat_id), | |
| media=raw.types.InputMediaUploadedDocument( | |
| mime_type=client.guess_mime_type( | |
| file_path) or "application/zip", | |
| file=await client.save_file(file_path), | |
| attributes=[ | |
| raw.types.DocumentAttributeFilename( | |
| file_name=os.path.basename(file_path) | |
| ) | |
| ], | |
| force_file=True, | |
| ), | |
| ) | |
| ) | |
| return raw.types.InputDocument( | |
| id=media.document.id, | |
| access_hash=media.document.access_hash, | |
| file_reference=media.document.file_reference, | |
| ) | |
| async def get_document_from_file_id( | |
| file_id: str, | |
| ) -> raw.base.InputDocument: | |
| decoded = FileId.decode(file_id) | |
| return raw.types.InputDocument( | |
| id=decoded.media_id, | |
| access_hash=decoded.access_hash, | |
| file_reference=decoded.file_reference, | |
| ) | |
| async def remove_sticker(c: Gojo, stickerid: str) -> raw.base.messages.StickerSet: | |
| sticker = await get_document_from_file_id(stickerid) | |
| return await c.invoke(raw.functions.stickers.RemoveStickerFromSet(sticker=sticker)) | |
| async def draw_meme(image_path: str, text: str, sticker: bool, fiill: str) -> list: | |
| _split = text.split(";", 1) | |
| if len(_split) == 2: | |
| lower_text = _split[1] | |
| upper_text = _split[0] | |
| else: | |
| upper_text = text | |
| lower_text = "" | |
| image = Image.open(image_path) | |
| width, height = image.size | |
| font_size = int((30 / 500) * width) | |
| font = ImageFont.truetype("./extras/comic.ttf", font_size) | |
| draw = ImageDraw.Draw(image) | |
| curr_height, padding = 20, 5 | |
| for utext in textwrap.wrap(upper_text, 25): | |
| upper_width = draw.textlength(utext, font=font) | |
| draw.text( | |
| ((width - upper_width) / 2, curr_height), | |
| unidecode(utext), | |
| (255, 255, 255), | |
| font, | |
| stroke_width=3, | |
| stroke_fill=fiill, | |
| ) | |
| curr_height += font_size + padding | |
| curr_height = height - font_size | |
| for ltext in reversed(textwrap.wrap(lower_text, 25)): | |
| lower_width = draw.textlength(ltext, font=font) | |
| draw.text( | |
| ((width - lower_width) / 2, curr_height - font_size), | |
| ltext, | |
| (255, 255, 255), | |
| font, | |
| stroke_width=3, | |
| stroke_fill=fiill, | |
| ) | |
| curr_height -= font_size + padding | |
| if sticker: | |
| stick_path = image_path | |
| else: | |
| stick_path = await resize_file_to_sticker_size(image_path) | |
| image1 = image_path | |
| image2 = tosticker(stick_path, f"@GojoSuperbot_{int(time())}.webp") | |
| image.save(image1) | |
| image.save(image2) | |
| image.close() | |
| return [image1, image2] | |
| def toimage(image, filename=None, is_direc=False): | |
| filename = filename or "gojo.png" | |
| if is_direc: | |
| os.rename(image, filename) | |
| return filename | |
| img = Image.open(image) | |
| if img.mode != "RGB": | |
| img = img.convert("RGB") | |
| img.save(filename, "png") | |
| os.remove(image) | |
| return filename | |
| def tosticker(response, filename=None, is_direc=False): | |
| filename = filename or "gojo.webp" | |
| if is_direc: | |
| os.rename(response, filename) | |
| return filename | |
| image = Image.open(response) | |
| if image.mode != "RGB": | |
| image.convert("RGB") | |
| image.save(filename, "webp") | |
| os.remove(response) | |
| return filename | |