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

推荐订阅源

V2EX - 技术
V2EX - 技术
L
LangChain Blog
IT之家
IT之家
S
SegmentFault 最新的问题
博客园 - 三生石上(FineUI控件)
H
Hackread – Cybersecurity News, Data Breaches, AI and More
T
The Blog of Author Tim Ferriss
Blog — PlanetScale
Blog — PlanetScale
N
Netflix TechBlog - Medium
U
Unit 42
B
Blog RSS Feed
GbyAI
GbyAI
Microsoft Security Blog
Microsoft Security Blog
博客园 - 司徒正美
Apple Machine Learning Research
Apple Machine Learning Research
T
Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
The Register - Security
The Register - Security
Vercel News
Vercel News
S
Schneier on Security
Spread Privacy
Spread Privacy
C
Cyber Attacks, Cyber Crime and Cyber Security
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
博客园 - 叶小钗
雷峰网
雷峰网
博客园_首页
人人都是产品经理
人人都是产品经理
P
Palo Alto Networks Blog
The Hacker News
The Hacker News
T
Tor Project blog
L
Lohrmann on Cybersecurity
Know Your Adversary
Know Your Adversary
D
Darknet – Hacking Tools, Hacker News & Cyber Security
C
Cybersecurity and Infrastructure Security Agency CISA
P
Privacy International News Feed
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
Tenable Blog
V
Vulnerabilities – Threatpost
大猫的无限游戏
大猫的无限游戏
博客园 - 【当耐特】
V
V2EX
Security Latest
Security Latest
A
About on SuperTechFans
Cloudbric
Cloudbric
S
Security Affairs
MongoDB | Blog
MongoDB | Blog
Y
Y Combinator Blog
Martin Fowler
Martin Fowler
TaoSecurity Blog
TaoSecurity Blog

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
refactor(browser): simplify lazy CLI placeholders · openclaw/openclaw@89755d1
steipete · 2026-04-25 · via Recent Commits to openclaw:main

@@ -1,12 +1,10 @@

11

import type { Command } from "commander";

22

import {

3-

buildCommandGroupEntries,

43

registerCommandGroups,

54

resolveCliArgvInvocation,

65

shouldEagerRegisterSubcommands,

76

type CommandGroupEntry,

8-

type CommandGroupDescriptorSpec,

9-

type NamedCommandDescriptor,

7+

type CommandGroupPlaceholder,

108

} from "openclaw/plugin-sdk/cli-runtime";

119

import { browserActionExamples, browserCoreExamples } from "./browser-cli-examples.js";

1210

import type { BrowserParentOpts } from "./browser-cli-shared.js";

@@ -20,178 +18,107 @@ import {

2018

theme,

2119

} from "./core-api.js";

222023-

type BrowserCommandDescriptor = NamedCommandDescriptor;

2421

type BrowserCommandRegistrar = (args: {

2522

browser: Command;

2623

parentOpts: (cmd: Command) => BrowserParentOpts;

2724

}) => Promise<void> | void;

282529-

