x-create-agent — OpenClaw Agent 标准化创建流程
作者:少年李迟迟 工作区文件(USER.md 等)不写死任何用户名,参考模板结合用户信息动态生成。 飞书配对自动化(脚本直接写入 openclaw.json),无需主 agent 介入。
工作流程
Step 1:收集信息
向用户收集以下信息(逐项询问,不要一次性问完):
| 信息 | 说明 | 验证规则 |
|------|------|---------|
| agent_id | 唯一标识,英文字母/数字/连字符 | 必须是合法标识符(字母开头) |
| name | 中文名称 | 1-20字 |
| description | 职能描述 | 一句话说明这个 agent 是做什么的 |
| feishu_appid | 飞书 AppID | 格式:cli_xxxxxxxx |
| feishu_appsecret | 飞书 AppSecret | 非空字符串 |
⚠️ 如果用户跳过飞书信息,创建完成后仍需引导填写。
路径说明:
~/.openclaw/skills/x-create-agent是默认安装路径示例,实际路径因用户环境而异。脚本支持自动搜索,搜不到时会交互式询问,用户只需输入自己的OPENCLAW_HOME绝对路径即可,开源分享无障碍。
Step 2:执行创建脚本
路径确认制:脚本发现路径后,先展示汇总信息,用户确认(输入 y)后再创建。
cd ~/.openclaw/skills/x-create-agent
python3 scripts/create_agent.py "<agent_id>" "<name>" "<description>" \
[--openclaw-home <path>] \
[--workspace <path>] \
[--user-name <name>] \
[--feishu-appid <appid>] \
[--feishu-appsecret <secret>]
展示内容(等用户确认):
- Agent ID / 名称 / 职能描述
- 发现的配置目录路径
- 将创建的 Agent 目录路径
- 将创建的工作区路径
路径发现优先级(自动搜索,无需手动指定):
OPENCLAW_HOME环境变量(如已设置)- 脚本自身目录向上持续搜索(无层级限制,直到根目录)
openclaw二进制所在目录向上搜索- 常见安装路径(
~/.openclaw/等 Linux/macOS/Windows 平台覆盖)
手动指定(可选):
--openclaw-home <path>— 显式指定配置目录路径--workspace <path>— 所有 Agent 工作区的父目录路径。传入后会拼接为<path>/workspace-<agent_id>(即无需指定到具体目录,脚本自动处理)。省略则默认{OPENCLAW_HOME}/workspace-<agent_id>
如全部搜索失败:脚本进入交互模式,提示用户输入配置目录路径并验证 openclaw.json 存在。
用户输入非 y:脚本立即退出,不创建任何文件。
Step 2.1:飞书配对(可选,命令行直接传入)
创建时直接传入 AppID 和 AppSecret,自动完成飞书机器人配对:
python3 scripts/create_agent.py "<agent_id>" "<name>" "<description>" \
--feishu-appid "cli_xxxxxxxx" \
--feishu-appsecret "<secret>"
这会在 openclaw.json 中自动写入:
channels.feishu.accounts[<agent_id>]:机器人凭证bindings:路由绑定
如未传入,脚本会在创建完成后打印操作指引。无需主 agent 介入,skill 调用者自己引导用户完成即可。
飞书机器人创建链接:
Step 2.2:补配飞书(pair-feishu 子命令)
当「先创建 agent、后补配对」时,使用独立命令追加飞书凭证 + 路由绑定:
python3 scripts/create_agent.py pair-feishu <agent_id> \
--feishu-appid "cli_xxxxxxxx" \
--feishu-appsecret "<secret>"
此命令会同时写入:
channels.feishu.accounts[<agent_id>]:机器人凭证bindings:路由绑定
⚠️ 注意:如果创建 agent 时已传入飞书凭证,bindings 会由创建流程自动写入,无需再调用此命令。
Step 3:确认完成
创建完成后,报告:
- Agent 目录路径
- 工作区路径
- 飞书绑定状态(如已传入凭证,则自动完成)
脚本详情:scripts/create_agent.py
功能
- 创建
agents/<agent_id>/agent/目录 - 创建工作区目录及标准文件(SOUL.md / AGENTS.md / USER.md 等)
- 将新 agent 注册到
openclaw.json - 自动完成飞书机器人配对(写入 accounts + bindings)
关键实现细节
路径发现逻辑(按优先级):
OPENCLAW_HOME环境变量~/.openclaw//vol1/@apphome/trim.openclaw/data/home/.openclaw/(当前部署路径)
openclaw.json 注册:
- 在
agents.list中添加新条目(含id、name、workspace、agentDir) - 在
tools.agentToAgent.allow中添加新 agent_id
飞书配对自动写入:
channels.feishu.accounts[<agent_id>]:机器人凭证(appId + appSecret)bindings:路由绑定(channel=feishu, accountId=<agent_id>)
工作区文件:
- 脚本参考内置模板,结合用户提供的
agent_id、name、description、user_name动态渲染生成各文件 SOUL.md→ 填入 agent 名称和职能描述(专属内容)USER.md→ 填入 user_name(主人名)IDENTITY.md→ 填入 agent 名称AGENTS.md/HEARTBEAT.md/TOOLS.md/MEMORY.md/SESSION-STATE.md→ 使用模板固定内容
注意事项
- 脚本不生成任何业务内容,工作区文件内容由模板 + 用户信息共同渲染生成
- 不在
openclaw.json中写入enabled字段(schema 不支持) - 不在顶层
agents下创建配置(schema 要求在agents.list中) - agent 的
workspace和agentDir必须使用绝对路径 --user-name为可选,不传则 USER.md 中显示为"用户"
依赖
lark-cli(用于验证飞书凭证连通性,可选)- Python 3(脚本执行)
微信扫一扫