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

推荐订阅源

F
Full Disclosure
Recorded Future
Recorded Future
T
Tenable Blog
S
Securelist
C
CERT Recently Published Vulnerability Notes
T
Threatpost
S
Schneier on Security
A
Arctic Wolf
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
AWS News Blog
AWS News Blog
K
Kaspersky official blog
T
True Tiger Recordings
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
P
Palo Alto Networks Blog
T
The Exploit Database - CXSecurity.com
小众软件
小众软件
B
Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Microsoft Azure Blog
Microsoft Azure Blog
Cyberwarzone
Cyberwarzone
C
Cybersecurity and Infrastructure Security Agency CISA
T
Tor Project blog
Spread Privacy
Spread Privacy
Malwarebytes
Malwarebytes
P
Proofpoint News Feed
F
Fox-IT International blog
F
Fortinet All Blogs
P
Privacy & Cybersecurity Law Blog
G
GRAHAM CLULEY
量子位
Latest news
Latest news
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 叶小钗
Project Zero
Project Zero
T
Tailwind CSS Blog
N
Netflix TechBlog - Medium
Martin Fowler
Martin Fowler
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
I
Intezer
博客园_首页
腾讯CDC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
Darknet – Hacking Tools, Hacker News & Cyber Security

Recent Commits to openclaw:main

