Merge pull request #18 from Fairy-Oracle-Sanctuary/dev

Dev
This commit is contained in:
镀铬酸钾
2026-01-02 19:45:07 +08:00
committed by GitHub
3 changed files with 98 additions and 2 deletions

View File

@@ -1,5 +1,6 @@
from .command_manager import matcher
from .config_loader import global_config
from .ws import WS
from .plugin_manager import PluginDataManager
from .WS import WS
__all__ = ["WS", "matcher", "global_config", "PluginDataManager"]

89
plugins/code_py.py Normal file
View File

@@ -0,0 +1,89 @@
"""
code_py插件
输入/code py回车再加上python代码机器人就会执行代码并返回执行结果。
"""
import asyncio
import os
import sys
import tempfile
from typing import Tuple
from core.bot import Bot
from core.command_manager import matcher
from models import MessageEvent
__plugin_meta__ = {
"name": "code_py",
"description": "提供执行python代码的功能",
"usage": "/code py [python代码] - 执行python代码",
}
@matcher.command("code_py")
async def execute_python_code(bot: Bot, event: MessageEvent, args: list[str]):
if not args:
await event.reply("请提供要执行的Python代码。用法/code_py [python代码]")
return
code = " ".join(args)
async def run_code_in_subprocess(
code_str: str, timeout: float = 5.0
) -> Tuple[str, str]:
# 这里用临时文件
with tempfile.NamedTemporaryFile(
"w", suffix=".py", delete=False, encoding="utf-8"
) as tf:
tf.write(code_str)
tf_path = tf.name
try:
proc = await asyncio.create_subprocess_exec(
sys.executable,
tf_path,
stdout=asyncio.subprocess.PIPE,
stderr=asyncio.subprocess.PIPE,
)
try:
out_bytes, err_bytes = await asyncio.wait_for(
proc.communicate(), timeout=timeout
)
except asyncio.TimeoutError:
proc.kill()
await proc.communicate()
return "", f"执行超时(>{timeout}s"
return out_bytes.decode(errors="ignore"), err_bytes.decode(errors="ignore")
finally:
try:
os.remove(tf_path)
except Exception:
pass
try:
stdout, stderr = await run_code_in_subprocess(code, timeout=5.0)
except Exception as e:
await event.reply(f"执行失败:{e}")
return
# 优先显示 stderr如果 stderr 为空则显示 stdout
resp = stderr.strip() or stdout.strip() or "(无输出)"
# 限制返回长度,避免过长消息
MAX = 1500
if len(resp) > MAX:
resp = resp[:MAX] + "\n...输出被截断..."
nodes = [
bot.build_forward_node(user_id=event.self_id, nickname="机器人", message=code),
bot.build_forward_node(
user_id=event.self_id, nickname="机器人", message="执行结果:\n" + resp
),
]
try:
await bot.send_forwarded_messages(event, nodes)
except Exception as e:
await event.reply(f"发送失败: {e}")

View File

@@ -3,6 +3,7 @@
提供 /jrcd 和 /bbcd 指令,用于娱乐。
"""
import random
from datetime import datetime
@@ -100,8 +101,13 @@ async def handle_bbcd(bot: Bot, event: MessageEvent, args: list[str]):
print(message)
if len(message) < 2:
return
user_id1 = event.user_id
try:
user_id2 = int(message[1].data.get("qq", 0))
except Exception:
return
if user_id1 == user_id2:
await event.reply("不能和自己比!")
return