const browserCommandDescriptors: readonly BrowserCommandDescriptor[] = [

30-

{ name: "status", description: "Show browser status", hasSubcommands: false },

31-

{

32-

name: "start",

33-

description: "Start the browser (no-op if already running)",

34-

hasSubcommands: false,

35-

},

36-

{ name: "stop", description: "Stop the browser (best-effort)", hasSubcommands: false },

37-

{

38-

name: "reset-profile",

39-

description: "Reset browser profile (moves it to Trash)",

40-

hasSubcommands: false,

41-

},

42-

{ name: "tabs", description: "List open tabs", hasSubcommands: false },

43-

{ name: "tab", description: "Tab shortcuts (index-based)", hasSubcommands: true },

44-

{ name: "open", description: "Open a URL in a new tab", hasSubcommands: false },

45-

{

46-

name: "focus",

47-

description: "Focus a tab by target id (or unique prefix)",

48-

hasSubcommands: false,

49-

},

50-

{ name: "close", description: "Close a tab (target id optional)", hasSubcommands: false },

51-

{ name: "profiles", description: "List all browser profiles", hasSubcommands: false },

52-

{ name: "create-profile", description: "Create a new browser profile", hasSubcommands: false },

53-

{ name: "delete-profile", description: "Delete a browser profile", hasSubcommands: false },

54-

{ name: "screenshot", description: "Capture a screenshot (MEDIA:<path>)", hasSubcommands: false },

55-

{

56-

name: "snapshot",

57-

description: "Capture a snapshot (default: ai; aria is the accessibility tree)",

58-

hasSubcommands: false,

59-

},

60-

{ name: "navigate", description: "Navigate the current tab to a URL", hasSubcommands: false },

61-

{ name: "resize", description: "Resize the viewport", hasSubcommands: false },

62-

{ name: "click", description: "Click an element by ref from snapshot", hasSubcommands: false },

63-

{ name: "click-coords", description: "Click viewport coordinates", hasSubcommands: false },

64-

{ name: "type", description: "Type into an element by ref from snapshot", hasSubcommands: false },

65-

{ name: "press", description: "Press a key", hasSubcommands: false },

66-

{ name: "hover", description: "Hover an element by ai ref", hasSubcommands: false },

67-

{

68-

name: "scrollintoview",

69-

description: "Scroll an element into view by ref from snapshot",

70-

hasSubcommands: false,

71-

},

72-

{ name: "drag", description: "Drag from one ref to another", hasSubcommands: false },

73-

{ name: "select", description: "Select option(s) in a select element", hasSubcommands: false },

74-

{

75-

name: "upload",

76-

description: "Arm file upload for the next file chooser",

77-

hasSubcommands: false,

78-

},

79-

{

80-

name: "waitfordownload",

81-

description: "Wait for the next download (and save it)",

82-

hasSubcommands: false,

83-

},

84-

{

85-

name: "download",

86-

description: "Click a ref and save the resulting download",

87-

hasSubcommands: false,

88-

},

89-

{

90-

name: "dialog",

91-

description: "Arm the next modal dialog (alert/confirm/prompt)",

92-

hasSubcommands: false,

93-

},

94-

{ name: "fill", description: "Fill a form with JSON field descriptors", hasSubcommands: false },

95-

{

96-

name: "wait",

97-

description: "Wait for time, selector, URL, load state, or JS conditions",

98-

hasSubcommands: false,

99-

},

100-

{

101-

name: "evaluate",

102-

description: "Evaluate a function against the page or a ref",

103-

hasSubcommands: false,

104-

},

105-

{ name: "console", description: "Get recent console messages", hasSubcommands: false },

106-

{ name: "pdf", description: "Save page as PDF", hasSubcommands: false },

107-

{

108-

name: "responsebody",

109-

description: "Wait for a network response and return its body",

110-

hasSubcommands: false,

111-

},

112-

{ name: "highlight", description: "Highlight an element by ref", hasSubcommands: false },

113-

{ name: "errors", description: "Get recent page errors", hasSubcommands: false },

114-

{

115-

name: "requests",

116-

description: "Get recent network requests (best-effort)",

117-

hasSubcommands: false,

118-

},

119-

{ name: "doctor", description: "Diagnose browser readiness", hasSubcommands: false },

120-

{ name: "trace", description: "Record a Playwright trace", hasSubcommands: true },

121-

{ name: "cookies", description: "Read/write cookies", hasSubcommands: true },

122-

{ name: "storage", description: "Read/write localStorage/sessionStorage", hasSubcommands: true },

123-

{ name: "set", description: "Browser environment settings", hasSubcommands: true },

124-

];

26+

type BrowserCommandGroupDefinition = {

27+

placeholders: readonly CommandGroupPlaceholder[];

28+

register: BrowserCommandRegistrar;

29+

};

12530126-

