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.*.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並寫入同級 refs (keyRef/tokenRef)。 - Auth-profile refs 包含在執行時期解析和稽核覆蓋範圍內。
- 在
openclaw.json中,SecretRefs 必須使用結構化物件,例如{"source":"env","provider":"default","id":"DISCORD_BOT_TOKEN"}。舊版secretref-env:<ENV_VAR>標記字串會在 SecretRef 憑證路徑上被拒絕;請執行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)中,只有第一個依優先順序解析的提供者金鑰是作用中的。 - 在自動模式下,非選定的提供者 refs 在被選定之前會被視為非作用中。
- 舊版
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 解析。