mirror of
https://github.com/LiteyukiStudio/nonebot-plugin-marshoai.git
synced 2025-01-26 18:12:47 +08:00
✨ 添加内置工具插件,支持获取已加载插件列表和读取本地文件内容功能
This commit is contained in:
parent
d8ac06419b
commit
1e58944edc
3
.gitignore
vendored
3
.gitignore
vendored
@ -185,3 +185,6 @@ praises.json
|
||||
node_modules/
|
||||
docs/.vitepress/cache
|
||||
docs/.vitepress/dist
|
||||
|
||||
# viztracer
|
||||
result.json
|
@ -1,8 +1,6 @@
|
||||
"""该功能目前~~正在开发中~~开发基本完成,暂时~~不~~可用,受影响的文件夹 `plugin`, `plugins`
|
||||
"""
|
||||
|
||||
from nonebot import logger
|
||||
|
||||
from .func_call import *
|
||||
from .load import *
|
||||
from .models import *
|
||||
|
@ -39,12 +39,12 @@ class Caller:
|
||||
if self.bot is None or self.event is None:
|
||||
return False, "Context is None"
|
||||
if self._permission and not await self._permission(self.bot, self.event):
|
||||
return False, "Permission Denied 权限不足"
|
||||
return False, "告诉用户 Permission Denied 权限不足"
|
||||
|
||||
if self.state is None:
|
||||
return False, "State is None"
|
||||
if self._rule and not await self._rule(self.bot, self.event, self.state):
|
||||
return False, "Rule Denied 规则不匹配"
|
||||
return False, "告诉用户 Rule Denied 规则不匹配"
|
||||
|
||||
return True, ""
|
||||
|
||||
@ -92,10 +92,10 @@ class Caller:
|
||||
self.func = async_wrap(func) # type: ignore
|
||||
|
||||
if module := inspect.getmodule(func):
|
||||
module_name = module.__name__ + "."
|
||||
module_name = module.__name__.split(".")[-1] + "."
|
||||
else:
|
||||
module_name = ""
|
||||
logger.opt(colors=True).info(
|
||||
logger.opt(colors=True).debug(
|
||||
f"<y>加载函数 {module_name}{func.__name__}: {self._description}</y>"
|
||||
)
|
||||
|
||||
|
@ -19,6 +19,8 @@ _plugins: dict[str, Plugin] = {}
|
||||
__all__ = [
|
||||
"load_plugin",
|
||||
"load_plugins",
|
||||
"get_plugin",
|
||||
"get_plugins",
|
||||
"_plugins",
|
||||
]
|
||||
|
||||
|
12
nonebot_plugin_marshoai/plugins/builtin_tools/__init__.py
Normal file
12
nonebot_plugin_marshoai/plugins/builtin_tools/__init__.py
Normal file
@ -0,0 +1,12 @@
|
||||
from nonebot_plugin_marshoai.plugin import PluginMetadata
|
||||
|
||||
from .file_io import *
|
||||
from .manager import *
|
||||
from .network import *
|
||||
|
||||
__marsho_meta__ = PluginMetadata(
|
||||
name="内置增强组件",
|
||||
version="0.0.1",
|
||||
description="内置工具插件",
|
||||
author="MarshoTeam of LiteyukiStudio",
|
||||
)
|
23
nonebot_plugin_marshoai/plugins/builtin_tools/file_io.py
Normal file
23
nonebot_plugin_marshoai/plugins/builtin_tools/file_io.py
Normal file
@ -0,0 +1,23 @@
|
||||
import aiofiles # type: ignore
|
||||
from nonebot.permission import SUPERUSER
|
||||
|
||||
from nonebot_plugin_marshoai.plugin import String, on_function_call
|
||||
|
||||
|
||||
@on_function_call(description="获取设备上本地文件内容").params(
|
||||
fp=String(description="文件路径")
|
||||
).permission(SUPERUSER)
|
||||
async def read_file(fp: str) -> str:
|
||||
"""获取设备上本地文件内容
|
||||
|
||||
Args:
|
||||
fp (str): 文件路径
|
||||
|
||||
Returns:
|
||||
str: 文件内容
|
||||
"""
|
||||
try:
|
||||
async with aiofiles.open(fp, "r", encoding="utf-8") as f:
|
||||
return await f.read()
|
||||
except Exception as e:
|
||||
return "读取出错: " + str(e)
|
18
nonebot_plugin_marshoai/plugins/builtin_tools/manager.py
Normal file
18
nonebot_plugin_marshoai/plugins/builtin_tools/manager.py
Normal file
@ -0,0 +1,18 @@
|
||||
from nonebot_plugin_marshoai.plugin import get_plugins, on_function_call
|
||||
|
||||
|
||||
@on_function_call(description="获取已加载的插件列表")
|
||||
def get_marsho_plugins() -> str:
|
||||
"""获取已加载的插件列表
|
||||
|
||||
Returns:
|
||||
str: 插件列表
|
||||
"""
|
||||
|
||||
reply = "加载的插件列表"
|
||||
for p in get_plugins().values():
|
||||
if p.metadata:
|
||||
reply += f"名称: {p.metadata.name},描述: {p.metadata.description}\n"
|
||||
else:
|
||||
reply += f"名称: {p.name},描述: 暂无\n"
|
||||
return reply
|
48
nonebot_plugin_marshoai/plugins/builtin_tools/network.py
Normal file
48
nonebot_plugin_marshoai/plugins/builtin_tools/network.py
Normal file
@ -0,0 +1,48 @@
|
||||
import time
|
||||
|
||||
from httpx import AsyncClient
|
||||
from newspaper import Article
|
||||
from nonebot import logger
|
||||
|
||||
from nonebot_plugin_marshoai.plugin.func_call.caller import on_function_call
|
||||
from nonebot_plugin_marshoai.plugin.func_call.params import String
|
||||
|
||||
headers = {
|
||||
"User-Agent": "Firefox/90.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0"
|
||||
}
|
||||
|
||||
|
||||
@on_function_call(
|
||||
description="使用网页链接(url)获取网页内容摘要,可以让AI上网查询资料"
|
||||
).params(
|
||||
url=String(description="网页链接"),
|
||||
typ=String(description="获取类型,摘要还是内容", enum=["摘要", "内容"]),
|
||||
)
|
||||
async def get_web_content(url: str, typ: str) -> str:
|
||||
"""使用网页链接获取网页内容摘要
|
||||
为什么要获取摘要,不然token超限了
|
||||
|
||||
Args:
|
||||
url (str): _description_
|
||||
|
||||
Returns:
|
||||
str: _description_
|
||||
"""
|
||||
async with AsyncClient(headers=headers) as client:
|
||||
try:
|
||||
response = await client.get(url)
|
||||
t1 = time.time()
|
||||
article = Article(url)
|
||||
article.set_html(response.text)
|
||||
article.parse()
|
||||
t2 = time.time()
|
||||
logger.debug(f"获取网页内容耗时: {t2 - t1}")
|
||||
if typ == "摘要":
|
||||
return f"标题: {article.title}\n作者: {article.authors}\n发布日期: {article.publish_date}"
|
||||
elif typ == "内容":
|
||||
return f"标题: {article.title}\n作者: {article.authors}\n发布日期: {article.publish_date}\n摘要: {article.summary}\n正文: {article.text}"
|
||||
except Exception as e:
|
||||
logger.error(f"marsho builtin: 获取网页内容失败: {e}")
|
||||
return "获取网页内容失败:" + str(e)
|
||||
|
||||
return "未能获取到有效的网页内容"
|
@ -21,7 +21,10 @@ dependencies = [
|
||||
"psutil>=6.1.0",
|
||||
"beautifulsoup4>=4.12.3",
|
||||
"pydantic>=2.10.3",
|
||||
"litedoc>=0.1.0.dev20241214103915"
|
||||
"litedoc>=0.1.0.dev20241214103915",
|
||||
"newspaper3k>=0.2.8",
|
||||
"lxml[html_clean]>=5.3.0",
|
||||
"aiofiles>=24.1.0"
|
||||
|
||||
]
|
||||
license = { text = "MIT, Mulan PSL v2" }
|
||||
@ -65,6 +68,7 @@ dev = [
|
||||
"mypy>=1.13.0",
|
||||
"black>=24.10.0",
|
||||
"litedoc>=0.1.0.dev20240906203154",
|
||||
"viztracer>=1.0.0",
|
||||
]
|
||||
test = [
|
||||
"nonebug>=0.4.3",
|
||||
|
Loading…
x
Reference in New Issue
Block a user