-
-
Notifications
You must be signed in to change notification settings - Fork 2.4k
zh dev openapi
从 v4.18.0 开始,AstrBot 提供基于 API Key 的 HTTP API,开发者可以通过标准 HTTP 请求访问核心能力。
- 在 WebUI - 设置中创建 API Key。
- 在请求头中携带 API Key:
Authorization: Bearer abk_xxx也支持:
X-API-Key: abk_xxx- 对于对话接口,
username为必填参数:
-
POST /api/v1/chat:请求体必须包含username -
GET /api/v1/chat/sessions:查询参数必须包含username
本地 OpenAPI 描述文件地址为 http://localhost:6185/api/v1/openapi.json,交互式文档地址为 http://localhost:6185/api/v1/docs。
创建 API Key 时可配置 scopes。每个 scope 控制可访问的接口范围:
| Scope | 作用 | 可访问接口 |
|---|---|---|
bot |
管理机器人/平台配置 |
GET /api/v1/bot-types、GET/POST /api/v1/bots、PATCH /api/v1/bots/enabled
|
provider |
管理模型提供商和提供商源 |
GET/POST /api/v1/providers、GET/PUT/DELETE /api/v1/provider-sources/by-id
|
persona |
管理人格和人格文件夹 |
GET/POST /api/v1/personas、GET/POST /api/v1/persona-folders
|
im |
主动发 IM 消息、查询 bot/platform 列表 |
POST /api/v1/im/message、GET /api/v1/im/bots
|
config |
管理配置文件、系统配置和通用配置。该 scope 同时包含 bot 和 provider 访问权限。 |
GET /api/v1/configs、GET/PUT /api/v1/system-config、GET/POST /api/v1/config-profiles
|
chat |
调用对话能力、查询对话会话 |
POST /api/v1/chat、GET /api/v1/chat/sessions
|
plugin |
管理插件、插件配置、插件源和插件市场 |
GET /api/v1/plugins、GET/PUT /api/v1/plugins/config、POST /api/v1/plugins/install/url
|
mcp |
管理 MCP 服务器配置和服务端同步 |
GET/POST /api/v1/mcp/servers、PATCH /api/v1/mcp/servers/{server_name}/enabled、POST /api/v1/mcp/providers/modelscope/sync
|
skill |
管理 Skills、Skill 压缩包、Skill 文件和 Shipyard Neo Skill 流程 |
GET/POST /api/v1/skills、PUT /api/v1/skills/{skill_name}/files/{file_path}、POST /api/v1/skills/neo/sync
|
如果 API Key 未包含目标接口所需 scope,请求会返回 403 Insufficient API key scope。
config 是较大的管理 scope。创建 API Key 时如果包含 config,AstrBot 会同时授予该 Key config、bot 和 provider 访问权限。WebUI 的勾选逻辑也会体现这个依赖关系:选中 config 会同时选中 bot 和 provider;取消选中 bot 或 provider 时,会同步取消 config。
当前开发者 API Key 仅开放以上 9 个 scope。file、tool、skills、kb、data、system 暂不支持作为开发者 API Key scope。/api/v1/skills/* 接口使用单数 skill scope,不使用复数 skills。相关接口可能仍出现在 /api/v1 文档中,但只有 scope 属于上表支持范围时才对开发者 API Key 开放。
对话类
调用 AstrBot 内建的 Agent 进行对话交互。支持插件调用、工具调用等能力,与 IM 端对话能力一致。
-
POST /api/v1/chat:发送对话消息(SSE 流式返回,不传session_id会自动创建 UUID) -
GET /api/v1/chat/sessions:分页获取指定username的会话 -
GET /api/v1/configs:获取可用配置文件列表
机器人和模型提供商
-
GET /api/v1/bots:获取机器人/平台配置列表 -
POST /api/v1/bots:创建机器人/平台配置 -
GET /api/v1/providers:获取模型提供商配置列表 -
GET /api/v1/provider-sources:获取提供商源配置列表
人格、插件、MCP 和 Skills
-
GET /api/v1/personas:获取人格列表 -
GET /api/v1/plugins:获取插件列表 -
GET /api/v1/mcp/servers:获取 MCP 服务器列表 -
GET /api/v1/skills:获取 Skills 列表
IM 消息发送
-
POST /api/v1/im/message:按 UMO 主动发消息 -
GET /api/v1/im/bots:获取 bot/platform ID 列表
POST /api/v1/chat 和 POST /api/v1/im/message 的 message 字段支持两种格式:
- 字符串:纯文本消息
- 数组:消息段(message chain)
{
"message": "Hello"
}{
"message": [
{ "type": "plain", "text": "请看这个文件" },
{ "type": "file", "attachment_id": "9a2f8c72-e7af-4c0e-b352-111111111111" }
]
}支持的 type:
| type | 必填字段 | 可选字段 | 说明 |
|---|---|---|---|
plain |
text |
- | 文本段 |
reply |
message_id |
selected_text |
引用回复某条消息 |
image |
attachment_id |
- | 图片附件段 |
record |
attachment_id |
- | 音频附件段 |
file |
attachment_id |
- | 通用文件段 |
video |
attachment_id |
- | 视频附件段 |
- reply 消息段目前仅适配
/api/v1/chat,不适用于POST /api/v1/im/message。
说明:
-
attachment_id来自已存在的附件记录。开发者 API Key 当前不能使用POST /api/v1/file上传附件。 -
reply不能单独作为唯一内容,至少需要一个有实际内容的段(如plain/image/file/...)。 - 仅
reply或空内容会返回错误。
POST /api/v1/chat 额外需要 username,可选 session_id(不传会自动创建 UUID)。
{
"username": "alice",
"session_id": "my_session_001",
"message": [
{ "type": "plain", "text": "帮我总结这个 PDF" },
{ "type": "file", "attachment_id": "9a2f8c72-e7af-4c0e-b352-111111111111" }
],
"enable_streaming": true
}POST /api/v1/im/message 需要 umo + message。
{
"umo": "webchat:FriendMessage:openapi_probe",
"message": [
{ "type": "plain", "text": "这是主动消息" },
{ "type": "image", "attachment_id": "9a2f8c72-e7af-4c0e-b352-222222222222" }
]
}curl -N 'http://localhost:6185/api/v1/chat' \
-H 'Authorization: Bearer abk_xxx' \
-H 'Content-Type: application/json' \
-d '{"message":"Hello","username":"alice"}'交互式 API 文档请查看:
- 首页
- 文档入口
- Top Level
- community events
- deploy
- dev
- others
- platform
- 接入 OneBot v11 协议实现
- 接入钉钉 DingTalk
- 接入 Discord
- 接入 Kook
- 接入飞书
- 接入 LINE
- 接入 Matrix
- 接入 Mattermost
- 接入 Misskey 平台
- 接入 QQ 官方机器人平台
- 通过 QQ官方机器人 接入 QQ (Webhook)
- 通过 QQ官方机器人 接入 QQ (Websockets)
- 接入 Satori 协议
- 接入 server-satori (基于 Koishi)
- 接入 Slack
- 接入消息平台
- 接入 Telegram
- 接入 VoceChat
- AstrBot 接入企业微信
- 接入企业微信智能机器人平台
- AstrBot 接入微信公众平台
- 接入个人微信
- providers
- use
- Home
- Docs Entry
- Top Level
- config
- deploy
- Deploy AstrBot on 1Panel
- Deploy AstrBot on BT Panel
- Deploy AstrBot on CasaOS
- Deploy AstrBot from Source Code
- Community-Provided Deployment Methods
- Deploy via Compshare
- Deploy with AstrBot Desktop Client
- Deploy AstrBot with Docker
- Deploy AstrBot with Kubernetes
- Deploy AstrBot with AstrBot Launcher
- Other Deployments
- Package Manager Deployment (uv)
- Installation via System Package Manager
- Preface
- dev
- AstrBot Configuration File
- AstrBot HTTP API
- Developing a Platform Adapter
- plugin
- AI
- Text to Image
- Handling Message Events
- Plugin Configuration
- Plugin Internationalization
- Plugin Pages
- Sending Messages
- Session Control
- Minimal Example
- Plugin Storage
- AstrBot Plugin Development Guide 🌠
- Publishing Plugins to the Plugin Marketplace
- ospp
- others
- platform
- Connect OneBot v11 Protocol Implementations
- Connect to DingTalk
- Connecting to Discord
- Connect to KOOK
- Connecting to Lark
- Connecting to LINE
- Connecting to Matrix
- Connecting to Mattermost
- Connecting to Misskey Platform
- Connect QQ Official Bot
- Connect QQ via QQ Official Bot (Webhook)
- Connect QQ via QQ Official Bot (Websockets)
- Connect to Satori Protocol
- Connect server-satori (Koishi)
- Connecting to Slack
- Messaging Platforms
- Connecting to Telegram
- Connect to VoceChat
- Connect AstrBot to WeCom
- Connect to WeCom AI Bot Platform
- Connect AstrBot to WeChat Official Account Platform
- Connect Personal WeChat
- providers
- Connect 302.AI
- Agent Runners
- Built-in Agent Runner
- Connect to Coze
- Connect to Alibaba Cloud Bailian Application
- Connect to DeerFlow
- Connect to Dify
- Connect AIHubMix
- coze
- dashscope
- dify
- 大语言模型提供商
- NewAPI
- Connect PPIO Cloud
- Connect LM Studio to Use DeepSeek-R1 and Other Models
- Integrating Ollama
- Connecting to SiliconFlow
- Connecting Model Services
- Connecting to TokenPony
- use
- Agent Runner
- Agent Sandbox Environment ⛵️
- astrbot sandbox
- Docker-based Code Interpreter
- Built-in Commands
- Computer Use
- Context Compression
- Custom Rules
- Function Calling
- AstrBot Knowledge Base
- MCP
- AstrBot Star
- Proactive Capabilities
- Anthropic Skills
- Agent Handoff and SubAgent
- Unified Webhook Mode
- Web Search
- WebUI