Skip to content

69gg/Undefined

Repository files navigation

Undefined

QQ bot platform with cognitive memory architecture and multi-agent Skills, via OneBot V11.

Python uv License PyPI Ask DeepWiki

大鹏一日同风起,扶摇直上九万里。

项目简介

Undefined 是一个基于 Python 异步架构的高性能 QQ 机器人平台,搭载认知记忆架构,采用自研 Skills 系统,内置多个智能 Agent,支持代码分析、网络搜索、娱乐互动等多模态能力,并提供 Management-first WebUI 在线管理,以及可连接同一管理服务的 Desktop / Android App

Undefined

NagaAgent 进行联动!


⚡ 立即体验

点击添加官方实例QQ

推荐上手方式:优先运行 uv run Undefined-webui。它会先拉起管理控制台,你可以在浏览器里直接补配置、校验配置、查看日志、启动 Bot;后续也可以用桌面端或 Android App 连接这同一个管理入口,实现远程管理。

⚡ 核心特性

  • Skills 架构:全新设计的技能系统,将基础工具(Tools)与智能代理(Agents)分层管理,支持自动发现与注册。
  • Skills 热重载:自动扫描 skills/ 目录,检测到变更后即时重载工具与 Agent,无需重启服务。
  • 三层分层记忆架构:创新的分层记忆系统,模拟人类记忆机制——
    • 短期记忆end.memo):每轮对话结束自动记录便签备忘,最近 N 条始终注入,保持短期连续性,零配置开箱即用
    • 认知记忆end.observations + cognitive.*):核心层,AI 在每轮对话中主动观察并提取用户/群聊事实及有价值的自身行为,经后台史官异步改写后存入向量数据库;支持语义检索、时间衰减加权排序、MMR 多样性去重、跨群记忆联动与用户/群聊自动侧写(合并时注入历史事件防止特征丢失),前台零延迟
    • 置顶备忘录memory.*):AI 自身的置顶提醒(自我约束、待办事项),每轮固定注入,支持增删改查 详见 认知记忆文档
  • Management-first WebUI:继续保留 uv run Undefined-webui 一键入口;即使 config.toml 缺失或未配完,也能先进入管理态补配置、看日志、校验并启动 Bot。
  • 远程管理 + 多端客户端:浏览器版 WebUI 与新的跨平台控制台共享同一管理面,支持远程管理,并覆盖 Windows / macOS / Linux / Android 发布链路。
  • Management API + Runtime API 分层:配置、日志、Bot 启停和管理探针由 Management API 提供;主进程 Runtime API 则专注探针、记忆只读查询、认知侧写检索和 WebUI AI Chat。详见 docs/management-api.mddocs/openapi.md
  • 多模型池:支持配置多个 AI 模型,可轮询、随机选择或用户指定;支持多模型并发比较,选择最佳结果继续对话。详见 多模型功能文档
  • 本地知识库:将纯文本文件向量化存入 ChromaDB,AI 可通过关键词搜索或语义搜索查询领域知识;支持增量嵌入与自动扫描。详见 知识库文档
  • 访问控制(群/私聊):支持 access.mode 三种模式(off / blacklist / allowlist)和群/私聊黑白名单;可按策略限制收发范围,避免误触发与误投递。详见 docs/access-control.md
  • 并行工具执行:无论是主 AI 还是子 Agent,均支持 asyncio 并发工具调用,大幅提升多任务处理速度(如同时读取多个文件或搜索多个关键词)。
  • 智能 Agent 矩阵:内置多个专业 Agent,分工协作处理复杂任务。
  • callable.json 共享机制:通过简单的配置文件(callable.json)即可让 Agent 互相调用、将 skills/tools/skills/toolsets/ 下的工具按白名单暴露给 Agent,支持细粒度访问控制,实现复杂的多 Agent 协作场景。
  • Agent 自我介绍自动生成:启动时按 Agent 代码/配置 hash 生成 intro.generated.md(第一人称、结构化),与 intro.md 合并后作为描述;减少手动维护,保持能力说明与实现同步,有助于精准调度。
  • 请求上下文管理:基于 Python contextvars 的统一请求上下文系统,自动 UUID 追踪,零竞态条件,完全的并发隔离。
  • 定时任务系统:支持 Crontab 语法的强大定时任务系统,可自动执行各种操作(如定时提醒、定时搜索),并支持“向未来的自己发指令”(self_instruction 自调用模式)。
  • MCP 协议支持:支持通过 MCP (Model Context Protocol) 连接外部工具和数据源,扩展 AI 能力。
  • Agent 私有 MCP:可为单个 agent 提供独立 MCP 配置,按调用即时加载并释放,工具仅对该 agent 可见。
  • Anthropic Skills:支持 Anthropic Agent Skills(SKILL.md 格式),遵循 agentskills.io 开放标准,提供领域知识注入能力。
  • Bilibili 视频提取:自动检测消息中的 B 站视频链接/BV 号/小程序分享,下载 1080p 视频并通过 QQ 发送;同时提供 AI 工具调用入口。
  • 思维链支持:支持开启思维链,提升复杂逻辑推理能力。
  • 高并发架构:基于 asyncio 全异步设计,支持多队列消息处理与工具并发执行,轻松应对高并发场景。
  • 异步安全 I/O:统一 IO 层通过线程池 + 跨平台文件锁(Linux/macOS flock,Windows msvcrt)+ 原子写入(os.replace)保证并发写入不损坏、且不阻塞主事件循环。
  • 安全防护:内置独立的安全模型,实时检测注入攻击与恶意内容。
  • OneBot 协议:完美兼容 OneBot V11 协议,支持多种前端实现(如 NapCat)。

