惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

D
Docker
Microsoft Azure Blog
Microsoft Azure Blog
云风的 BLOG
云风的 BLOG
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
L
LangChain Blog
P
Privacy & Cybersecurity Law Blog
Hugging Face - Blog
Hugging Face - Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
大猫的无限游戏
大猫的无限游戏
Cyberwarzone
Cyberwarzone
The Register - Security
The Register - Security
Stack Overflow Blog
Stack Overflow Blog
A
Arctic Wolf
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
T
Threatpost
The GitHub Blog
The GitHub Blog
P
Privacy International News Feed
WordPress大学
WordPress大学
U
Unit 42
S
Securelist
T
The Exploit Database - CXSecurity.com
C
Cyber Attacks, Cyber Crime and Cyber Security
P
Proofpoint News Feed
Latest news
Latest news
Hacker News: Ask HN
Hacker News: Ask HN
小众软件
小众软件
Know Your Adversary
Know Your Adversary
The Cloudflare Blog
V
Vulnerabilities – Threatpost
The Hacker News
The Hacker News
Scott Helme
Scott Helme
有赞技术团队
有赞技术团队
Security Latest
Security Latest
Google DeepMind News
Google DeepMind News
Application and Cybersecurity Blog
Application and Cybersecurity Blog
Simon Willison's Weblog
Simon Willison's Weblog
博客园 - Franky
Y
Y Combinator Blog
博客园 - 叶小钗
Security Archives - TechRepublic
Security Archives - TechRepublic
Google DeepMind News
Google DeepMind News
N
Netflix TechBlog - Medium
S
Secure Thoughts
T
Threat Research - Cisco Blogs
aimingoo的专栏
aimingoo的专栏
S
SegmentFault 最新的问题
Microsoft Security Blog
Microsoft Security Blog
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
博客园 - 司徒正美
M
MIT News - Artificial intelligence

Recent Commits to openclaw:main

