SecretRef 凭据定义
SecretRef 凭证范围
Section titled “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.*skills.entries.*.apiKeyagents.defaults.memorySearch.remote.apiKeyagents.list[].memorySearch.remote.apiKeytalk.apiKeytalk.providers.*.apiKeymessages.tts.providers.*.apiKeytools.web.fetch.firecrawl.apiKeyplugins.entries.brave.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.tavily.config.webSearch.apiKeytools.web.search.apiKeytools.web.x_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.bluebubbles.passwordchannels.bluebubbles.accounts.*.passwordchannels.feishu.appSecretchannels.feishu.encryptKeychannels.feishu.verificationTokenchannels.feishu.accounts.*.appSecretchannels.feishu.accounts.*.encryptKeychannels.feishu.accounts.*.verificationTokenchannels.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.*.webhookSecret- 通过同级
serviceAccountRef的channels.googlechat.serviceAccount(兼容性例外) - 通过同级
serviceAccountRef的channels.googlechat.accounts.*.serviceAccount(兼容性例外)
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 引用包含在运行时解析和审计覆盖范围内。
- 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 解析。