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

推荐订阅源

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

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 build: use rastermill 0.3.0 · openclaw/openclaw@cee8c87 refactor: delegate image processing to Rastermill · openclaw/openclaw@50b98a1 fix: keep EXIF normalization best-effort (#86923) · openclaw/openclaw@acb942f build: update rastermill dependency · openclaw/openclaw@e6edcca ci: satisfy opengrep git add guard · openclaw/openclaw@16d06aa ci: normalize Windows toolcache paths · openclaw/openclaw@03ae999 refactor: delegate image limits to Rastermill · openclaw/openclaw@4f728f8 refactor: use unified rastermill encode API · openclaw/openclaw@a3325c9 build: update rastermill pin · openclaw/openclaw@7d4d751 fix: infer realtime smoke dev server type · openclaw/openclaw@4e84229 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(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(commands): keep slash handling off reply startup · openclaw/openclaw@c2b56de fix(reply): defer context compaction safely · openclaw/openclaw@ed3ae0d fix(telegram): refine typing and progress drafts · openclaw/openclaw@0afccc6 fix(codex): gate profiler timing and startup setup · openclaw/openclaw@21c25bb fix(agents): avoid runtime model hydration on hot paths · openclaw/openclaw@7951cc0 fix(reply): reduce visible reply delivery latency · openclaw/openclaw@699c047 docs(changelog): note reply latency fixes · openclaw/openclaw@29a1dc2 fix(e2e): support plain timeout wrappers fix(channels): preserve direct native progress callbacks · openclaw/openclaw@e750041 fix: tighten parser edge cases (#86999) · openclaw/openclaw@174cd49 fix(e2e): clean stale docker lane containers · openclaw/openclaw@3968288 fix(e2e): bound docker lifecycle hangs · openclaw/openclaw@71cb607 fix(gateway): bound live agent model probes fix(e2e): bound plugin binding docker smoke · openclaw/openclaw@b36fa1d fix(e2e): preserve docker run failure status feat(discord): bucket large model picker menus fix(telegram): derive DM topics from bot capability · openclaw/openclaw@aa117ec fix: improve discord voice playback and wake replies fix(e2e): kill timed kitchen rpc command groups · openclaw/openclaw@23aeb58 ci: use supported codex mini live target · openclaw/openclaw@b56ddcc fix(ci): kill wedged bun smoke commands fix(e2e): bound corrupt plugin update runs · openclaw/openclaw@2b63eb2 ci: require codex profiles for live probes · openclaw/openclaw@6930538 docs: clarify inline comment guidance docs: update changelog for landed sweep fixes · openclaw/openclaw@8c575bd fix(agents): disclose scoped session list results (#86944) · openclaw/openclaw@598aad4 fix(telegram): treat ENETDOWN as transient network failure (#86762) · openclaw/openclaw@1fd8de8 fix(mac): harden package script safety · openclaw/openclaw@564e0bb fix(ci): kill wedged checkout fetches · openclaw/openclaw@c867ecb ci: restore codex replay live probe contract · openclaw/openclaw@9fd8158 fix(codex): preserve oversized native thread reuse · openclaw/openclaw@7a14741 fix(scripts): detect timed changed gates · openclaw/openclaw@a5eee8f ci: stop waiting for nonexistent capability restart wake · openclaw/openclaw@3c6fd49 fix(e2e): route plugin update through timeout helper · openclaw/openclaw@e8f584e fix: respect root options in startup guards (#86927) · openclaw/openclaw@7e6837b fix: tighten CLI utility failure handling (#86918) · openclaw/openclaw@0ec2928 fix: preserve config and hook contracts (#86911) fix: tighten small runtime parsing guards (#86909) fix(ci): kill timed tui pty test runs · openclaw/openclaw@081e295 fix(logging): preserve env placeholders during redaction · openclaw/openclaw@6c18c21 fix(memory-core): avoid per-file watcher FD fan-out for memory direct… fix: use current config sdk contract in feishu doctor · openclaw/openclaw@5535eef Validate wide-area DNS zone domains [AI] (#84136) · openclaw/openclaw@84b9704 ci: stabilize release live QA gates · openclaw/openclaw@27359ec ci: harden live release gates · openclaw/openclaw@cf21c8a ci: normalize Windows toolcache Node paths perf: cache read-only channel resolution chore: remove stale codex test conversion · openclaw/openclaw@fdb7848 fix(test): explain missing vitest dependency · openclaw/openclaw@373b3bf fix(e2e): kill timed docker scenario runners · openclaw/openclaw@d5bf325 fix: add transcripts tool display metadata · openclaw/openclaw@645cbf6 docs: update changelog for landed fixes · openclaw/openclaw@12b81d8 fix(agents): route btw through embedded stream resolver (#86312) fix(telegram): treat targeted bot commands as mentions (#86553) · openclaw/openclaw@c7821bd fix(e2e): route doctor switch commands through timeout helper · openclaw/openclaw@9ced76a fix: ignore other codex thread completions · openclaw/openclaw@ead847f fix(feishu): repair stale channel state · openclaw/openclaw@b7c461a fix: remove stale image provider assertions · openclaw/openclaw@0973a7e fix: accept trailing fuzzy voice wake questions · openclaw/openclaw@d001d35 fix(podman): bound setup image builds · openclaw/openclaw@d6fcb56 fix(podman): kill timed container launches · openclaw/openclaw@6118f3f
fix(e2e): bound docker package preparation · openclaw/openclaw@38edae7
vincentkoc · 2026-05-27 · via Recent Commits to openclaw:main

@@ -8,6 +8,48 @@ import path from "node:path";

88

import { fileURLToPath } from "node:url";

991010

const ROOT_DIR = path.resolve(path.dirname(fileURLToPath(import.meta.url)), "..");

11+

const DEFAULT_PACKAGE_BUILD_TIMEOUT_MS = 45 * 60 * 1000;

12+

const DEFAULT_PACKAGE_INVENTORY_TIMEOUT_MS = 5 * 60 * 1000;

13+

const DEFAULT_PACKAGE_PACK_TIMEOUT_MS = 5 * 60 * 1000;

14+

const DEFAULT_PACKAGE_TARBALL_CHECK_TIMEOUT_MS = 5 * 60 * 1000;

15+

const DEFAULT_TIMEOUT_KILL_AFTER_MS = 5_000;

16+

const ACTIVE_CHILD_KILLERS = new Set();

17+

const SIGNAL_EXIT_CODES = {

18+

SIGHUP: 129,

19+

SIGINT: 130,

20+

SIGTERM: 143,

21+

};

22+

let forwardedSignalExitCode;

23+24+

for (const signal of Object.keys(SIGNAL_EXIT_CODES)) {

25+

process.on(signal, () => {

26+

forwardedSignalExitCode ??= SIGNAL_EXIT_CODES[signal];

27+

if (ACTIVE_CHILD_KILLERS.size === 0) {

28+

process.exit(forwardedSignalExitCode);

29+

}

30+

for (const killChild of ACTIVE_CHILD_KILLERS) {

31+

killChild(signal);

32+

}

33+

setTimeout(() => {

34+

for (const killChild of ACTIVE_CHILD_KILLERS) {

35+

killChild("SIGKILL");

36+

}

37+

process.exit(forwardedSignalExitCode);

38+

}, DEFAULT_TIMEOUT_KILL_AFTER_MS);

39+

});

40+

}

41+42+

function resolveTimeoutMs(envName, defaultValue) {

43+

const raw = process.env[envName];

44+

if (raw === undefined || raw === "") {

45+

return defaultValue;

46+

}

47+

const parsed = Number(raw);

48+

if (!Number.isFinite(parsed) || parsed <= 0) {

49+

throw new Error(`${envName} must be a positive timeout in milliseconds`);

50+

}

51+

return Math.trunc(parsed);

52+

}

11531254

function parseArgs(argv) {

1355

const options = {

@@ -41,37 +83,78 @@ function parseArgs(argv) {

41834284

function run(command, args, cwd, options = {}) {

4385

return new Promise((resolve, reject) => {

86+

const useProcessGroup = process.platform !== "win32";

4487

const child = spawn(command, args, {

4588

cwd,

4689

stdio: ["ignore", "pipe", "pipe"],

4790

env: options.env ?? process.env,

91+

detached: useProcessGroup,

4892

});

4993

let timedOut = false;

50-

const timeout =

94+

let stdout = "";

95+

let settled = false;

96+

let timeout;

97+

const finish = (error, value = "") => {

98+

if (settled) {

99+

return;

100+

}

101+

settled = true;

102+

if (timeout) {

103+

clearTimeout(timeout);

104+

}

105+

ACTIVE_CHILD_KILLERS.delete(killChild);

106+

if (forwardedSignalExitCode !== undefined && ACTIVE_CHILD_KILLERS.size === 0) {

107+

process.exit(forwardedSignalExitCode);

108+

}

109+

if (error) {

110+

reject(error);

111+

return;

112+

}

113+

resolve(value);

114+

};

115+

const killChild = (signal) => {

116+

if (useProcessGroup && child.pid) {

117+

try {

118+

process.kill(-child.pid, signal);

119+

return;

120+

} catch {

121+

// The direct child may already have exited; fall back to child.kill.

122+

}

123+

}

124+

child.kill(signal);

125+

};

126+

ACTIVE_CHILD_KILLERS.add(killChild);

127+

timeout =

51128

options.timeoutMs === undefined

52129

? undefined

53130

: setTimeout(() => {

54131

timedOut = true;

55-

child.kill("SIGTERM");

56-

setTimeout(() => child.kill("SIGKILL"), 5_000).unref?.();

132+

killChild("SIGTERM");

133+

setTimeout(

134+

() => killChild("SIGKILL"),

135+

options.killAfterMs ?? DEFAULT_TIMEOUT_KILL_AFTER_MS,

136+

).unref?.();

57137

}, options.timeoutMs);

58138

timeout?.unref?.();

59-

child.stdout.pipe(process.stderr, { end: false });

139+

if (options.captureStdout) {

140+

child.stdout.on("data", (chunk) => {

141+

stdout += String(chunk);

142+

});

143+

} else {

144+

child.stdout.pipe(process.stderr, { end: false });

145+

}

60146

child.stderr.pipe(process.stderr, { end: false });

61-

child.on("error", reject);

147+

child.on("error", (error) => finish(error));

62148

child.on("close", (status, signal) => {

63-

if (timeout) {

64-

clearTimeout(timeout);

65-

}

66149

if (timedOut) {

67-

reject(new Error(`${command} ${args.join(" ")} timed out after ${options.timeoutMs}ms`));

150+

finish(new Error(`${command} ${args.join(" ")} timed out after ${options.timeoutMs}ms`));

68151

return;

69152

}

70153

if (status === 0) {

71-

resolve();

154+

finish(undefined, stdout);

72155

return;

73156

}

74-

reject(new Error(`${command} ${args.join(" ")} failed with ${status ?? signal}`));

157+

finish(new Error(`${command} ${args.join(" ")} failed with ${status ?? signal}`));

75158

});

76159

});

77160

}

@@ -90,30 +173,18 @@ export async function buildPackageArtifacts(sourceDir, options = {}) {

90173

console.error(`==> ${step.label}`);

91174

await runImpl(step.command, step.args, sourceDir, {

92175

env: { ...process.env, OPENCLAW_BUILD_ALL_NO_PNPM: "1" },

176+

timeoutMs: resolveTimeoutMs(

177+

"OPENCLAW_DOCKER_PACKAGE_BUILD_TIMEOUT_MS",

178+

DEFAULT_PACKAGE_BUILD_TIMEOUT_MS,

179+

),

93180

});

94181

}

95182

}

9618397-

async function runCapture(command, args, cwd) {

98-

return await new Promise((resolve, reject) => {

99-

const child = spawn(command, args, {

100-

cwd,

101-

stdio: ["ignore", "pipe", "pipe"],

102-

});

103-

let stdout = "";

104-

child.stdout.on("data", (chunk) => {

105-

stdout += String(chunk);

106-

});

107-

child.stderr.pipe(process.stderr, { end: false });

108-

child.on("error", reject);

109-

child.on("close", (status, signal) => {

110-

if (status === 0) {

111-

resolve(stdout);

112-

return;

113-

}

114-

reject(new Error(`${command} ${args.join(" ")} failed with ${status ?? signal}`));

115-

});

116-

});

184+

export const runCommandForTest = run;

185+186+

async function runCapture(command, args, cwd, options = {}) {

187+

return await run(command, args, cwd, { ...options, captureStdout: true });

117188

}

118189119190

async function newestOpenClawTarball(outputDir, packOutput) {

@@ -163,13 +234,25 @@ async function main() {

163234

"const { writePackageDistInventory } = await import('./src/infra/package-dist-inventory.ts'); await writePackageDistInventory(process.cwd());",

164235

],

165236

sourceDir,

237+

{

238+

timeoutMs: resolveTimeoutMs(

239+

"OPENCLAW_DOCKER_PACKAGE_INVENTORY_TIMEOUT_MS",

240+

DEFAULT_PACKAGE_INVENTORY_TIMEOUT_MS,

241+

),

242+

},

166243

);

167244168245

console.error("==> Packing OpenClaw package");

169246

const packOutput = await runCapture(

170247

"npm",

171248

["pack", "--silent", "--ignore-scripts", "--pack-destination", outputDir],

172249

sourceDir,

250+

{

251+

timeoutMs: resolveTimeoutMs(

252+

"OPENCLAW_DOCKER_PACKAGE_PACK_TIMEOUT_MS",

253+

DEFAULT_PACKAGE_PACK_TIMEOUT_MS,

254+

),

255+

},

173256

);

174257

let tarball = await newestOpenClawTarball(outputDir, packOutput);

175258

@@ -188,7 +271,12 @@ async function main() {

188271

"node",

189272

[path.join(ROOT_DIR, "scripts/check-openclaw-package-tarball.mjs"), tarball],

190273

sourceDir,

191-

{ timeoutMs: 5 * 60 * 1000 },

274+

{

275+

timeoutMs: resolveTimeoutMs(

276+

"OPENCLAW_DOCKER_PACKAGE_TARBALL_CHECK_TIMEOUT_MS",

277+

DEFAULT_PACKAGE_TARBALL_CHECK_TIMEOUT_MS,

278+

),

279+

},

192280

);

193281

console.error(

194282

`==> OpenClaw package tarball check finished in ${Math.round((Date.now() - checkStartedAt) / 1000)}s`,