技能配置
所有技能相关配置位于 ~/.openclaw/openclaw.json 中的 skills 下。
{
skills: {
allowBundled: ["gemini", "peekaboo"],
load: {
extraDirs: ["~/Projects/agent-scripts/skills", "~/Projects/oss/some-skill-pack/skills"],
watch: true,
watchDebounceMs: 250,
},
install: {
preferBrew: true,
nodeManager: "npm", // npm | pnpm | yarn | bun (Gateway 运行时仍是 Node;不推荐 bun)
},
entries: {
"nano-banana-pro": {
enabled: true,
apiKey: { source: "env", provider: "default", id: "GEMINI_API_KEY" }, // 或明文字符串
env: {
GEMINI_API_KEY: "GEMINI_KEY_HERE",
},
},
peekaboo: { enabled: true },
sag: { enabled: false },
},
},
}
字段
allowBundled:仅对捆绑技能的可选白名单。设置后,仅列表中的捆绑技能符合条件(管理的/工作区技能不受影响)。load.extraDirs:要扫描的额外技能目录(最低优先级)。load.watch:监视技能文件夹并刷新技能快照(默认:true)。load.watchDebounceMs:技能监视器事件的防抖毫秒数(默认:250)。install.preferBrew:可用时优先使用 brew 安装程序(默认:true)。install.nodeManager:节点安装程序偏好(npm|pnpm|yarn|bun,默认:npm)。 这仅影响技能安装;Gateway 运行时仍应是 Node(WhatsApp/Telegram 不推荐 Bun)。entries.<skillKey>:每个技能的覆盖。
每技能字段:
enabled:设为false禁用技能,即使它已捆绑/安装。env:为代理运行注入的环境变量(仅在未设置时)。apiKey:为声明主要环境变量的技能提供的可选便利。支持明文字符串或 SecretRef 对象({ source, provider, id })。
注意
entries下的键默认映射到技能名称。如果技能定义metadata.openclaw.skillKey,改用该键。- 当监视器启用时,更改的技能在下一个代理轮次中被获取。
沙箱化技能 + 环境变量
当会话是沙箱化时,技能进程在 Docker 内运行。沙箱不继承主机的 process.env。
使用以下之一:
agents.defaults.sandbox.docker.env(或每代理agents.list[].sandbox.docker.env)- 将环境变量烘焙到你的自定义沙箱镜像中
全局 env 和 skills.entries.<skill>.env/apiKey 仅适用于主机运行。