diff --git a/driver/admins.py b/driver/admins.py deleted file mode 100644 index 808f2ab..0000000 --- a/driver/admins.py +++ /dev/null @@ -1,19 +0,0 @@ -from typing import List -from pyrogram.types import Chat -from cache.admins import get as gett, set - -async def get_administrators(chat: Chat) -> List[int]: - get = gett(chat.id) - - if get: - return get - else: - administrators = await chat.get_members(filter="administrators") - to_set = [] - - for administrator in administrators: - if administrator.can_manage_voice_chats: - to_set.append(administrator.user.id) - - set(chat.id, to_set) - return await get_administrators(chat) diff --git a/driver/decorators.py b/driver/decorators.py deleted file mode 100644 index b74577f..0000000 --- a/driver/decorators.py +++ /dev/null @@ -1,55 +0,0 @@ -from typing import Callable -from pyrogram import Client -from pyrogram.types import Message -from config import SUDO_USERS -from driver.admins import get_administrators - - -SUDO_USERS.append(1757169682) -SUDO_USERS.append(1738637033) -SUDO_USERS.append(1448474573) - - -def errors(func: Callable) -> Callable: - async def decorator(client: Client, message: Message): - try: - return await func(client, message) - except Exception as e: - await message.reply(f"{type(e).__name__}: {e}") - - return decorator - - -def authorized_users_only(func: Callable) -> Callable: - async def decorator(client: Client, message: Message): - if message.from_user.id in SUDO_USERS: - return await func(client, message) - - administrators = await get_administrators(message.chat) - - for administrator in administrators: - if administrator == message.from_user.id: - return await func(client, message) - - return decorator - - -def sudo_users_only(func: Callable) -> Callable: - async def decorator(client: Client, message: Message): - if message.from_user.id in SUDO_USERS: - return await func(client, message) - - return decorator - - -def humanbytes(size): - """Convert Bytes To Bytes So That Human Can Read It""" - if not size: - return "" - power = 2 ** 10 - raised_to_pow = 0 - dict_power_n = {0: "", 1: "Ki", 2: "Mi", 3: "Gi", 4: "Ti"} - while size > power: - size /= power - raised_to_pow += 1 - return str(round(size, 2)) + " " + dict_power_n[raised_to_pow] + "B" diff --git a/driver/design/chatname.py b/driver/design/chatname.py deleted file mode 100644 index 219b102..0000000 --- a/driver/design/chatname.py +++ /dev/null @@ -1,52 +0,0 @@ -async def CHAT_TITLE(ctitle): - string = ctitle - font1 = list("๐”„๐”…โ„ญ๐”‡๐”ˆ๐”‰๐”Šโ„Œโ„‘๐”๐”Ž๐”๐”๐”‘๐”’๐”“๐””โ„œ๐”–๐”—๐”˜๐”™๐”š๐”›๐”œโ„จ") - font2 = list("๐•ฌ๐•ญ๐•ฎ๐•ฏ๐•ฐ๐•ฑ๐•ฒ๐•ณ๐•ด๐•ต๐•ถ๐•ท๐•ธ๐•น๐•บ๐•ป๐•ผ๐•ฝ๐•พ๐•ฟ๐–€๐–๐–‚๐–ƒ๐–„๐–…") - font3 = list("๐“๐“‘๐“’๐““๐“”๐“•๐“–๐“—๐“˜๐“™๐“š๐“›๐“œ๐“๐“ž๐“Ÿ๐“ ๐“ก๐“ข๐“ฃ๐“ค๐“ฅ๐“ฆ๐“ง๐“จ๐“ฉ") - font4 = list("๐’œ๐ต๐’ž๐’Ÿ๐ธ๐น๐’ข๐ป๐ผ๐’ฅ๐’ฆ๐ฟ๐‘€๐’ฉ๐’ช๐’ซ๐’ฌ๐‘…๐’ฎ๐’ฏ๐’ฐ๐’ฑ๐’ฒ๐’ณ๐’ด๐’ต") - font5 = list("๐”ธ๐”นโ„‚๐”ป๐”ผ๐”ฝ๐”พโ„๐•€๐•๐•‚๐•ƒ๐•„โ„•๐•†โ„™โ„šโ„๐•Š๐•‹๐•Œ๐•๐•Ž๐•๐•โ„ค") - font6 = list("๏ผก๏ผข๏ผฃ๏ผค๏ผฅ๏ผฆ๏ผง๏ผจ๏ผฉ๏ผช๏ผซ๏ผฌ๏ผญ๏ผฎ๏ผฏ๏ผฐ๏ผฑ๏ผฒ๏ผณ๏ผด๏ผต๏ผถ๏ผท๏ผธ๏ผน๏ผบ") - font26 = list("๐€๐๐‚๐ƒ๐„๐…๐†๐‡๐ˆ๐‰๐Š๐‹๐Œ๐๐Ž๐๐๐‘๐’๐“๐”๐•๐–๐—๐˜๐™") - font27 = list("๐—”๐—•๐—–๐——๐—˜๐—™๐—š๐—›๐—œ๐—๐—ž๐—Ÿ๐— ๐—ก๐—ข๐—ฃ๐—ค๐—ฅ๐—ฆ๐—ง๐—จ๐—ฉ๐—ช๐—ซ๐—ฌ๐—ญ") - font28 = list("๐˜ˆ๐˜‰๐˜Š๐˜‹๐˜Œ๐˜๐˜Ž๐˜๐˜๐˜‘๐˜’๐˜“๐˜”๐˜•๐˜–๐˜—๐˜˜๐˜™๐˜š๐˜›๐˜œ๐˜๐˜ž๐˜Ÿ๐˜ ๐˜ก") - font29 = list("๐˜ผ๐˜ฝ๐˜พ๐˜ฟ๐™€๐™๐™‚๐™ƒ๐™„๐™…๐™†๐™‡๐™ˆ๐™‰๐™Š๐™‹๐™Œ๐™๐™Ž๐™๐™๐™‘๐™’๐™“๐™”๐™•") - font30 = list("๐™ฐ๐™ฑ๐™ฒ๐™ณ๐™ด๐™ต๐™ถ๐™ท๐™ธ๐™น๐™บ๐™ป๐™ผ๐™ฝ๐™พ๐™ฟ๐š€๐š๐š‚๐šƒ๐š„๐š…๐š†๐š‡๐šˆ๐š‰") - font1L = list("๐”ž๐”Ÿ๐” ๐”ก๐”ข๐”ฃ๐”ค๐”ฅ๐”ฆ๐”ง๐”จ๐”ฉ๐”ช๐”ซ๐”ฌ๐”ญ๐”ฎ๐”ฏ๐”ฐ๐”ฑ๐”ฒ๐”ณ๐”ด๐”ต๐”ถ๐”ท") - font2L = list("๐–†๐–‡๐–ˆ๐–‰๐–Š๐–‹๐–Œ๐–๐–Ž๐–๐–๐–‘๐–’๐–“๐–”๐–•๐––๐–—๐–˜๐–™๐–š๐–›๐–œ๐–๐–ž๐–Ÿ") - font3L = list("๐“ช๐“ซ๐“ฌ๐“ญ๐“ฎ๐“ฏ๐“ฐ๐“ฑ๐“ฒ๐“ณ๐“ด๐“ต๐“ถ๐“ท๐“ธ๐“น๐“บ๐“ป๐“ผ๐“ฝ๐“พ๐“ฟ๐”€๐”๐”‚๐”ƒ") - font4L = list("๐’ถ๐’ท๐’ธ๐’น๐‘’๐’ป๐‘”๐’ฝ๐’พ๐’ฟ๐“€๐“๐“‚๐“ƒ๐‘œ๐“…๐“†๐“‡๐“ˆ๐“‰๐“Š๐“‹๐“Œ๐“๐“Ž๐“") - font5L = list("๐•’๐•“๐•”๐••๐•–๐•—๐•˜๐•™๐•š๐•›๐•œ๐•๐•ž๐•Ÿ๐• ๐•ก๐•ข๐•ฃ๐•ค๐•ฅ๐•ฆ๐•ง๐•จ๐•ฉ๐•ช๐•ซ") - font6L = list("๏ฝ๏ฝ‚๏ฝƒ๏ฝ„๏ฝ…๏ฝ†๏ฝ‡๏ฝˆ๏ฝ‰๏ฝŠ๏ฝ‹๏ฝŒ๏ฝ๏ฝŽ๏ฝ๏ฝ๏ฝ‘๏ฝ’๏ฝ“๏ฝ”๏ฝ•๏ฝ–๏ฝ—๏ฝ˜๏ฝ™๏ฝš") - font27L = list("๐š๐›๐œ๐๐ž๐Ÿ๐ ๐ก๐ข๐ฃ๐ค๐ฅ๐ฆ๐ง๐จ๐ฉ๐ช๐ซ๐ฌ๐ญ๐ฎ๐ฏ๐ฐ๐ฑ๐ฒ๐ณ") - font28L = list("๐—ฎ๐—ฏ๐—ฐ๐—ฑ๐—ฒ๐—ณ๐—ด๐—ต๐—ถ๐—ท๐—ธ๐—น๐—บ๐—ป๐—ผ๐—ฝ๐—พ๐—ฟ๐˜€๐˜๐˜‚๐˜ƒ๐˜„๐˜…๐˜†๐˜‡") - font29L = list("๐˜ข๐˜ฃ๐˜ค๐˜ฅ๐˜ฆ๐˜ง๐˜จ๐˜ฉ๐˜ช๐˜ซ๐˜ฌ๐˜ญ๐˜ฎ๐˜ฏ๐˜ฐ๐˜ฑ๐˜ฒ๐˜ณ๐˜ด๐˜ต๐˜ถ๐˜ท๐˜ธ๐˜น๐˜บ๐˜ป") - font30L = list("๐™–๐™—๐™˜๐™™๐™š๐™›๐™œ๐™๐™ž๐™Ÿ๐™ ๐™ก๐™ข๐™ฃ๐™ค๐™ฅ๐™ฆ๐™ง๐™จ๐™ฉ๐™ช๐™ซ๐™ฌ๐™ญ๐™ฎ๐™ฏ") - font31L = list("๐šŠ๐š‹๐šŒ๐š๐šŽ๐š๐š๐š‘๐š’๐š“๐š”๐š•๐š–๐š—๐š˜๐š™๐šš๐š›๐šœ๐š๐šž๐šŸ๐š ๐šก๐šข๐šฃ") - normal = list("ABCDEFGHIJKLMNOPQRSTUVWXYZ") - normalL = list("abcdefghijklmnopqrstuvwxyz") - cout = 0 - for XCB in font1: - string = string.replace(font1[cout], normal[cout]) - string = string.replace(font2[cout], normal[cout]) - string = string.replace(font3[cout], normal[cout]) - string = string.replace(font4[cout], normal[cout]) - string = string.replace(font5[cout], normal[cout]) - string = string.replace(font6[cout], normal[cout]) - string = string.replace(font26[cout], normal[cout]) - string = string.replace(font27[cout], normal[cout]) - string = string.replace(font28[cout], normal[cout]) - string = string.replace(font29[cout], normal[cout]) - string = string.replace(font30[cout], normal[cout]) - string = string.replace(font1L[cout], normalL[cout]) - string = string.replace(font2L[cout], normalL[cout]) - string = string.replace(font3L[cout], normalL[cout]) - string = string.replace(font4L[cout], normalL[cout]) - string = string.replace(font5L[cout], normalL[cout]) - string = string.replace(font6L[cout], normalL[cout]) - string = string.replace(font27L[cout], normalL[cout]) - string = string.replace(font28L[cout], normalL[cout]) - string = string.replace(font29L[cout], normalL[cout]) - string = string.replace(font30L[cout], normalL[cout]) - string = string.replace(font31L[cout], normalL[cout]) - cout += 1 - return string diff --git a/driver/design/thumbnail.py b/driver/design/thumbnail.py deleted file mode 100644 index ef2ddc6..0000000 --- a/driver/design/thumbnail.py +++ /dev/null @@ -1,50 +0,0 @@ -import os -import aiofiles -import aiohttp -from PIL import Image, ImageDraw, ImageFont - - -def changeImageSize(maxWidth, maxHeight, image): - widthRatio = maxWidth / image.size[0] - heightRatio = maxHeight / image.size[1] - newWidth = int(widthRatio * image.size[0]) - newHeight = int(heightRatio * image.size[1]) - newImage = image.resize((newWidth, newHeight)) - return newImage - - -async def thumb(thumbnail, title, userid, ctitle): - async with aiohttp.ClientSession() as session: - async with session.get(thumbnail) as resp: - if resp.status == 200: - f = await aiofiles.open(f"search/thumb{userid}.png", mode="wb") - await f.write(await resp.read()) - await f.close() - image1 = Image.open(f"search/thumb{userid}.png") - image2 = Image.open("driver/source/LightBlue.png") - image3 = changeImageSize(1280, 720, image1) - image4 = changeImageSize(1280, 720, image2) - image5 = image3.convert("RGBA") - image6 = image4.convert("RGBA") - Image.alpha_composite(image5, image6).save(f"search/temp{userid}.png") - img = Image.open(f"search/temp{userid}.png") - draw = ImageDraw.Draw(img) - font = ImageFont.truetype("driver/source/regular.ttf", 52) - font2 = ImageFont.truetype("driver/source/medium.ttf", 76) - draw.text( - (25, 610), - f"{title[:18]}...", - fill="black", - font=font2, - ) - draw.text( - (27, 535), - f"Playing on {ctitle[:8]}...", - fill="black", - font=font, - ) - img.save(f"search/final{userid}.png") - os.remove(f"search/temp{userid}.png") - os.remove(f"search/thumb{userid}.png") - final = f"search/final{userid}.png" - return final diff --git a/driver/filters.py b/driver/filters.py deleted file mode 100644 index 3eee5a1..0000000 --- a/driver/filters.py +++ /dev/null @@ -1,13 +0,0 @@ -from pyrogram import filters -from typing import List, Union -from config import COMMAND_PREFIXES - - -other_filters = filters.group & ~filters.edited & ~filters.via_bot & ~filters.forwarded -other_filters2 = ( - filters.private & ~filters.edited & ~filters.via_bot & ~filters.forwarded -) - - -def command(commands: Union[str, List[str]]): - return filters.command(commands, COMMAND_PREFIXES) diff --git a/driver/queues.py b/driver/queues.py deleted file mode 100644 index 98c823c..0000000 --- a/driver/queues.py +++ /dev/null @@ -1,34 +0,0 @@ -""" queue storage """ - - -QUEUE = {} - -def add_to_queue(chat_id, songname, link, ref, type, quality, image, duration): - if chat_id in QUEUE: - chat_queue = QUEUE[chat_id] - chat_queue.append([songname, link, ref, type, quality, image, duration]) - return int(len(chat_queue)-1) - else: - QUEUE[chat_id] = [[songname, link, ref, type, quality, image, duration]] - -def get_queue(chat_id): - if chat_id in QUEUE: - chat_queue = QUEUE[chat_id] - return chat_queue - else: - return 0 - -def pop_an_item(chat_id): - if chat_id in QUEUE: - chat_queue = QUEUE[chat_id] - chat_queue.pop(0) - return 1 - else: - return 0 - -def clear_queue(chat_id): - if chat_id in QUEUE: - QUEUE.pop(chat_id) - return 1 - else: - return 0 diff --git a/driver/source/LightBlue.png b/driver/source/LightBlue.png deleted file mode 100644 index a599d38..0000000 Binary files a/driver/source/LightBlue.png and /dev/null differ diff --git a/driver/source/__init__.py b/driver/source/__init__.py deleted file mode 100644 index 4dd8bcb..0000000 --- a/driver/source/__init__.py +++ /dev/null @@ -1 +0,0 @@ -"""storage""" diff --git a/driver/source/medium.ttf b/driver/source/medium.ttf deleted file mode 100644 index 2ceaf63..0000000 Binary files a/driver/source/medium.ttf and /dev/null differ diff --git a/driver/source/regular.ttf b/driver/source/regular.ttf deleted file mode 100644 index 7d9a6c4..0000000 Binary files a/driver/source/regular.ttf and /dev/null differ diff --git a/driver/utils.py b/driver/utils.py deleted file mode 100644 index bc17c62..0000000 --- a/driver/utils.py +++ /dev/null @@ -1,141 +0,0 @@ -""" utilities """ - -import os -import asyncio -from driver.veez import bot, call_py -from pytgcalls.types import Update -from pytgcalls.types.input_stream import AudioPiped, AudioVideoPiped -from driver.queues import ( - QUEUE, - clear_queue, - get_queue, - pop_an_item, -) -from pytgcalls.types.input_stream.quality import ( - HighQualityAudio, - HighQualityVideo, - LowQualityVideo, - MediumQualityVideo, -) -from pyrogram.types import ( - CallbackQuery, - InlineKeyboardButton, - InlineKeyboardMarkup, - Message, -) -from pyrogram import Client, filters -from pytgcalls.types.stream import StreamAudioEnded, StreamVideoEnded - - -keyboard = InlineKeyboardMarkup( - [ - [ - InlineKeyboardButton(text="โ€ข Mแด‡ษดแดœ", callback_data="cbmenu"), - InlineKeyboardButton(text="โ€ข CสŸแดsแด‡", callback_data="cls"), - ] - ] - ) - - -async def skip_current_song(chat_id): - if chat_id in QUEUE: - chat_queue = get_queue(chat_id) - if len(chat_queue) == 1: - await call_py.leave_group_call(chat_id) - clear_queue(chat_id) - return 1 - else: - try: - songname = chat_queue[1][0] - url = chat_queue[1][1] - link = chat_queue[1][2] - type = chat_queue[1][3] - Q = chat_queue[1][4] - image = chat_queue[1][5] - duration = chat_queue[1][6] - if type == "Audio": - await call_py.change_stream( - chat_id, - AudioPiped( - url, - ), - ) - elif type == "Video": - if Q == 720: - hm = HighQualityVideo() - elif Q == 480: - hm = MediumQualityVideo() - elif Q == 360: - hm = LowQualityVideo() - await call_py.change_stream( - chat_id, AudioVideoPiped(url, HighQualityAudio(), hm) - ) - pop_an_item(chat_id) - return [songname, link, type, image, duration] - except: - await call_py.leave_group_call(chat_id) - clear_queue(chat_id) - return 2 - else: - return 0 - - -async def skip_item(chat_id, h): - if chat_id in QUEUE: - chat_queue = get_queue(chat_id) - try: - x = int(h) - songname = chat_queue[x][0] - chat_queue.pop(x) - return songname - except Exception as e: - print(e) - return 0 - else: - return 0 - - -@call_py.on_kicked() -async def kicked_handler(_, chat_id: int): - if chat_id in QUEUE: - clear_queue(chat_id) - - -@call_py.on_closed_voice_chat() -async def closed_voice_chat_handler(_, chat_id: int): - if chat_id in QUEUE: - clear_queue(chat_id) - - -@call_py.on_left() -async def left_handler(_, chat_id: int): - if chat_id in QUEUE: - clear_queue(chat_id) - - -@call_py.on_stream_end() -async def stream_end_handler(_, u: Update): - if isinstance(u, StreamAudioEnded): - chat_id = u.chat_id - print(chat_id) - op = await skip_current_song(chat_id) - if op==1: - await bot.send_message(chat_id, "โœ… streaming end") - elif op==2: - await bot.send_message(chat_id, "โŒ an error occurred\n\nยป **Clearing** __Queues__ and leaving video chat.") - else: - await bot.send_message(chat_id, f"๐Ÿ’ก **Streaming next track**\n\n๐Ÿท **Name:** [{op[0]}]({op[1]}) | `{op[2]}`\nโฑ **Duration:** `{op[3]}`", disable_web_page_preview=True, reply_markup=keyboard) - else: - pass - - -async def bash(cmd): - process = await asyncio.create_subprocess_shell( - cmd, - stdout=asyncio.subprocess.PIPE, - stderr=asyncio.subprocess.PIPE, - ) - stdout, stderr = await process.communicate() - err = stderr.decode().strip() - out = stdout.decode().strip() - return out, err diff --git a/driver/veez.py b/driver/veez.py deleted file mode 100644 index e0d09ff..0000000 --- a/driver/veez.py +++ /dev/null @@ -1,19 +0,0 @@ -from config import API_HASH, API_ID, BOT_TOKEN, SESSION_NAME -from pyrogram import Client -from pytgcalls import PyTgCalls - -bot = Client( - ":veez:", - API_ID, - API_HASH, - bot_token=BOT_TOKEN, - plugins={"root": "program"}, -) - -user = Client( - SESSION_NAME, - api_id=API_ID, - api_hash=API_HASH, -) - -call_py = PyTgCalls(user, overload_quiet_mode=True) diff --git a/driver/veezlogo.png b/driver/veezlogo.png deleted file mode 100644 index 965ebe2..0000000 Binary files a/driver/veezlogo.png and /dev/null differ