const browserCommandGroupSpecs: readonly CommandGroupDescriptorSpec<BrowserCommandRegistrar>[] = [

127-

{

128-

commandNames: [

129-

"status",

130-

"start",

131-

"stop",

132-

"reset-profile",

133-

"tabs",

134-

"tab",

135-

"open",

136-

"focus",

137-

"close",

138-

"profiles",

139-

"create-profile",

140-

"delete-profile",

31+

const command = (name: string, description: string): CommandGroupPlaceholder => ({

32+

name,

33+

description,

34+

});

35+36+

const browserCommandGroupDefinitions: readonly BrowserCommandGroupDefinition[] = [

37+

{

38+

placeholders: [

39+

command("status", "Show browser status"),

40+

command("start", "Start the browser (no-op if already running)"),

41+

command("stop", "Stop the browser (best-effort)"),

42+

command("reset-profile", "Reset browser profile (moves it to Trash)"),

43+

command("tabs", "List open tabs"),

44+

command("tab", "Tab shortcuts (index-based)"),

45+

command("open", "Open a URL in a new tab"),

46+

command("focus", "Focus a tab by target id, tab id, label, or unique target id prefix"),

47+

command("close", "Close a tab (target id optional)"),

48+

command("profiles", "List all browser profiles"),

49+

command("create-profile", "Create a new browser profile"),

50+

command("delete-profile", "Delete a browser profile"),

14151

],

14252

register: async (args) => {

14353

const module = await import("./browser-cli-manage.js");

14454

module.registerBrowserManageCommands(args.browser, args.parentOpts);

14555

},

14656

},

14757

{

148-

commandNames: ["screenshot", "snapshot"],

58+

placeholders: [

59+

command("screenshot", "Capture a screenshot (MEDIA:<path>)"),

60+

command("snapshot", "Capture a snapshot (default: ai; aria is the accessibility tree)"),

61+

],

14962

register: async (args) => {

15063

const module = await import("./browser-cli-inspect.js");

15164

module.registerBrowserInspectCommands(args.browser, args.parentOpts);

15265

},

15366

},

15467

{

155-

commandNames: [

156-

"navigate",

157-

"resize",

158-

"click",

159-

"click-coords",

160-

"type",

161-

"press",

162-

"hover",

163-

"scrollintoview",

164-

"drag",

165-

"select",

166-

"upload",

167-

"waitfordownload",

168-

"download",

169-

"dialog",

170-

"fill",

171-

"wait",

172-

"evaluate",

68+

placeholders: [

69+

command("navigate", "Navigate the current tab to a URL"),

70+

command("resize", "Resize the viewport"),

71+

command("click", "Click an element by ref from snapshot"),

72+

command("click-coords", "Click viewport coordinates"),

73+

command("type", "Type into an element by ref from snapshot"),

74+

command("press", "Press a key"),

75+

command("hover", "Hover an element by ai ref"),

76+

command("scrollintoview", "Scroll an element into view by ref from snapshot"),

77+

command("drag", "Drag from one ref to another"),

78+

command("select", "Select option(s) in a select element"),

79+

command("upload", "Arm file upload for the next file chooser"),

80+

command("waitfordownload", "Wait for the next download (and save it)"),

81+

command("download", "Click a ref and save the resulting download"),

82+

command("dialog", "Arm the next modal dialog (alert/confirm/prompt)"),

83+

command("fill", "Fill a form with JSON field descriptors"),

84+

command("wait", "Wait for time, selector, URL, load state, or JS conditions"),

85+

command("evaluate", "Evaluate a function against the page or a ref"),

17386

],

17487

register: async (args) => {

17588

const module = await import("./browser-cli-actions-input.js");

17689

module.registerBrowserActionInputCommands(args.browser, args.parentOpts);

17790

},

17891

},

17992

{

180-

commandNames: ["console", "pdf", "responsebody"],

93+

placeholders: [

94+

command("console", "Get recent console messages"),

95+

command("pdf", "Save page as PDF"),

96+

command("responsebody", "Wait for a network response and return its body"),

97+

],

18198

register: async (args) => {

18299

const module = await import("./browser-cli-actions-observe.js");

183100

module.registerBrowserActionObserveCommands(args.browser, args.parentOpts);

184101

},

185102

},

186103

{

187-

commandNames: ["highlight", "errors", "requests", "doctor", "trace"],

104+

placeholders: [

105+

command("highlight", "Highlight an element by ref"),

106+

command("errors", "Get recent page errors"),

107+

command("requests", "Get recent network requests (best-effort)"),

108+

command("doctor", "Check browser plugin readiness"),

109+

command("trace", "Record a Playwright trace"),

110+

],

188111

register: async (args) => {

189112

const module = await import("./browser-cli-debug.js");

190113

module.registerBrowserDebugCommands(args.browser, args.parentOpts);

191114

},

192115

},

193116

{

194-

commandNames: ["cookies", "storage", "set"],

117+

placeholders: [

118+

command("cookies", "Read/write cookies"),

119+

command("storage", "Read/write localStorage/sessionStorage"),

120+

command("set", "Browser environment settings"),

121+

],

195122

register: async (args) => {

196123

const module = await import("./browser-cli-state.js");

197124

module.registerBrowserStateCommands(args.browser, args.parentOpts);

@@ -203,11 +130,10 @@ function buildBrowserCommandGroups(params: {

203130

browser: Command;

204131

parentOpts: (cmd: Command) => BrowserParentOpts;

205132

}): CommandGroupEntry[] {

206-

return buildCommandGroupEntries(

207-

browserCommandDescriptors,

208-

browserCommandGroupSpecs,

209-

(register) => async () => await register(params),

210-

);

133+

return browserCommandGroupDefinitions.map((entry) => ({

134+

placeholders: entry.placeholders,

135+

register: async () => await entry.register(params),

136+

}));

211137

}

212138213139

function registerLazyBrowserCommands(