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

推荐订阅源

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(auto-reply): suppress repeated silent tokens (#86848) · openclaw/openclaw@8ec2b2d 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 test: fix bundled install mock typing · openclaw/openclaw@669bfdd docs: explain bundled plugin npm override · openclaw/openclaw@40fa750 fix: keep bundled OpenClaw plugins image-owned · openclaw/openclaw@771675e 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(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(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
fix(crabbox): scope env-wrapped macOS bootstrap · openclaw/openclaw@2f7bfdb
vincentkoc · 2026-05-27 · via Recent Commits to openclaw:main

@@ -531,12 +531,6 @@ function runCommandArgs(commandArgs) {

531531532532

function normalizedCommandWords(commandArgs) {

533533

const words = commandArgs.length === 1 ? commandArgs[0].split(/\s+/u) : [...commandArgs];

534-

while (words[0] === "env") {

535-

words.shift();

536-

while (/^[A-Za-z_][A-Za-z0-9_]*=/.test(words[0] ?? "")) {

537-

words.shift();

538-

}

539-

}

540534

while (/^[A-Za-z_][A-Za-z0-9_]*=/.test(words[0] ?? "")) {

541535

words.shift();

542536

}

@@ -708,6 +702,12 @@ function stripShellExecutionPrefixes(words) {

708702

}

709703

continue;

710704

}

705+

if (first === "env") {

706+

if (!stripEnvCommandOptions(words, { canShimIgnoreEnvironment: false })) {

707+

return words;

708+

}

709+

continue;

710+

}

711711

if (first === "time") {

712712

words.shift();

713713

stripTimeOptions(words);

@@ -721,6 +721,91 @@ function stripShellExecutionPrefixes(words) {

721721

}

722722

}

723723724+

function stripEnvCommandOptions(words, { canShimIgnoreEnvironment = true } = {}) {

725+

const originalWords = [...words];

726+

const envCommand = words.shift() ?? "";

727+

let ignoresEnvironment = false;

728+

for (;;) {

729+

const word = words[0] ?? "";

730+

if (!word) {

731+

words.splice(0, words.length, ...originalWords);

732+

return false;

733+

}

734+

if (word === "--") {

735+

words.shift();

736+

return true;

737+

}

738+

if (/^[A-Za-z_][A-Za-z0-9_]*=/.test(word)) {

739+

words.shift();

740+

continue;

741+

}

742+

if (word === "-S" || word === "--split-string") {

743+

if (ignoresEnvironment) {

744+

words.splice(0, words.length, ...originalWords);

745+

return false;

746+

}

747+

words.shift();

748+

const split = splitShellWords(words.shift() ?? "");

749+

words.unshift(...split);

750+

return words.length > 0;

751+

}

752+

if (word.startsWith("-S") && word !== "-S") {

753+

if (ignoresEnvironment) {

754+

words.splice(0, words.length, ...originalWords);

755+

return false;

756+

}

757+

words.shift();

758+

words.unshift(...splitShellWords(word.slice(2)));

759+

return words.length > 0;

760+

}

761+

if (word.startsWith("--split-string=")) {

762+

if (ignoresEnvironment) {

763+

words.splice(0, words.length, ...originalWords);

764+

return false;

765+

}

766+

words.shift();

767+

words.unshift(...splitShellWords(word.slice("--split-string=".length)));

768+

return words.length > 0;

769+

}

770+

if (word === "-i" || word === "--ignore-environment") {

771+

if (!canShimIgnoreEnvironment || envCommand.includes("/")) {

772+

words.splice(0, words.length, ...originalWords);

773+

return false;

774+

}

775+

ignoresEnvironment = true;

776+

words.shift();

777+

continue;

778+

}

779+

if (word === "-u" || word === "--unset" || word === "-C" || word === "--chdir") {

780+

words.shift();

781+

if (words[0]) {

782+

words.shift();

783+

}

784+

continue;

785+

}

786+

if (word.startsWith("--unset=") || word.startsWith("--chdir=")) {

787+

words.shift();

788+

continue;

789+

}

790+

if (word.startsWith("-") && word !== "-") {

791+

if (word.includes("i")) {

792+

if (!canShimIgnoreEnvironment || envCommand.includes("/")) {

793+

words.splice(0, words.length, ...originalWords);

794+

return false;

795+

}

796+

ignoresEnvironment = true;

797+

}

798+

words.shift();

799+

continue;

800+

}

801+

if (ignoresEnvironment && (!canShimIgnoreEnvironment || envCommand.includes("/"))) {

802+

words.splice(0, words.length, ...originalWords);

803+

return false;

804+

}

805+

return true;

806+

}

807+

}

808+724809

function shellWordBasename(word) {

725810

return (word ?? "").split("/").pop() ?? "";

726811

}

@@ -1249,7 +1334,27 @@ function remoteAwsMacosJsBootstrap({ packageManager = false } = {}) {

12491334

'tar -xzf "$tmp_dir/$pkg" -C "$tool_root" || { status=$?; rm -rf "$tmp_dir"; return "$status"; };',

12501335

'rm -rf "$tmp_dir";',

12511336

"fi;",

1252-

"node --version >&2;",

1337+

"node --version >&2 || return 1;",

1338+

"openclaw_crabbox_env() {",

1339+

"openclaw_env_args=();",

1340+

"openclaw_env_ignore=0;",

1341+

"openclaw_env_path_seen=0;",

1342+

'while [ "$#" -gt 0 ]; do',

1343+

'case "$1" in',

1344+

'-i|--ignore-environment) openclaw_env_ignore=1; openclaw_env_args+=("$1"); shift ;;',

1345+

'-S|--split-string|-S*|--split-string=*) command env "${openclaw_env_args[@]}" "$@"; return ;;',

1346+

'-[!-]*i*) openclaw_env_ignore=1; openclaw_env_args+=("$1"); shift ;;',

1347+

'-u|--unset|-C|--chdir) openclaw_env_args+=("$1"); shift; if [ "$#" -gt 0 ]; then openclaw_env_args+=("$1"); shift; fi ;;',

1348+

'--unset=*|--chdir=*) openclaw_env_args+=("$1"); shift ;;',

1349+

'PATH=*) if [ "$openclaw_env_ignore" = "1" ]; then openclaw_env_args+=("PATH=$PATH:${1#PATH=}"); else openclaw_env_args+=("$1"); fi; openclaw_env_path_seen=1; shift ;;',

1350+

'[A-Za-z_]*=*) openclaw_env_args+=("$1"); shift ;;',

1351+

'--) openclaw_env_args+=("--"); shift; break ;;',

1352+

"*) break ;;",

1353+

"esac;",

1354+

"done;",

1355+

'if [ "$openclaw_env_ignore" = "1" ] && [ "$openclaw_env_path_seen" = "0" ]; then openclaw_env_args+=("PATH=$PATH"); fi;',

1356+

'command env "${openclaw_env_args[@]}" "$@";',

1357+

"};",

12531358

];

12541359

if (packageManager) {

12551360

bootstrap.push(

@@ -1265,9 +1370,34 @@ function remoteAwsMacosJsBootstrap({ packageManager = false } = {}) {

12651370

return bootstrap.join(" ");

12661371

}

126713721373+

function scopedAwsMacosEnvCommand(commandArgs) {

1374+

if (commandArgs.length <= 1 || shellWordBasename(commandArgs[0]) !== "env" || commandArgs[0].includes("/")) {

1375+

return null;

1376+

}

1377+1378+

const targetWords = [...commandArgs];

1379+

if (!stripEnvCommandOptions(targetWords, { canShimIgnoreEnvironment: true })) {

1380+

return null;

1381+

}

1382+1383+

const targetEntrypoint = shellWordBasename(targetWords[0]);

1384+

if (!jsRuntimeEntrypoints.has(targetEntrypoint) && !awsMacosCorepackEntrypoints.has(targetEntrypoint)) {

1385+

return null;

1386+

}

1387+1388+

return {

1389+

runtimeEntrypoint: targetEntrypoint,

1390+

packageManager: awsMacosCorepackEntrypoints.has(targetEntrypoint),

1391+

shellCommand: `openclaw_crabbox_env ${shellJoin(commandArgs.slice(1))}`,

1392+

};

1393+

}

1394+12681395

function injectRemoteAwsMacosJsBootstrap(commandArgs, providerName) {

12691396

const runArgs = runCommandArgs(commandArgs);

1270-

const runtimeEntrypoint = commandRuntimeEntrypoint(runArgs);

1397+

const directScopedEnvCommand = hasOption(commandArgs, "--shell")

1398+

? null

1399+

: scopedAwsMacosEnvCommand(runArgs);

1400+

const runtimeEntrypoint = directScopedEnvCommand?.runtimeEntrypoint || commandRuntimeEntrypoint(runArgs);

12711401

if (!isAwsMacosRemoteTarget(commandArgs, providerName) || !runtimeEntrypoint) {

12721402

return commandArgs;

12731403

}

@@ -1280,11 +1410,12 @@ function injectRemoteAwsMacosJsBootstrap(commandArgs, providerName) {

12801410

const normalizedArgs = [...commandArgs];

12811411

const remoteCommand = normalizedArgs.slice(start);

12821412

const originalShellCommand =

1283-

hasOption(normalizedArgs, "--shell") && remoteCommand.length === 1

1413+

directScopedEnvCommand?.shellCommand ??

1414+

(hasOption(normalizedArgs, "--shell") && remoteCommand.length === 1

12841415

? remoteCommand[0]

1285-

: shellJoin(remoteCommand);

1416+

: shellJoin(remoteCommand));

12861417

const shellCommand = `${remoteAwsMacosJsBootstrap({

1287-

packageManager: commandNeedsAwsMacosPackageManager(runArgs),

1418+

packageManager: directScopedEnvCommand?.packageManager || commandNeedsAwsMacosPackageManager(runArgs),

12881419

})} && { ${originalShellCommand}\n}`;

1289142012901421

if (!hasOption(normalizedArgs, "--shell")) {