SecretRef 凭证范围
此页面定义了规范的 SecretRef 凭证范围。
范围意图:
- 范围内:完全由用户提供的凭证,即 OpenClaw 不创建或轮换的凭证。
- 范围外:运行时创建或轮换的凭证、OAuth 刷新材料以及类似会话的工件。
openclaw.json 目标 (secrets configure + secrets apply + secrets audit)
Section titled “openclaw.json 目标 (secrets configure + secrets apply + secrets audit)”models.providers.*.apiKeymodels.providers.*.headers.*models.providers.*.request.auth.tokenmodels.providers.*.request.auth.valuemodels.providers.*.request.headers.*models.providers.*.request.proxy.tls.camodels.providers.*.request.proxy.tls.certmodels.providers.*.request.proxy.tls.keymodels.providers.*.request.proxy.tls.passphrasemodels.providers.*.request.tls.camodels.providers.*.request.tls.certmodels.providers.*.request.tls.keymodels.providers.*.request.tls.passphraseskills.entries.*.apiKeyagents.defaults.memorySearch.remote.apiKeyagents.list[].tts.providers.*.apiKeyagents.list[].memorySearch.remote.apiKeytalk.providers.*.apiKeymessages.tts.providers.*.apiKeytools.web.fetch.firecrawl.apiKeyplugins.entries.acpx.config.mcpServers.*.env.*plugins.entries.brave.config.webSearch.apiKeyplugins.entries.exa.config.webSearch.apiKeyplugins.entries.google.config.webSearch.apiKeyplugins.entries.xai.config.webSearch.apiKeyplugins.entries.moonshot.config.webSearch.apiKeyplugins.entries.perplexity.config.webSearch.apiKeyplugins.entries.firecrawl.config.webSearch.apiKeyplugins.entries.minimax.config.webSearch.apiKeyplugins.entries.tavily.config.webSearch.apiKeyplugins.entries.voice-call.config.realtime.providers.*.apiKeyplugins.entries.voice-call.config.streaming.providers.*.apiKeyplugins.entries.voice-call.config.tts.providers.*.apiKeyplugins.entries.voice-call.config.twilio.authTokentools.web.search.*.apiKeytools.web.search.apiKeygateway.auth.passwordgateway.auth.tokengateway.remote.tokengateway.remote.passwordcron.webhookTokenchannels.telegram.botTokenchannels.telegram.webhookSecretchannels.telegram.accounts.*.botTokenchannels.telegram.accounts.*.webhookSecretchannels.slack.botTokenchannels.slack.appTokenchannels.slack.userTokenchannels.slack.signingSecretchannels.slack.accounts.*.botTokenchannels.slack.accounts.*.appTokenchannels.slack.accounts.*.userTokenchannels.slack.accounts.*.signingSecretchannels.discord.tokenchannels.discord.pluralkit.tokenchannels.discord.voice.tts.providers.*.apiKeychannels.discord.accounts.*.tokenchannels.discord.accounts.*.pluralkit.tokenchannels.discord.accounts.*.voice.tts.providers.*.apiKeychannels.irc.passwordchannels.irc.nickserv.passwordchannels.irc.accounts.*.passwordchannels.irc.accounts.*.nickserv.passwordchannels.feishu.appSecretchannels.feishu.encryptKeychannels.feishu.verificationTokenchannels.feishu.accounts.*.appSecretchannels.feishu.accounts.*.encryptKeychannels.feishu.accounts.*.verificationTokenchannels.qqbot.clientSecretchannels.qqbot.accounts.*.clientSecretchannels.msteams.appPasswordchannels.mattermost.botTokenchannels.mattermost.accounts.*.botTokenchannels.matrix.accessTokenchannels.matrix.passwordchannels.matrix.accounts.*.accessTokenchannels.matrix.accounts.*.passwordchannels.nextcloud-talk.botSecretchannels.nextcloud-talk.apiPasswordchannels.nextcloud-talk.accounts.*.botSecretchannels.nextcloud-talk.accounts.*.apiPasswordchannels.zalo.botTokenchannels.zalo.webhookSecretchannels.zalo.accounts.*.botTokenchannels.zalo.accounts.*.webhookSecretchannels.googlechat.serviceAccount通过同级serviceAccountRef(兼容性例外)channels.googlechat.accounts.*.serviceAccount通过同级serviceAccountRef(兼容性例外)
auth-profiles.json 目标 (secrets configure + secrets apply + secrets audit)
Section titled “auth-profiles.json 目标 (secrets configure + secrets apply + secrets audit)”profiles.*.keyRef(type: "api_key"; 当auth.profiles.<id>.mode = "oauth"时不支持)profiles.*.tokenRef(type: "token"; 当auth.profiles.<id>.mode = "oauth"时不支持)
备注:
- Auth-profile 计划目标需要
agentId。 - 计划条目目标是
profiles.*.key/profiles.*.token并写入兄弟引用 (keyRef/tokenRef)。 - Auth-profile 引用包含在运行时解析和审计覆盖范围中。
- 在
openclaw.json中,SecretRefs 必须使用结构化对象,例如{"source":"env","provider":"default","id":"DISCORD_BOT_TOKEN"}。SecretRef 凭据路径上会拒绝旧版secretref-env:<ENV_VAR>标记字符串;请运行openclaw doctor --fix以迁移有效标记。 - OAuth 策略保护:
auth.profiles.<id>.mode = "oauth"不能与该配置文件的 SecretRef 输入结合使用。当违反此策略时,启动/重新加载和 auth-profile 解析会快速失败。 - 对于 SecretRef 托管的模型提供商,生成的
agents/*/agent/models.json条目会为apiKey/header 表面保留非机密标记(而不是已解析的机密值)。 - 标记保留以源为准:OpenClaw 从活动源配置快照(解析前)写入标记,而不是从已解析的运行时机密值写入。
- 对于网络搜索:
- 在显式提供商模式(设置了
tools.web.search.provider)中,只有选定的提供商密钥处于活动状态。 - 在自动模式(未设置
tools.web.search.provider)中,只有按优先级解析的第一个提供商密钥处于活动状态。 - 在自动模式下,未选定的提供商引用在被选中之前被视为不活动。
- 在兼容性窗口期间,旧版
tools.web.search.*提供商路径仍然会解析,但规范的 SecretRef 表面是plugins.entries.<plugin>.config.webSearch.*。
- 在显式提供商模式(设置了
不支持的凭据
Section titled “不支持的凭据”范围外的凭据包括:
commands.ownerDisplaySecrethooks.tokenhooks.gmail.pushTokenhooks.mappings[].sessionKeyauth-profiles.oauth.*channels.discord.threadBindings.webhookTokenchannels.discord.accounts.*.threadBindings.webhookTokenchannels.whatsapp.creds.jsonchannels.whatsapp.accounts.*.creds.json
基本原理:
- 这些凭据是由系统生成、轮换、包含会话信息,或者是属于 OAuth 持久类的凭据,并不适合只读的外部 SecretRef 解析。