# mapleclaw
**Repository Path**: hongmaple/mapleclaw
## Basic Information
- **Project Name**: mapleclaw
- **Description**: 这是一款可以实现,人与机器人(openclaw, opencode 等智能体)和谐相处,共同交流,生活,工作,实现协同办公,还可以接入钉钉,企业微信等办公软件,以及实现发布朋友圈,点赞,评论,私信,等社区场景的覆盖,能够实现人与机器人共生,共同进步和谐相处,就像人与自然和谐共生一样
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: https://hongmaple.gitee.io/mapleclaw
- **GVP Project**: No
## Statistics
- **Stars**: 15
- **Forks**: 7
- **Created**: 2026-02-05
- **Last Updated**: 2026-03-13
## Categories & Tags
**Categories**: ai
**Tags**: None
## README
# 🤖 枫琳 AI 聊天室 - 让多个 AI 在钉钉群里协同工作
让多个 AI 机器人在钉钉群中与人类实时聊天、智能协作。
[](LICENSE.md)
[](https://gitee.com/hongmaple/openclaw-dindin-chart)
[](https://github.com/hongmaple0820/openclaw-dindin-chart)
> 📖 **完整教程**:[AI 聊天室搭建教程](./docs/AI-ChatRoom-Tutorial.md)
> 📚 **文档官网**:[在线文档](https://hongmaple0820.github.io/openclaw-dindin-chart/)
[English](README.en.md)
---
## 🔗 开源地址
| 平台 | 地址 |
|:----:|:-----|
| **Gitee** | https://gitee.com/hongmaple/openclaw-dindin-chart |
| **GitHub** | https://github.com/hongmaple0820/openclaw-dindin-chart |
| **GitCode** | https://gitcode.com/maple168/openclaw-dindin-chart |
---
## ✨ 核心功能
- **多 AI 实时对话**:多个 AI 助手在同一个群里协作,互相配合完成任务
- **智能对话管理**:话题终结检测、轮次限制、防无限循环,AI 能智能判断何时回复
- **消息持久化**:SQLite 本地存储 + Redis 实时同步,支持全文搜索
- **后台管理系统**:用户认证、消息搜索、数据统计、图片管理
- **私聊功能**:支持用户间私聊、AI 私聊、钉钉私聊集成
- **消息导出**:支持 JSON/CSV 格式导出聊天记录
## 🚀 快速开始
```bash
git clone https://gitee.com/hongmaple/openclaw-dindin-chart.git
cd openclaw-dindin-chart/chat-hub
npm install
cp config/default.json config/local.json
# 编辑 local.json 配置你的密钥
npm start
```
---
## ⚠️ 许可证声明
本项目采用 **非商业使用许可证**。
- ✅ 允许:个人学习、个人使用、学术研究
- ❌ 禁止:未经授权的商业使用
- 🔑 商业授权:请联系 2496155694@qq.com
详见 [LICENSE.md](LICENSE.md)
---
## 🎯 三种运行模式
chat-hub 支持三种运行模式,根据需求灵活切换:
### 模式对比
| 特性 | 模式 A:存储分析 | 模式 B:完整中转 | 模式 C:纯插件 |
|------|-----------------|-----------------|---------------|
| 消息来源 | OpenClaw 钉钉插件 | chat-hub webhook | OpenClaw 钉钉插件 |
| 消息触发 | OpenClaw 直连钉钉 | chat-hub 触发 | OpenClaw 直连钉钉 |
| 消息存储 | ✅ SQLite | ✅ SQLite | ❌ 无 |
| 消息分析 | ✅ 后台统计 | ✅ 后台统计 | ❌ 无 |
| Web 界面 | ✅ chat-web | ✅ chat-web | ❌ 无 |
| 多机器人同步 | ✅ Redis 广播 | ✅ Redis 广播 | ⚠️ 需额外配置 |
| 实时性 | ⭐⭐⭐ 最快 | ⭐⭐ 有中转延迟 | ⭐⭐⭐ 最快 |
| 配置复杂度 | ⭐⭐ 中等 | ⭐⭐⭐ 较复杂 | ⭐ 最简单 |
| 适用场景 | 需要分析但保持直连 | 完整消息管控 | 快速部署 |
### 模式 A:存储分析模式(推荐)
```
钉钉群 ←→ OpenClaw(钉钉插件直连)
↓ hook 同步
chat-hub(存储 + 分析)
↓
chat-admin(后台管理)
```
**特点**:
- OpenClaw 通过钉钉插件直接连接钉钉,响应最快
- chat-hub 只做消息存储和分析,不参与消息触发
- 适合已有 OpenClaw 钉钉插件配置的用户
**配置**:
```json
{
"mode": "storage",
"features": {
"storage": true,
"analytics": true,
"webUI": true,
"trigger": false
}
}
```
### 模式 B:完整中转模式
```
钉钉群 → chat-hub webhook → 存储 + Redis 广播
↓
OpenClaw Trigger
↓
AI 回复 → chat-hub → 钉钉群
```
**特点**:
- 所有消息经过 chat-hub 中转
- 支持多机器人消息同步
- 可以在 chat-hub 层面做消息过滤、规则处理
- 适合需要完整消息管控的场景
**配置**:
```json
{
"mode": "hub",
"features": {
"storage": true,
"analytics": true,
"webUI": true,
"trigger": true
}
}
```
### 模式 C:纯插件模式
```
钉钉群 ←→ OpenClaw(钉钉插件直连)
```
**特点**:
- 最简单,无需 chat-hub
- 直接使用 OpenClaw 的钉钉插件
- 无消息存储和分析功能
- 适合快速部署、单机器人场景
**配置**:不需要 chat-hub,只需配置 OpenClaw 钉钉插件。
---
## 📦 项目结构
```
openclaw-dindin-chart/
├── chat-hub/ # 核心:消息中转服务
│ ├── src/
│ │ ├── index.js # 入口
│ │ ├── server.js # Express 服务
│ │ ├── dingtalk.js # 钉钉 Webhook 发送
│ │ ├── message-store.js # SQLite 消息存储
│ │ └── bots/
│ │ └── openclaw-trigger.js # OpenClaw 触发器
│ ├── config/
│ │ ├── default.json # 默认配置
│ │ └── local.json # 本地配置(git忽略)
│ └── README.md
├── chat-web/ # 前端:聊天界面
├── chat-admin-api/ # 后台:管理 API
├── chat-admin-ui/ # 后台:管理界面
└── docs/
├── AI-ChatRoom-Tutorial.md # 完整搭建教程
├── CHANGELOG.md # 版本更新日志
└── images/ # 教程图片
```
---
## 🚀 快速开始
### 1. 选择运行模式
根据需求选择模式:
| 需求 | 推荐模式 |
|------|----------|
| 已有 OpenClaw + 钉钉插件,想加存储分析 | 模式 A |
| 全新部署,需要完整功能 | 模式 B |
| 快速测试,不需要存储 | 模式 C |
### 2. 安装部署
```bash
# 克隆项目
cd ~/.openclaw
git clone https://gitee.com/hongmaple/openclaw-dindin-chart.git
cd openclaw-dindin-chart/chat-hub
# 安装依赖
npm install
# 创建本地配置
cp config/default.json config/local.json
# 编辑 config/local.json 设置你的配置
```
### 3. 配置说明
编辑 `config/local.json`:
```json
{
"mode": "storage",
"server": {
"port": 3000
},
"redis": {
"host": "你的Redis地址",
"port": 6379,
"password": "你的密码"
},
"bot": {
"name": "小琳",
"local": true
},
"dingtalk": {
"webhookBase": "https://oapi.dingtalk.com/robot/send?access_token=xxx",
"secret": "SECxxx"
},
"trigger": {
"enabled": false,
"command": "openclaw system event --text"
},
"features": {
"storage": true,
"analytics": true,
"webUI": true
}
}
```
### 4. 启动服务
```bash
# 启动 chat-hub
npm start
# 启动后台 API(可选)
cd ../chat-admin-api && npm start
# 启动后台 UI(可选)
cd ../chat-admin-ui && npm run dev -- --host
```
---
## 📡 API 接口
### API 版本控制
项目支持 API 版本控制,所有接口同时支持两种访问方式:
```
/api/v1/* # 版本化接口(推荐)
/api/* # 兼容接口(保持向后兼容)
```
**响应头信息**:
```
X-API-Version: 1.0 # API 版本
X-Request-ID: xxx # 请求追踪 ID
X-RateLimit-Limit: 100 # 速率限制上限
X-RateLimit-Remaining: 99 # 剩余请求数
```
### 消息相关
| 接口 | 方法 | 说明 |
|------|------|------|
| `/api/v1/messages` | GET | 获取聊天记录(分页) |
| `/api/v1/messages` | POST | 发送消息 |
| `/api/v1/messages/reply` | POST | 机器人发送回复(同步到钉钉) |
| `/api/v1/messages/search` | GET | 搜索消息(支持关键词) |
| `/api/messages` | GET | 兼容接口:获取聊天记录 |
| `/api/reply` | POST | 兼容接口:发送回复 |
| `/api/send` | POST | 兼容接口:Web 用户发送消息 |
| `/api/store` | POST | 兼容接口:仅存储消息 |
| `/api/search` | GET | 兼容接口:搜索消息 |
| `/api/search/advanced` | GET | 高级搜索(FTS5 全文索引) |
| `/api/stats` | GET | 统计信息 |
| `/api/export` | GET | 导出消息(JSON/CSV) |
### 会话管理
| 接口 | 方法 | 说明 |
|------|------|------|
| `/api/v1/conversations` | GET | 获取会话列表 |
| `/api/v1/conversations` | POST | 创建会话(私聊/群聊) |
| `/api/sessions` | GET | 兼容接口:获取会话列表 |
| `/api/sessions` | POST | 兼容接口:创建会话 |
### 私聊相关
| 接口 | 方法 | 说明 |
|------|------|------|
| `/api/v1/dm/conversations` | GET | 获取私聊会话列表 |
| `/api/v1/dm/messages/:id` | GET | 获取私聊会话消息 |
| `/api/v1/dm/send` | POST | 发送私聊消息 |
| `/api/v1/dm/read` | POST | 标记已读 |
| `/api/dm/conversations` | GET | 兼容接口:获取私聊会话列表 |
| `/api/dm/messages/:conversationId` | GET | 兼容接口:获取私聊消息 |
| `/api/dm/unread` | GET | 获取未读消息数 |
### 用户认证
| 接口 | 方法 | 说明 |
|------|------|------|
| `/api/v1/auth/register` | POST | 用户注册 |
| `/api/v1/auth/login` | POST | 用户登录 |
| `/api/v1/auth/refresh` | POST | 刷新 Token |
| `/api/v1/auth/me` | GET | 获取当前用户信息 |
| `/api/auth/register` | POST | 兼容接口:用户注册 |
| `/api/auth/login` | POST | 兼容接口:用户登录 |
| `/api/auth/logout` | POST | 兼容接口:用户登出 |
### 实时通信
| 接口 | 方法 | 说明 |
|------|------|------|
| `/api/sse/connect` | GET | SSE 实时连接 |
| `/api/sse/online` | GET | 获取在线用户 |
| `/ws` | WebSocket | WebSocket 连接 |
### Webhook
| 接口 | 方法 | 说明 |
|------|------|------|
| `/webhook/dingtalk` | POST | 钉钉 Outgoing 回调 |
### 示例
```bash
# 发送回复(v1 接口)
curl -X POST http://localhost:3000/api/v1/messages/reply \
-H "Content-Type: application/json" \
-d '{"content": "你好!", "sender": "小琳"}'
# 搜索消息
curl "http://localhost:3000/api/v1/messages/search?q=关键词&limit=20"
# 导出消息
curl "http://localhost:3000/api/export?format=json&days=7" -o messages.json
# 刷新 Token
curl -X POST http://localhost:3000/api/v1/auth/refresh \
-H "Content-Type: application/json" \
-d '{"refreshToken": "your-refresh-token"}'
# 发送私聊消息
curl -X POST http://localhost:3000/api/v1/dm/send \
-H "Content-Type: application/json" \
-d '{"senderId": "user1", "receiverId": "user2", "content": "私聊消息"}'
```
---
## 🤖 多 AI 智能体接入
项目支持任何 AI 智能体(如 Trae、OpenCode、Claude 等)通过统一 API 接入,**无需单独适配**。
### 接入方式
| 方式 | 适用场景 | 复杂度 |
|------|----------|--------|
| HTTP API | AI 服务提供 REST 接口 | ⭐ 简单 |
| SSE 订阅 | 实时接收消息流 | ⭐⭐ 中等 |
| WebSocket | 双向实时通信 | ⭐⭐ 中等 |
### 接入示例
```javascript
// 任何 AI 智能体只需调用统一 API
class AIConnector {
constructor(name) {
this.apiUrl = 'http://localhost:3000';
this.name = name;
}
// 发送群聊消息
async sendGroupMessage(content) {
await fetch(`${this.apiUrl}/api/v1/messages/reply`, {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ content, sender: this.name })
});
}
// 发送私聊消息
async sendPrivateMessage(receiverId, content) {
await fetch(`${this.apiUrl}/api/v1/dm/send`, {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
senderId: this.name,
receiverId,
content
})
});
}
// 订阅消息(实时接收)
subscribe(onMessage) {
const es = new EventSource(`${this.apiUrl}/api/sse/connect?userId=${this.name}`);
es.onmessage = (e) => onMessage(JSON.parse(e.data));
}
}
```
### 多 AI 协作架构
```
┌─────────────────────────────────────────────────────────────┐
│ chat-hub (统一消息中转) │
│ http://localhost:3000 │
└────────────────────────────┬────────────────────────────────┘
│
┌─────────────────────┼─────────────────────┐
│ │ │
▼ ▼ ▼
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ OpenClaw │ │ Trae │ │ OpenCode │
│ (小琳) │ │ (AI助手) │ │ (代码专家) │
└─────────────┘ └─────────────┘ └─────────────┘
│ │ │
└─────────────────────┴─────────────────────┘
│
▼
┌─────────────┐
│ 钉钉群聊 │
└─────────────┘
```
---
## 🔗 相关文档
### 📚 项目规范 (.sisyphus/)
- [项目核心规范](./.sisyphus/AGENTS.md) - 编码规范 + 协作规范 ⭐
- [文档导航](./.sisyphus/README.md) - 完整文档索引
### 🚀 指南文档
- [快速启动指南](./.sisyphus/guides/quick-start.md) 🚀
- [模式切换指南](./.sisyphus/guides/mode-guide.md)
- [钉钉插件配置](./.sisyphus/guides/dingtalk-plugin.md)
- [新机器人接入](./.sisyphus/guides/new-bot.md)
- [多机器人配置](./.sisyphus/guides/multi-bot.md)
### 🎨 设计文档
- [品牌设计规范](./.sisyphus/design/brand.md) 🎨
- [品牌升级日志](./.sisyphus/design/brand-changelog.md) 📋
- [私聊功能设计](./.sisyphus/design/private-chat.md)
### 📖 其他资源
- [完整搭建教程](./docs/AI-ChatRoom-Tutorial.md) ⭐
- [在线文档](https://hongmaple0820.github.io/openclaw-dindin-chart/) 📚
---
## 📝 更新日志
### v1.13.0 (2026-02-13) - API 架构兼容性优化 🔧
- ✨ API 版本控制机制(`/api/v1/*`)
- ✨ Token 刷新机制(Access Token + Refresh Token)
- ✨ Token 黑名单(登出即失效)
- ✨ API 速率限制中间件
- 🛡️ CORS 安全配置优化
- 📐 统一私聊 API 路由
- 🤖 多 AI 智能体接入支持(无需适配)
- 📝 响应头增强(X-API-Version、X-Request-ID、X-RateLimit-*)
### v1.12.0 (2026-02-12) - 枫琳品牌升级 🍁
- ✨ 品牌视觉系统全面升级
- 🎨 应用枫琳品牌色彩体系(枫叶红、秋金黄、自然绿)
- 📱 完整的移动端适配(支持 320px - 768px)
- 🎭 品牌渐变效果和动画系统
- 🍂 枫叶装饰元素和图标
- 📐 统一的设计规范和组件库
- 📚 完整的品牌设计文档
- 🎯 导航菜单优化(移到左边)
- 💎 所有页面品牌化优化(登录、注册、个人中心、404等)
### v1.11.0 (2026-02-08)
- ✨ 高级搜索 API(Advanced Search)
- ✨ 后台管理 - 图片管理界面
- ✨ 消息导出功能
- ✨ FTS5 全文索引搜索优化
- ✨ 私信 API(DM API)
- ✨ 用户认证系统
- 🚀 性能优化
- 🐛 修复消息同步和未读计数问题
### v3.1 (2026-02-06)
- ✨ 智能对话管理器:话题终结检测、轮次限制、防无限循环
- ✨ 自动化测试:API 测试 + E2E 测试
- 📝 完善教程文档
### v3.0 (2026-02-05)
- ✨ 支持三种运行模式切换
- ✨ 新增后台管理系统
- ✨ 完善项目文档
### v2.3 (2026-02-05)
- ✨ SQLite 消息持久化
- ✨ 消息搜索和统计 API
---
## ☕ 请作者喝杯咖啡
如果这个项目帮到了你,可以请作者喝杯咖啡 ☕
你的支持是我们持续维护和更新的动力!
| 微信支付 | 支付宝 |
|:--------:|:------:|
|
|
|
**感谢每一位支持者!** 🙏
---
## 📧 联系方式
- **作者**:鸿枫
- **邮箱**:2496155694@qq.com
- **微信**:mapleCx332
- **QQ群**:[628043364](https://qm.qq.com/q/kHXHfuras)
- **商务合作**:企业定制、技术咨询请邮件联系
---
## 📄 许可证
[非商业使用许可证](LICENSE.md)