mirror of
https://github.com/yasirarism/MissKatyPyro.git
synced 2025-12-29 17:44:50 +00:00
* 'Refactored by Sourcery' * reformating: code Co-authored-by: Sourcery AI <> Co-authored-by: yasirarism <yasiramunandar@gmail.com>
165 lines
5.6 KiB
Python
165 lines
5.6 KiB
Python
import asyncio
|
|
import io
|
|
import os
|
|
import sys
|
|
import traceback
|
|
|
|
from pyrogram import enums, filters
|
|
from pyrogram.types import InlineKeyboardButton, InlineKeyboardMarkup
|
|
|
|
from misskaty import app
|
|
from misskaty.vars import COMMAND_HANDLER, SUDO
|
|
|
|
__MODULE__ = "DevCommand"
|
|
__HELP__ = """
|
|
**For Owner Bot Only.**
|
|
/run [args] - Run eval CMD
|
|
/shell [args] - Run Exec/Terminal CMD
|
|
/download [link/reply_to_telegram_file] - Download file from Telegram
|
|
|
|
**For Public Use**
|
|
/json - Send structure message Telegram in JSON using Pyrogram Style.
|
|
"""
|
|
|
|
|
|
@app.on_message(filters.command(["logs"], COMMAND_HANDLER) & filters.user(SUDO))
|
|
async def log_file(bot, message):
|
|
"""Send log file"""
|
|
try:
|
|
await message.reply_document(
|
|
"MissKatyLogs.txt",
|
|
caption="Log Bot MissKatyPyro",
|
|
reply_markup=InlineKeyboardMarkup(
|
|
[
|
|
[
|
|
InlineKeyboardButton(
|
|
text="❌ Close",
|
|
callback_data=f"close#{message.from_user.id}",
|
|
)
|
|
]
|
|
]
|
|
),
|
|
)
|
|
except Exception as e:
|
|
await message.reply(str(e))
|
|
|
|
|
|
@app.on_message(filters.command(["donate"], COMMAND_HANDLER))
|
|
async def donate(_, message):
|
|
await message.reply_photo(
|
|
"AgACAgQAAxkBAAECsVNjbMvjxbN4gRafvNBH-Kv-Zqml8wACzq4xG95tbVPDeZ_UusonbAAIAQADAgADeQAHHgQ",
|
|
caption=f"Hai {message.from_user.mention}, jika kamu merasa bot ini berguna bisa melakukan donasi dengan scan kode QRIS diatas untuk kebutuhan server dan lainnya. Terimakasih..",
|
|
)
|
|
|
|
|
|
@app.on_message(filters.command(["balas"], COMMAND_HANDLER) & filters.user(SUDO) & filters.reply)
|
|
async def balas(c, m):
|
|
pesan = m.text.split(" ", 1)
|
|
await m.delete()
|
|
await m.reply(pesan[1], reply_to_message_id=m.reply_to_message.id)
|
|
|
|
|
|
@app.on_message(filters.command(["neofetch"], COMMAND_HANDLER) & filters.user(SUDO))
|
|
async def neofetch(c, m):
|
|
neofetch = (await shell_exec("neofetch --stdout"))[0]
|
|
await m.reply(f"<code>{neofetch}</code>")
|
|
|
|
|
|
@app.on_message(filters.command(["shell", "sh"], COMMAND_HANDLER) & filters.user(SUDO))
|
|
@app.on_edited_message(filters.command(["shell", "sh"], COMMAND_HANDLER) & filters.user(SUDO))
|
|
async def shell(_, m):
|
|
cmd = m.text.split(" ", 1)
|
|
if len(cmd) == 1:
|
|
return await m.reply("No command to execute was given.")
|
|
shell = (await shell_exec(cmd[1]))[0]
|
|
if len(shell) > 3000:
|
|
with open("shell_output.txt", "w") as file:
|
|
file.write(shell)
|
|
with open("shell_output.txt", "rb") as doc:
|
|
await m.reply_document(
|
|
document=doc,
|
|
file_name=doc.name,
|
|
reply_markup=InlineKeyboardMarkup([[InlineKeyboardButton(text="❌ Close", callback_data=f"close#{m.from_user.id}")]]),
|
|
)
|
|
try:
|
|
os.remove("shell_output.txt")
|
|
except:
|
|
pass
|
|
elif len(shell) != 0:
|
|
await m.reply(
|
|
shell,
|
|
parse_mode=enums.ParseMode.HTML,
|
|
reply_markup=InlineKeyboardMarkup([[InlineKeyboardButton(text="❌ Close", callback_data=f"close#{m.from_user.id}")]]),
|
|
)
|
|
else:
|
|
await m.reply("No Reply")
|
|
|
|
|
|
@app.on_message(filters.command(["ev", "run"], COMMAND_HANDLER) & filters.user(SUDO))
|
|
@app.on_edited_message(filters.command(["ev", "run"]) & filters.user(SUDO))
|
|
async def evaluation_cmd_t(_, m):
|
|
status_message = await m.reply("__Processing eval pyrogram...__")
|
|
try:
|
|
cmd = m.text.split(" ", maxsplit=1)[1]
|
|
except IndexError:
|
|
return await status_message.edit("__No evaluate message!__")
|
|
|
|
old_stderr = sys.stderr
|
|
old_stdout = sys.stdout
|
|
redirected_output = sys.stdout = io.StringIO()
|
|
redirected_error = sys.stderr = io.StringIO()
|
|
stdout, stderr, exc = None, None, None
|
|
|
|
try:
|
|
await aexec(cmd, _, m)
|
|
except Exception:
|
|
exc = traceback.format_exc()
|
|
|
|
stdout = redirected_output.getvalue()
|
|
stderr = redirected_error.getvalue()
|
|
sys.stdout = old_stdout
|
|
sys.stderr = old_stderr
|
|
|
|
evaluation = ""
|
|
if exc:
|
|
evaluation = exc
|
|
elif stderr:
|
|
evaluation = stderr
|
|
elif stdout:
|
|
evaluation = stdout
|
|
else:
|
|
evaluation = "Success"
|
|
|
|
final_output = f"**EVAL**:\n`{cmd}`\n\n**OUTPUT**:\n`{evaluation.strip()}`\n"
|
|
|
|
if len(final_output) > 4096:
|
|
with open("MissKatyEval.txt", "w+", encoding="utf8") as out_file:
|
|
out_file.write(final_output)
|
|
await status_message.reply_document(
|
|
document="MissKatyEval.txt",
|
|
caption=f"<code>{cmd[: 4096 // 4 - 1]}</code>",
|
|
disable_notification=True,
|
|
reply_markup=InlineKeyboardMarkup([[InlineKeyboardButton(text="❌ Close", callback_data=f"close#{m.from_user.id}")]]),
|
|
)
|
|
os.remove("MissKatyEval.txt")
|
|
await status_message.delete()
|
|
else:
|
|
await status_message.edit(
|
|
final_output,
|
|
parse_mode=enums.ParseMode.MARKDOWN,
|
|
reply_markup=InlineKeyboardMarkup([[InlineKeyboardButton(text="❌ Close", callback_data=f"close#{m.from_user.id}")]]),
|
|
)
|
|
|
|
|
|
async def aexec(code, c, m):
|
|
exec("async def __aexec(c, m): " + "\n p = print" + "\n replied = m.reply_to_message" + "".join(f"\n {l_}" for l_ in code.split("\n")))
|
|
return await locals()["__aexec"](c, m)
|
|
|
|
|
|
async def shell_exec(code, treat=True):
|
|
process = await asyncio.create_subprocess_shell(code, stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.STDOUT)
|
|
|
|
stdout = (await process.communicate())[0]
|
|
if treat:
|
|
stdout = stdout.decode().strip()
|
|
return stdout, process
|