ci: retry corepack pnpm activation · openclaw/openclaw@d122839 test: bound gateway live model discovery · openclaw/openclaw@dc1e6fb test: speed up plugin install suites · openclaw/openclaw@75fc0bc fix(irc): use channel routes for group inbound targets · openclaw/openclaw@bf8be79 Preserve xAI usage limit errors in local TUI (#86614) · openclaw/openclaw@532494b fix: filter claude autoreview streaming · openclaw/openclaw@fa384d4 fix(cli-runner): scale Claude CLI reseed history automatically · openclaw/openclaw@474b1e0 test: speed up infra test hotspots · openclaw/openclaw@8592352 fix(e2e): keep mac smoke commands bounded without timeout · openclaw/openclaw@3e70144 fix(live): classify Z.ai plan denials as billing drift · openclaw/openclaw@693f06d fix(config): render transform-backed config schema inputs (#67328) · openclaw/openclaw@678a0ee perf: speed up test hotspots · openclaw/openclaw@980d73d feat: stream autoreview progress · openclaw/openclaw@322ceb3 test: improve full-suite failure summaries · openclaw/openclaw@8f1fb67 fix(e2e): require bounded helper timeouts · openclaw/openclaw@0028c2f fix(ui): eliminate double scrollbar on Logs view · openclaw/openclaw@068d88c test: speed up hot test fixtures · openclaw/openclaw@0f608bc fix(commands): preserve async skill commands · openclaw/openclaw@1313e15 fix(docker): bound telegram npm installs · openclaw/openclaw@130464e fix(mac): use corepack pnpm for app packaging · openclaw/openclaw@728b61a fix: mark ios watch app as watchkit app · openclaw/openclaw@1600bcd docs: explain bundled plugin npm override · openclaw/openclaw@40fa750 fix: keep bundled OpenClaw plugins image-owned · openclaw/openclaw@771675e test: fix bundled install mock typing · openclaw/openclaw@669bfdd fix: preserve whatsapp inbound batch order · openclaw/openclaw@84a33c7 perf: cache npm globalconfig lookups · openclaw/openclaw@3f524a6 fix(daemon): ignore recursive Windows gateway wrapper · openclaw/openclaw@126a336 fix(docker): bound live setup commands · openclaw/openclaw@eb15c44 fix: restore ios build stability · openclaw/openclaw@1daef79 feat(plugin-sdk): add reaction approval helpers (#86735) · openclaw/openclaw@7d6b7f4 test(auto-reply): type manifest catalog harness mock · openclaw/openclaw@4f83cd6 fix(docker): bound live docker runs · openclaw/openclaw@96307ca test(auto-reply): mock manifest model catalog in trigger harness · openclaw/openclaw@989d449 fix(crabbox): scope env-wrapped macOS bootstrap · openclaw/openclaw@2f7bfdb fix(gateway): reject RPCs from invalidated device-token clients durin… · openclaw/openclaw@1e1cf14 fix(channel): handle plugin channel markdown fallback · openclaw/openclaw@6158742 fix(docker): require bounded e2e docker commands · openclaw/openclaw@3736d7b fix(codex): share native hook relay registry (#73950) · openclaw/openclaw@6729dea fix(release): stabilize plugin prerelease tests · openclaw/openclaw@5a684c4 fix(diagnostics): flush OTel trace batches · openclaw/openclaw@c4b9f54 fix(memory): reject invalid CLI numeric options · openclaw/openclaw@d569e41 fix(codex): bound app-server timeout fallout · openclaw/openclaw@5a7d5c6 fix(agents): keep model browse normalization bounded · openclaw/openclaw@9fc71e9 fix: stabilize media-related tests · openclaw/openclaw@a818556 fix(ci): preserve docker pull retry failures · openclaw/openclaw@be2213e fix(build): stabilize shrinkwrap generation · openclaw/openclaw@538b537 fix(ui): ignore stale running session rows · openclaw/openclaw@1705189 ci: support windows node download fallback · openclaw/openclaw@bb48fcf test(agents): pin native anthropic replay policy · openclaw/openclaw@acd3ce0 fix(status): surface systemd gateway hygiene (#86976) · openclaw/openclaw@0a085bf fix(ui): show failed tool results as errors (#85786) ci: allow Windows Node 22 patch range · openclaw/openclaw@ce4db4f ci: enforce Node 22 floor in setup helper · openclaw/openclaw@1d972af Fix status JSON plugin scan (#87001) · openclaw/openclaw@f3e6158 fix(telegram): preserve command slots for aliases (#85270) · openclaw/openclaw@77505da fix(agents): handle deferred maintenance drain · openclaw/openclaw@94fb547 test: keep legacy tool-result error proof ci: fix post-merge Rastermill checks · openclaw/openclaw@b546998 fix(agents): mark repaired legacy tool results errored · openclaw/openclaw@8523d32 docs(changelog): note rastermill exif fix docs(changelog): regroup 2026.5.26 release notes · openclaw/openclaw@a6973ab fix: keep EXIF normalization best-effort (#86923) · openclaw/openclaw@acb942f build: update rastermill pin · openclaw/openclaw@7d4d751 build: use rastermill 0.3.0 · openclaw/openclaw@cee8c87 ci: normalize Windows toolcache paths · openclaw/openclaw@03ae999 refactor: use unified rastermill encode API · openclaw/openclaw@a3325c9 ci: satisfy opengrep git add guard · openclaw/openclaw@16d06aa refactor: delegate image processing to Rastermill · openclaw/openclaw@50b98a1 build: update rastermill dependency · openclaw/openclaw@e6edcca fix: infer realtime smoke dev server type · openclaw/openclaw@4e84229 refactor: delegate image limits to Rastermill · openclaw/openclaw@4f728f8 fix(agents): repair legacy tool results before replay · openclaw/openclaw@4e45b11 fix(config): narrow profiled tool section doctor repair (#87030) · openclaw/openclaw@3c16648 test: fix current suite drift · openclaw/openclaw@80655fe fix(lock): require owner identity proof before stale removal · openclaw/openclaw@daa7b1d fix(deps): pin shrinkwrap patch drift to pnpm lock · openclaw/openclaw@d8a14e7 revert: 60bec8c duplicate tool display guard · openclaw/openclaw@e09f89d fix(e2e): bound docker package preparation · openclaw/openclaw@38edae7 fix(cli): add Windows stack-size respawn (#87031) · openclaw/openclaw@5e8f498 fix(agents): preserve sessions_spawn transcript payloads (#82203) · openclaw/openclaw@ef86d8c fix(agents): guard duplicate tool display metadata (#87025) · openclaw/openclaw@60bec8c ci(release): port 2026.5.25 release gate fixes · openclaw/openclaw@f7e2d9b chore: update tool display snapshot · openclaw/openclaw@ad71c42 fix(web-search): keep runtime legacy merge out of validation (#86818) · openclaw/openclaw@4a85cd7 fix(cli): default logs to local timestamps (#85387) · openclaw/openclaw@3127808 fix(agents): dedupe transcripts tool display config · openclaw/openclaw@8788ae1 fix(updater): exclude prerelease tags from stable git channel (#86559) · openclaw/openclaw@e070519 fix(agents): memoize session lock owner args · openclaw/openclaw@c430fcd fix: dedupe transcripts tool display metadata · openclaw/openclaw@0f49bbb fix(cli): validate timeout and banner TTY state · openclaw/openclaw@abb85cc fix(codex): project newer history on app-server resume (#86677) fix(codex): keep turn timeouts inside Codex (#86476) fix(auto-reply): stage sandboxed workspace media · openclaw/openclaw@f22c3a5 fix(e2e): support plain telegram install timeouts fix(mac): harden restart and dSYM packaging · openclaw/openclaw@639e7ff fix(exec): avoid default approval store writes (#86964) · openclaw/openclaw@4d65936 fix(agents): restore current guard checks (#86934) · openclaw/openclaw@9b1b6d0 docs(changelog): prepare 2026.5.26 notes · openclaw/openclaw@983b338 fix(reply): defer context compaction safely · openclaw/openclaw@ed3ae0d fix(codex): gate profiler timing and startup setup · openclaw/openclaw@21c25bb
fix(auto-reply): suppress repeated silent tokens (#86848) · openclaw/openclaw@8ec2b2d
Alix-007 · 2026-05-27 · via Recent Commits to openclaw:main
Original file line numberDiff line numberDiff line change

@@ -136,6 +136,7 @@ describe("AgentRuntimePlan", () => {

136136

expect(plan.auth.authProfileProviderForAuth).toBe("openai-codex");

137137

expect(plan.auth.harnessAuthProvider).toBe("openai-codex");

138138

expect(plan.auth.forwardedAuthProfileId).toBe("openai-codex:work");

139+

expect(plan.delivery.isSilentPayload({ text: "NO_REPLY\n\nNO_REPLY" })).toBe(true);

139140

expect(plan.delivery.isSilentPayload({ text: '{"action":"NO_REPLY"}' })).toBe(true);

140141

expect(

141142

plan.delivery.isSilentPayload({

Original file line numberDiff line numberDiff line change

@@ -152,6 +152,11 @@ describe("normalizeReplyPayload", () => {

152152

it("records skip reasons for silent/empty payloads", () => {

153153

const cases = [

154154

{ name: "silent", payload: { text: SILENT_REPLY_TOKEN }, reason: "silent" },

155+

{

156+

name: "repeated silent",

157+

payload: { text: `${SILENT_REPLY_TOKEN}\n\n${SILENT_REPLY_TOKEN}` },

158+

reason: "silent",

159+

},

155160

{ name: "empty", payload: { text: " " }, reason: "empty" },

156161

] as const;

157162

for (const testCase of cases) {

Original file line numberDiff line numberDiff line change

@@ -22,6 +22,11 @@ describe("isSilentReplyText", () => {

2222

expect(isSilentReplyText(" No_RePlY ")).toBe(true);

2323

});

2424
25+

it("returns true for repeated token-only text separated by whitespace", () => {

26+

expect(isSilentReplyText("NO_REPLY\n\nNO_REPLY")).toBe(true);

27+

expect(isSilentReplyText(" no_reply \t No_RePlY ")).toBe(true);

28+

});

29+
2530

it("returns false for undefined/empty", () => {

2631

expect(isSilentReplyText(undefined)).toBe(false);

2732

expect(isSilentReplyText("")).toBe(false);

@@ -87,6 +92,11 @@ describe("custom silent tokens", () => {

8792

check: () => isSilentReplyText("Checked inbox. HEARTBEAT_OK", "HEARTBEAT_OK"),

8893

expected: false,

8994

},

95+

{

96+

name: "repeated-token detection",

97+

check: () => isSilentReplyText("HEARTBEAT_OK\nHEARTBEAT_OK", "HEARTBEAT_OK"),

98+

expected: true,

99+

},

90100

{

91101

name: "trailing token stripping",

92102

check: () => stripSilentToken("done HEARTBEAT_OK", "HEARTBEAT_OK"),

Original file line numberDiff line numberDiff line change

@@ -13,7 +13,7 @@ function getSilentExactRegex(token: string): RegExp {

1313

return cached;

1414

}

1515

const escaped = escapeRegExp(token);

16-

const regex = new RegExp(`^\\s*${escaped}\\s*$`, "i");

16+

const regex = new RegExp(`^\\s*${escaped}(?:\\s+${escaped})*\\s*$`, "i");

1717

silentExactRegexByToken.set(token, regex);

1818

return regex;

1919

}

@@ -36,7 +36,7 @@ export function isSilentReplyText(

3636

if (!text) {

3737

return false;

3838

}

39-

// Match only the exact silent token with optional surrounding whitespace.

39+

// Match only token-only replies, including repeated tokens separated by whitespace.

4040

// This prevents substantive replies ending with NO_REPLY from being suppressed (#19537).

4141

return getSilentExactRegex(token).test(text);

4242

}

Original file line numberDiff line numberDiff line change

@@ -77,6 +77,7 @@ describe("normalizeReplyPayloadsForDelivery", () => {

7777

expect(

7878

normalizeReplyPayloadsForDelivery([

7979

{ text: "NO_REPLY" },

80+

{ text: "NO_REPLY\n\nNO_REPLY" },

8081

{ text: "Reasoning:\n_step_", isReasoning: true },

8182

{ text: "final answer" },

8283

]),

@@ -157,6 +158,7 @@ describe("normalizeReplyPayloadsForDelivery", () => {

157158

normalizeReplyPayloadsForDelivery([

158159

{ text: "NO_REPLY thanks for the update" },

159160

{ text: "NO_REPLY" },

161+

{ text: "NO_REPLY\n\nNO_REPLY" },

160162

{ text: "thanks NO_REPLY" },

161163

]),

162164

).toEqual([

Original file line numberDiff line numberDiff line change

@@ -574,7 +574,12 @@ describe("plugin-sdk subpath exports", () => {

574574

"createResolvedApproverActionAuthAdapter",

575575

"resolveApprovalApprovers",

576576

]);

577-

expectSourceMentions("reply-chunking", ["chunkText", "chunkTextWithMode"]);

577+

expectSourceMentions("reply-chunking", [

578+

"chunkText",

579+

"chunkTextWithMode",

580+

"isSilentReplyPayloadText",

581+

"isSilentReplyText",

582+

]);

578583

expectSourceMentions("reply-history", [

579584

"buildInboundHistoryFromEntries",

580585

"buildInboundHistoryFromMap",

@@ -1421,6 +1426,19 @@ describe("plugin-sdk subpath exports", () => {

14211426

}

14221427

});

14231428
1429+

it("keeps repeated silent-token semantics visible through the reply-chunking subpath", async () => {

1430+

const replyChunkingSdk = await importResolvedPluginSdkSubpath(

1431+

"openclaw/plugin-sdk/reply-chunking",

1432+

);

1433+
1434+

expect(replyChunkingSdk.isSilentReplyText("NO_REPLY\n\nNO_REPLY")).toBe(true);

1435+

expect(replyChunkingSdk.isSilentReplyPayloadText("NO_REPLY\n\nNO_REPLY")).toBe(true);

1436+

expect(replyChunkingSdk.isSilentReplyText("HEARTBEAT_OK\nHEARTBEAT_OK", "HEARTBEAT_OK")).toBe(

1437+

true,

1438+

);

1439+

expect(replyChunkingSdk.isSilentReplyText("Visible update\n\nNO_REPLY")).toBe(false);

1440+

});

1441+
14241442

it("keeps the Zalouser command-auth compatibility facade importable", () => {

14251443

expect(zalouserSdk.resolveSenderCommandAuthorization).toBe(

14261444

commandAuthSdk.resolveSenderCommandAuthorization,