Fix: shell.py
This commit is contained in:
@@ -1,28 +1,10 @@
|
||||
# Moon-Userbot - telegram userbot
|
||||
# Copyright (C) 2020-present Moon Userbot Organization
|
||||
# Copyright (C) 2020-present Dragon Userbot Organization
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
# This program 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 General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
import subprocess
|
||||
import shlex
|
||||
import os
|
||||
from time import perf_counter
|
||||
|
||||
from pyrogram import Client, filters
|
||||
from pyrogram.types import Message
|
||||
from pyrogram import enums as enums
|
||||
|
||||
from utils.misc import modules_help, prefix
|
||||
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
@@ -36,7 +18,7 @@ from subprocess import Popen, PIPE, TimeoutExpired
|
||||
import os
|
||||
from time import perf_counter
|
||||
|
||||
from pyrogram import Client, filters
|
||||
from pyrogram import Client, filters, enums
|
||||
from pyrogram.types import Message
|
||||
|
||||
from utils.misc import modules_help, prefix
|
||||
@@ -47,18 +29,13 @@ async def shell(_, message: Message):
|
||||
if len(message.command) < 2:
|
||||
return await message.edit("<b>Specify the command in message text</b>", parse_mode=enums.ParseMode.HTML)
|
||||
cmd_text = message.text.split(maxsplit=1)[1]
|
||||
cmd_args = shlex.split(cmd_text)
|
||||
cmd_obj = subprocess.Popen(
|
||||
cmd_args,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE,
|
||||
cmd_obj = Popen(
|
||||
cmd_text,
|
||||
shell=True,
|
||||
stdout=PIPE,
|
||||
stderr=PIPE,
|
||||
text=True,
|
||||
)
|
||||
try:
|
||||
stdout, stderr = cmd_obj.communicate(timeout=60)
|
||||
except subprocess.TimeoutExpired:
|
||||
cmd_obj.kill()
|
||||
text += "<b>Timeout expired (60 seconds)</b>"
|
||||
|
||||
char = "#" if os.getuid() == 0 else "$"
|
||||
text = f"<b>{char}</b> <code>{cmd_text}</code>\n\n"
|
||||
@@ -66,18 +43,18 @@ async def shell(_, message: Message):
|
||||
await message.edit(text + "<b>Running...</b>", parse_mode=enums.ParseMode.HTML)
|
||||
try:
|
||||
start_time = perf_counter()
|
||||
stdout, stderr = cmd_obj.stdout, cmd_obj.stderr
|
||||
except subprocess.TimeoutExpired:
|
||||
stdout, stderr = cmd_obj.communicate(timeout=60)
|
||||
except TimeoutExpired:
|
||||
text += "<b>Timeout expired (60 seconds)</b>"
|
||||
else:
|
||||
stop_time = perf_counter()
|
||||
if stdout:
|
||||
text += "<b>Output:</b>\n" f"<code>{stdout}</code>\n\n"
|
||||
text += f"<b>Output:</b>\n<code>{stdout}</code>\n\n"
|
||||
if stderr:
|
||||
text += "<b>Error:</b>\n" f"<code>{stderr}</code>\n\n"
|
||||
text += f"<b>Error:</b>\n<code>{stderr}</code>\n\n"
|
||||
text += f"<b>Completed in {round(stop_time - start_time, 5)} seconds with code {cmd_obj.returncode}</b>"
|
||||
await message.edit(text, parse_mode=enums.ParseMode.HTML)
|
||||
cmd_obj.kill()
|
||||
|
||||
|
||||
modules_help["shell"] = {"sh [command]*": "Execute command in shell"}
|
||||
modules_help["shell"] = {"sh [command]*": "Execute command in shell"}
|
||||
Reference in New Issue
Block a user