test: merge chat side-result checks · openclaw/openclaw@ddd2c2a test: merge cron history checks · openclaw/openclaw@f7eb746 test: merge responsive navigation shell checks · openclaw/openclaw@c2e4b47 docs(changelog): add codex oauth fixes · openclaw/openclaw@628e6cd test: merge navigation routing cases · openclaw/openclaw@5d8cecb Tests: mock channel registry bundled fallback · openclaw/openclaw@2b08233 Secrets: avoid broad web search discovery for single plugin config · openclaw/openclaw@a464f59 test: merge config view browser checks · openclaw/openclaw@20cf511 fix(status): align oauth health with runtime · openclaw/openclaw@eed7116 feat: add macOS screen snapshots for monitor preview (#67954) thanks … · openclaw/openclaw@f377db1 fix: report shared auth scopes in hello-ok (#67810) thanks @BunsDev · openclaw/openclaw@0b6c39b Auto-reply: avoid eager bundled route fallback · openclaw/openclaw@3ea1bf4 Tests: narrow session binding contract setup · openclaw/openclaw@54e4e16 fix(macOS): enable undo/redo in webchat composer text input (#34962) · openclaw/openclaw@00951dc Tests: speed up channel setup promotion · openclaw/openclaw@82b529a Docs: refresh agent instructions · openclaw/openclaw@5775fe2 fix(auth): serialize OAuth refresh across agents to fix #26322 (#67876) · openclaw/openclaw@8e79080 test: allow ollama public surface boundary test · openclaw/openclaw@7d4f1a6 Docs: add test performance guardrails · openclaw/openclaw@89706d3 Tests: restore context-engine usage proof · openclaw/openclaw@e4c4f95 Tests: slim context engine runtime coverage · openclaw/openclaw@74c198f ci: retry failed custom checkouts · openclaw/openclaw@0ee5baf test: trim duplicate provider auth onboarding cases · openclaw/openclaw@1ffc02e matrix: fix sessions_spawn --thread subagent session spawning (#67643) · openclaw/openclaw@1ce2596 test: reduce auth choice fixture churn · openclaw/openclaw@857b9cd test: mock health status config boundaries · openclaw/openclaw@9d5ab4a test: mock onboard config io boundary · openclaw/openclaw@299694d test: mock legacy state plugin boundaries · openclaw/openclaw@2713089 test: mock channel install boundaries · openclaw/openclaw@b945248 test: mock doctor preview channel boundaries · openclaw/openclaw@b1a3ad4 test: trim doctor command hotspots · openclaw/openclaw@c66f16a test: isolate agent auth and spawn hotspots · openclaw/openclaw@9285935 test: stabilize MCP startup disposal race · openclaw/openclaw@dd9d2eb test: merge browser contract server suites · openclaw/openclaw@5817a76 test: narrow ollama provider discovery setup · openclaw/openclaw@a0d9598 build: declare qa-lab aimock runtime dependency · openclaw/openclaw@24431e5 test: speed up safe-bins exec harness · openclaw/openclaw@ee856ab test: preserve tool helpers in embedded runner mocks · openclaw/openclaw@acd86a0 refactor: move memory embeddings into provider plugins · openclaw/openclaw@77e6e4c test: reuse system-run temp fixtures · openclaw/openclaw@7e9ff0f test: trim hotspot wait overhead · openclaw/openclaw@12a59b0 Check: avoid duplicate boundary prep · openclaw/openclaw@baf11b8 test: reduce hotspot fixture overhead · openclaw/openclaw@3a59edd feat(ui): overhaul settings and slash command UX (#67819) thanks @Bun… · openclaw/openclaw@2cfb660 QA Matrix: exit cleanly on failure · openclaw/openclaw@42805d2 QA Matrix: isolate scenario coverage · openclaw/openclaw@7e659e1 Matrix: refresh crypto bootstrap state · openclaw/openclaw@94081d8 QA Lab: add provider registry · openclaw/openclaw@bb7e982 Matrix: add plugin changelog · openclaw/openclaw@4acab55 test: trim more hotspot overhead · openclaw/openclaw@f485311 test: trim remaining hotspot tests · openclaw/openclaw@6ba8626 test: narrow hotspot mocks · openclaw/openclaw@dbc8179 test: isolate gemini embedding request helpers · openclaw/openclaw@cd330f5 test: trim memory and mcp hotspots · openclaw/openclaw@fd48dfa test: slim provider registry mocks · openclaw/openclaw@2e08c77 test: harden Parallels update smoke · openclaw/openclaw@1a98090 feat: default Anthropic to Opus 4.7 · openclaw/openclaw@628b454 fix: harden node-host shell payload mutability checks · openclaw/openclaw@75c551e fix: land node-host approval binding for native binaries (#66731) (th… · openclaw/openclaw@29919bb CI: add daily schedule to CodeQL workflow (#67645) · openclaw/openclaw@69d25f5 fix(gateway): capture config hash after plugin auto-enable to prevent… · openclaw/openclaw@8c11210 fix: repair sanitized replay tool results before send (#67620) (thank… · openclaw/openclaw@c3c7a99 fix: restrict HTML timeout short-circuit to transient statuses · openclaw/openclaw@de129a6 fix: keep TUI watchdog bound to active run (#67401) (thanks @xantorres) · openclaw/openclaw@3525273 Gateway/skills: dedupe skills prefix-match + drop dead fallback on log · openclaw/openclaw@d7f489f Extensions/lmstudio: back off inference preload after consecutive fai… · openclaw/openclaw@b555214 TUI/streaming: add watchdog that resets the activity indicator after … · openclaw/openclaw@f44ab20 Agents/tool-loop: enable unknown-tool stream guard by default · openclaw/openclaw@36ed367 Gateway/skills: invalidate session skills snapshot on config write · openclaw/openclaw@b23d59a fix: classify HTML provider error pages correctly (#67642) (thanks @s… · openclaw/openclaw@e588e90 fix(skills): remove unused model-usage import (#67641) · openclaw/openclaw@55f05df docs(changelog): credit codex fix superseded PRs · openclaw/openclaw@e485f24 fix(openai-codex): normalize stale transport metadata in resolution a… · openclaw/openclaw@90801ba CI: pin Docker-related GitHub Actions (#67632) · openclaw/openclaw@f697b01 Android: modernize WebView and discovery API usage (#67627) · openclaw/openclaw@44a6e50 fix(deps): bump hono to 4.12.14 and @hono/node-server to 1.19.14 (GHS… · openclaw/openclaw@fbccc18 fix(deps): bump dompurify to 3.4.0 (#67614) · openclaw/openclaw@2c2dc00 CI: add explicit permissions to all workflow jobs (fixes code-scannin… · openclaw/openclaw@01b7516 fix: register bundled TTS providers and route overrides correctly (#6… · openclaw/openclaw@6ea3cdd fix: align host tilde paths with OS home (#62804) (thanks @stainlu) · openclaw/openclaw@ecfaf64 fix: flush creds queue before reconnect socket open (#67464) (thanks … · openclaw/openclaw@405c63f fix: strip standalone <function> tool call tags from visible text (#6… · openclaw/openclaw@78df859 fix(agents): preserve cli session metadata before transcript persist … · openclaw/openclaw@898fd04 docs(changelog): move cli transcript entry · openclaw/openclaw@c1817c6 fix(agents): normalize cli transcript api field · openclaw/openclaw@3a3fae0 docs(changelog): note cli transcript persistence · openclaw/openclaw@6c343f1 fix(agents): persist cli transcript turns · openclaw/openclaw@b8ef507 fix(msteams): harden security-sensitive flows (#65841) · openclaw/openclaw@c56b56e [Dashboard] Fix exec approval modal overflow for long command content… · openclaw/openclaw@053c5b0 Docs: remove QA changelog entry · openclaw/openclaw@7fd5771 QA: fix private runtime source loading (#67428) · openclaw/openclaw@d5933af docs(gateway): correct protocol.md schema path, hello-ok example, aut… · openclaw/openclaw@489404d CI: pin Node 22 runners to 22.18.0 · openclaw/openclaw@4ffa621 models.authStatus: normalize provider ids + tighten env-backed escape… · openclaw/openclaw@f2fdb9d Update CHANGELOG.md · openclaw/openclaw@7694a92 test(parallels): clean up npm update guard jobs · openclaw/openclaw@045ea7b Plugins: prefer scanDir override paths · openclaw/openclaw@b2974da fix(dreaming): default storage.mode to "separate" so phase blocks sto… · openclaw/openclaw@8c392f0 fix(memory-core): skip dreaming transcript ingestion via session stor… · openclaw/openclaw@a1b01f0 fix: dedupe replayed exec.finished node events (#67281) · openclaw/openclaw@5dcf526
Remove ttl on auth config. Prewarm prepared config for each agent. Ke… · openclaw/openclaw@95343af
sjf · 2026-05-22 · via Recent Commits to openclaw:main
11

import { hashRuntimeConfigValue } from "../config/runtime-snapshot.js";

22

import type { OpenClawConfig } from "../config/types.openclaw.js";

3+

import {

4+

listAgentIds,

5+

resolveAgentDir,

6+

resolveAgentWorkspaceDir,

7+

resolveDefaultAgentId,

8+

} from "./agent-scope-config.js";

39

import {

410

externalCliDiscoveryForProviderAuth,

511

externalCliDiscoveryForProviders,

@@ -20,24 +26,43 @@ import { resolveDefaultAgentWorkspaceDir } from "./workspace.js";

2026

// discovery and external-CLI probing on the hot path.

21272228

type PreparedProviderAuthState = {

29+

agentId: string;

2330

configFingerprint: string;

24-

workspaceDir: string;

25-

preparedAtMs: number;

2631

providers: ReadonlyMap<string, boolean>;

2732

};

283329-

const PREPARED_PROVIDER_AUTH_STATE_TTL_MS = 10_000;

30-

let currentProviderAuthState: PreparedProviderAuthState | null = null;

34+

// One entry per configured agent, keyed by agentId. Populated by

35+

// warmCurrentProviderAuthState at gateway startup / on reload; consulted by

36+

// hasAuthForModelProvider on every model-listing call.

37+

let currentProviderAuthStates: ReadonlyMap<string, PreparedProviderAuthState> | null = null;

3138

const configFingerprintCache = new WeakMap<OpenClawConfig, string>();

3239

// Generation counter guards against an in-flight warm publishing stale

3340

// state after a subsequent warm or clear has invalidated it.

3441

let currentProviderAuthStateGeneration = 0;

35423643

export function clearCurrentProviderAuthState(): void {

37-

currentProviderAuthState = null;

44+

currentProviderAuthStates = null;

3845

currentProviderAuthStateGeneration += 1;

3946

}

404748+

function resolvePreparedStateForCaller(params: {

49+

states: ReadonlyMap<string, PreparedProviderAuthState> | null;

50+

cfg: OpenClawConfig | undefined;

51+

callerAgentId: string | undefined;

52+

}): PreparedProviderAuthState | null {

53+

if (!params.states) {

54+

return null;

55+

}

56+

if (params.callerAgentId !== undefined) {

57+

return params.states.get(params.callerAgentId) ?? null;

58+

}

59+

// Caller didn't pass agentId: treat as a query against the default agent.

60+

if (!params.cfg) {

61+

return null;

62+

}

63+

return params.states.get(resolveDefaultAgentId(params.cfg)) ?? null;

64+

}

65+4166

function resolveProviderAuthConfigFingerprint(cfg: OpenClawConfig | undefined): string | null {

4267

if (!cfg) {

4368

return null;

@@ -55,33 +80,41 @@ export function hasAuthForModelProvider(params: {

5580

provider: string;

5681

cfg?: OpenClawConfig;

5782

workspaceDir?: string;

58-

agentDir?: string;

83+

agentId?: string;

5984

env?: NodeJS.ProcessEnv;

6085

store?: AuthProfileStore;

6186

allowPluginSyntheticAuth?: boolean;

6287

discoverExternalCliAuth?: boolean;

6388

}): boolean {

6489

const provider = normalizeProviderId(params.provider);

65-

// The prepared map is built by warmCurrentProviderAuthState with broad

66-

// auth discovery (external CLI + plugin synthetic auth enabled) and the

67-

// default-agent workspace dir. Only consult it when the caller's full

68-

// auth context matches; otherwise fall through to compute so callers

69-

// that narrow the scope — e.g. gateway `models.list` with

70-

// `runtimeAuthDiscovery: false`, or per-agent picker calls that pass a

71-

// non-default workspaceDir — get the answer they asked for.

72-

const preparedState = currentProviderAuthState;

90+

// The prepared map is built by warmCurrentProviderAuthState — one entry per

91+

// configured agent, keyed by agentId. Only consult it when the caller's

92+

// full auth context matches the warmed scope; otherwise fall through to

93+

// compute so callers that narrow the scope — e.g. gateway `models.list`

94+

// with `runtimeAuthDiscovery: false`, or callers with a non-warmed

95+

// workspaceDir — get the answer they asked for.

96+

const preparedStates = currentProviderAuthStates;

7397

const workspaceDir = params.workspaceDir ?? resolveDefaultAgentWorkspaceDir();

7498

const configFingerprint = resolveProviderAuthConfigFingerprint(params.cfg);

75-

const preparedStateFresh =

76-

preparedState !== null &&

77-

Date.now() - preparedState.preparedAtMs <= PREPARED_PROVIDER_AUTH_STATE_TTL_MS;

99+

const preparedState = resolvePreparedStateForCaller({

100+

states: preparedStates,

101+

cfg: params.cfg,

102+

callerAgentId: params.agentId,

103+

});

104+

// workspaceDir is a pure function of (cfg, agentId), so we recompute the

105+

// warmer's expected value at read time rather than storing it. Caller can

106+

// still override workspaceDir explicitly — that forces a mismatch and

107+

// falls through to the compute path.

108+

const expectedWorkspaceDir =

109+

preparedState !== null && params.cfg

110+

? resolveAgentWorkspaceDir(params.cfg, preparedState.agentId)

111+

: null;

78112

const matchesWarmedScope =

79-

preparedStateFresh &&

113+

preparedState !== null &&

80114

configFingerprint === preparedState.configFingerprint &&

81-

workspaceDir === preparedState.workspaceDir &&

115+

workspaceDir === expectedWorkspaceDir &&

82116

params.discoverExternalCliAuth !== false &&

83117

params.allowPluginSyntheticAuth !== false &&

84-

params.agentDir === undefined &&

85118

params.env === undefined &&

86119

params.store === undefined;

87120

if (matchesWarmedScope) {

@@ -101,13 +134,15 @@ export function hasAuthForModelProvider(params: {

101134

) {

102135

return true;

103136

}

137+

const slowPathAgentDir =

138+

params.agentId && params.cfg ? resolveAgentDir(params.cfg, params.agentId) : undefined;

104139

const store =

105140

params.store ??

106141

(params.discoverExternalCliAuth === false

107-

? ensureAuthProfileStoreWithoutExternalProfiles(params.agentDir, {

142+

? ensureAuthProfileStoreWithoutExternalProfiles(slowPathAgentDir, {

108143

allowKeychainPrompt: false,

109144

})

110-

: ensureAuthProfileStore(params.agentDir, {

145+

: ensureAuthProfileStore(slowPathAgentDir, {

111146

externalCli: externalCliDiscoveryForProviderAuth({ cfg: params.cfg, provider }),

112147

}));

113148

if (listProfilesForProvider(store, provider).length > 0) {

@@ -119,7 +154,7 @@ export function hasAuthForModelProvider(params: {

119154

export function createProviderAuthChecker(params: {

120155

cfg?: OpenClawConfig;

121156

workspaceDir?: string;

122-

agentDir?: string;

157+

agentId?: string;

123158

env?: NodeJS.ProcessEnv;

124159

allowPluginSyntheticAuth?: boolean;

125160

discoverExternalCliAuth?: boolean;

@@ -135,7 +170,7 @@ export function createProviderAuthChecker(params: {

135170

provider: key,

136171

cfg: params.cfg,

137172

workspaceDir: params.workspaceDir,

138-

agentDir: params.agentDir,

173+

agentId: params.agentId,

139174

env: params.env,

140175

allowPluginSyntheticAuth: params.allowPluginSyntheticAuth,

141176

discoverExternalCliAuth: params.discoverExternalCliAuth,

@@ -155,35 +190,45 @@ export async function warmCurrentProviderAuthState(cfg: OpenClawConfig): Promise

155190

for (const entry of catalog) {

156191

providers.add(normalizeProviderId(entry.provider));

157192

}

158-

const workspaceDir = resolveDefaultAgentWorkspaceDir();

159-

// One AuthProfileStore scoped to every candidate provider; without this the

160-

// per-provider externalCli discovery rebuilds the store ~N times.

161-

const store = ensureAuthProfileStore(undefined, {

162-

config: cfg,

163-

externalCli: externalCliDiscoveryForProviders({

164-

cfg,

165-

providers: [...providers],

166-

}),

167-

});

168-

const state = new Map<string, boolean>();

169-

for (const provider of providers) {

170-

const value = hasAuthForModelProvider({

171-

provider,

172-

cfg,

173-

workspaceDir,

174-

store,

193+

const providerList = [...providers];

194+

const configFingerprint = resolveProviderAuthConfigFingerprint(cfg) ?? "";

195+

const states = new Map<string, PreparedProviderAuthState>();

196+

// Warm one entry per configured agent so callers hit the prepared map for

197+

// any agentId. The catalog above is shared across agents; the per-agent

198+

// work is the auth-discovery sweep against that agent's store.

199+

for (const agentId of listAgentIds(cfg)) {

200+

const workspaceDir = resolveAgentWorkspaceDir(cfg, agentId);

201+

const agentDir = resolveAgentDir(cfg, agentId);

202+

// One AuthProfileStore scoped to every candidate provider; without this

203+

// the per-provider externalCli discovery rebuilds the store ~N times.

204+

const store = ensureAuthProfileStore(agentDir, {

205+

config: cfg,

206+

externalCli: externalCliDiscoveryForProviders({

207+

cfg,

208+

providers: providerList,

209+

}),

210+

});

211+

const state = new Map<string, boolean>();

212+

for (const provider of providers) {

213+

const value = hasAuthForModelProvider({

214+

provider,

215+

cfg,

216+

workspaceDir,

217+

agentId,

218+

store,

219+

});

220+

state.set(provider, value);

221+

}

222+

states.set(agentId, {

223+

agentId,

224+

configFingerprint,

225+

providers: state,

175226

});

176-

state.set(provider, value);

177227

}

178228

if (ownGeneration !== currentProviderAuthStateGeneration) {

179229

// A newer warm or clear ran while we were building; skip publication so

180230

// the newer answer wins.

181231

return;

182232

}

183-

currentProviderAuthState = {

184-

configFingerprint: resolveProviderAuthConfigFingerprint(cfg) ?? "",

185-

workspaceDir,

186-

preparedAtMs: Date.now(),

187-

providers: state,

188-

};

233+

currentProviderAuthStates = states;

189234

}