想详细了解这些特性是如何组织的?请看完整系统架构: 👉 ARCHITECTURE.md


📖 官方文档导航

Undefined 的功能极为丰富,为了让本页面不过于臃肿,我们将各个模块的深入解析与高阶玩法整理成了专题游览图。这里是开启探索的钥匙:

  • ⚙️ 安装与部署指南:不管你是需要 pip 无脑一键安装,还是源码二次开发,这里的排坑指南应有尽有。
  • 🧭 Management API 与远程管理:WebUI / App 共用的管理接口、认证、配置/日志/Bot 控制与引导探针说明。
  • 🛠️ 配置与热更新说明:从模型切换到 MCP 库挂载,全方位掌握 config.toml 的高阶配置。
  • 💡 交互与使用手册:包含实用的对话示例、多模态解析用法,以及群管家必备的管理员/指令
  • 🛡️ 访问控制说明:教你如何精准配置黑白名单,让机器人的使用范围分毫不差。
  • 🧠 认知记忆系统详解:黑科技解密——“无阻塞后台史官”是如何将对话内化为向量记忆与用户侧写的。
  • 📚 本地知识库接入方案:为 AI 挂载本地文本资产,轻松拥抱企业/个人专属 QA。
  • 🔄 多模型并发竞技:配置多个异构模型,让它们并行运算、同台 PK,从中择优响应。
  • ⌨️ 命令系统与斜杠指令:查阅所有斜杠指令(/*)的详细用法,并学习如何轻松扩展你自己的指令系统。
  • 🌐 Runtime API 与 OpenAPI:主进程 Runtime API、鉴权、探针、记忆/侧写查询和运行态集成说明。
  • 🏗️ 构建指南:Python 包、WebUI、跨平台 App、Android 与 Release 工作流的构建说明。
  • 🔧 运维脚本:嵌入模型更换后的向量库重嵌入等维护工具。
  • 👨‍💻 开发者与拓展中心:代码结构剖析和开发新 Agent 的流程参考及自检命令。

⚡ 快速开始 (源码模式)

👶 新手必看:如果您是首次部署此类项目或不熟悉 Git/环境配置,强烈建议直接前往 《详细安装与部署指南》 阅读手把手教程,避免遇到常见报错。

以下步骤适合有一定开发经验、想快速跑起项目源码的用户。我们推荐使用现代 Python 构建工具 uv

# 1. 完整克隆源码库(注意附带 NagaAgent 模块)
git clone --recursive https://github.com/69gg/Undefined.git

# 2. 进入目录并安装项目依赖包
cd Undefined
pip install uv # 若未安装 uv
uv sync            # uv 将自动为你处理兼容的 Python 解释器并安装包
uv run playwright install  # 安装浏览器内核(用于页面截图等能力)

# 3. 启动管理控制台(推荐入口)
uv run Undefined-webui

# 4. 在 WebUI 中补齐/校验配置,然后直接点击启动 Bot
#    如需先手动准备配置,也可以再执行:
# cp config.toml.example config.toml

浏览器是默认入口;如果你下载了 Release 中的桌面端或 Android 安装包,也可以在完成首轮密码设置后,连接到同一个 Management API 地址进行远程管理。


风险提示与免责声明

  1. 账号风控与封禁风险(含 QQ 账号)
    本项目依赖第三方协议端(如 NapCat/Lagrange.Core)接入平台服务。任何因账号风控、功能限制、临时冻结或永久封禁造成的损失,均由实际部署方自行承担。

  2. 敏感信息处理风险
    请勿使用本项目主动收集、存储、导出或传播敏感信息。因使用者配置不当或违规处理数据导致的合规处罚及连带损失保留追究权力。

  3. 合规义务归属
    使用者应确保其部署与运营行为符合所在地区法律法规、平台协议及群规。项目维护者不对使用者的具体行为及后果承担连带责任。

开源协议与致谢

本项目遵循 MIT License 开源协议。

感谢 NagaAgent 子模块作者及社区支持:NagaAgent - A simple yet powerful agent framework.

⭐ 如果这个项目对您有帮助,请考虑给我们一个 Star

About

QQ bot platform with cognitive memory architecture and multi-agent Skills, via OneBot V11.

Topics

Resources

License

Stars

Watchers

Forks

Contributors