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

推荐订阅源

博客园 - 司徒正美
aimingoo的专栏
aimingoo的专栏
MongoDB | Blog
MongoDB | Blog
云风的 BLOG
云风的 BLOG
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
酷 壳 – CoolShell
酷 壳 – CoolShell
博客园 - 聂微东
Y
Y Combinator Blog
T
Tailwind CSS Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
S
SegmentFault 最新的问题
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 【当耐特】
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
J
Java Code Geeks
美团技术团队
Google DeepMind News
Google DeepMind News
博客园_首页
Apple Machine Learning Research
Apple Machine Learning Research
T
The Blog of Author Tim Ferriss

Recent Commits to openclaw:main

fix(docker): seed offline prune store in runtime stage · openclaw/openclaw@faf2a6c fix(ci): stabilize npm shrinkwrap metadata · openclaw/openclaw@21bedd3 test(installer): track portable node root helper · openclaw/openclaw@9364b21 fix(ui): sync talk transcript translations fix(ui): localize talk transcript labels · openclaw/openclaw@8fc48af fix(release): stabilize config restart QA · openclaw/openclaw@cc91ff0 fix(installer): extract portable Node directly test(qa-lab): report scenario pack coverage · openclaw/openclaw@dcd98bf fix(plugins): drop stale tlon tool contract · openclaw/openclaw@d70dc4b fix(installer): prefer tar for portable Node extraction · openclaw/openclaw@a54a881 fix(codex): deliver native subagent completions feat: add context-engine host capability requirements (#84994) · openclaw/openclaw@cff5244 fix(release): keep shrinkwrap pinned to pnpm lock · openclaw/openclaw@9d24fde fix: surface plan updates as status notices · openclaw/openclaw@dc04503 test(google): narrow web search fake timers · openclaw/openclaw@fe7d13c fix(installer): extract portable Node with ZipFile · openclaw/openclaw@ffa6cd8 fix(gateway): defer provider auth prewarm after startup (#85369) · openclaw/openclaw@69255f8 fix(talk): stabilize realtime voice consults · openclaw/openclaw@683ad75 test(qa): tolerate slow gateway rpc startup · openclaw/openclaw@29118a0 chore(diagnostics): refresh plugin sdk baseline · openclaw/openclaw@ab684f5 fix(diagnostics): surface async queue drops fix(diagnostics): bound diagnostic buffers · openclaw/openclaw@bdcaac0 fix(installer): copy portable Node into place · openclaw/openclaw@c21ca88 fix(cli): recover replaced device approvals (#85342) · openclaw/openclaw@6ea907c test(release): align prerelease validation · openclaw/openclaw@0def3e2 fix(installer): install portable Node directory atomically · openclaw/openclaw@2890b1a fix(runtime-llm): avoid duplicate provider prefix in allowlist diagno… · openclaw/openclaw@937a756 fix(gateway): include openclaw bin in service PATH (#84475) · openclaw/openclaw@66d1d13 fix(gateway): handle concurrent launchd bootstrap restart race (#84722) · openclaw/openclaw@ba86716 feat: support pi and opencode autoreview engines · openclaw/openclaw@31a189d ci(package): gate acceptance on package integrity · openclaw/openclaw@5275929 ci(release): bypass pnpm for tsdown package build · openclaw/openclaw@fea89cd test(release): align prerelease validation baselines · openclaw/openclaw@04ebdc6 ci(release): harden docker package build · openclaw/openclaw@7b1fbe1 fix(codex): skip native web search transcript mirroring (#85346) · openclaw/openclaw@c3531fc fix(gateway): harden launchd reload handoff race recovery (#84641) · openclaw/openclaw@fc7a531 fix: honor per-model provider transport overrides (#80488) fix(skills): type watcher mock calls in dedupe regression tests · openclaw/openclaw@bb73f0a fix(skills): dedupe shared-directory watchers across agent workspaces… · openclaw/openclaw@3e94290 fix(skills): document watcher edge cases, add teardown/rebuild tests,… · openclaw/openclaw@19ff77e fix(infra): allow macos browser open over ssh env (#85340) · openclaw/openclaw@47d66fe fix(update): preserve package service state during cutover (#83026) · openclaw/openclaw@a15797a fix(gateway): broadcast agent-run error payloads (#85355) · openclaw/openclaw@07e61fc test(e2e): avoid synthetic channel config in plugin smoke fix(cli): suppress systemd hints for live gateway (#85336) · openclaw/openclaw@a00c583 fix(cli): honor agent for model auth logout (#85326) · openclaw/openclaw@fc47c1f fix(gateway): eager-load lifecycle runtime to survive in-place upgrad… · openclaw/openclaw@4a91385 fix(doctor): point codex asset warning at migrate plan (#85324) fix(update): harden managed handoff cwd (#83875) · openclaw/openclaw@1bafc23 docs(release): prepare 2026.5.21 notes ci(crabbox): harden docker hydration refactor(crabbox): parse provider list from binary help instead of ha… test(plugins): keep rpc source walk on source call gateway test(plugins): add kitchen sink rpc docker lane · openclaw/openclaw@6f6da5f test(plugins): run kitchen sink rpc lane without tsx test(qa-lab): add bus tool trace scenario · openclaw/openclaw@2b39613 fix(cron): classify network retry errors (#85344) fix(installer): bootstrap portable Windows Node · openclaw/openclaw@3551e98 fix(ui): move chat session search into picker (#85303) · openclaw/openclaw@1fdc73a fix: honor shrinkwrap when bundling plugin deps fix: opt codex out of bundled runtime deps · openclaw/openclaw@fcecbd8 fix: include plugin shrinkwraps in dependency reports · openclaw/openclaw@82f69a2 fix: make bundled plugin packages portable test: update shrinkwrap packaging expectations · openclaw/openclaw@a1b05aa fix: publish explicit plugin bundled dependencies · openclaw/openclaw@976da39 chore: refresh shrinkwrap for Testbox npm · openclaw/openclaw@b2dc449 fix: cover plugin package locks in dependency review · openclaw/openclaw@bfa5b39 fix: opt acpx out of bundled runtime deps · openclaw/openclaw@9914e25 chore: refresh shrinkwrap metadata chore: harden npm shrinkwrap release path fix: keep bundled plugin peers nested · openclaw/openclaw@86faf65 chore: add shrinkwrap to plugin npm packages · openclaw/openclaw@b6c8807 feat: bundle plugin npm dependencies · openclaw/openclaw@de022bb fix: honor overrides in npm shrinkwrap generation · openclaw/openclaw@0d28040 test: refresh shrinkwrap after rebase · openclaw/openclaw@8b0537c fix: limit subagent bootstrap defaults · openclaw/openclaw@56308a7 feat: update autoreview engine coverage · openclaw/openclaw@ab1fedb fix(messages): strip unsupported citation markers (#85204) (thanks @n… · openclaw/openclaw@0a95e53 test(qa-lab): report live transport coverage lanes · openclaw/openclaw@fda0baf fix(gateway): close child ACP sessions on parent reset/delete · openclaw/openclaw@136c927 fix: preserve Google Gemini 3 cron thinking (#85300) docs(skills): exclude SDK boundary bug sweeps · openclaw/openclaw@85e468d feat(plugin-sdk): add generic channel poll sender (#85299) · openclaw/openclaw@c9a0f03 fix(agents): preserve OpenAI reasoning token usage · openclaw/openclaw@0ddf51c test(e2e): harden plugin smoke cleanup fix(plugins): resolve native plugin sdk aliases (#85298) · openclaw/openclaw@6b1c868 fix(update): keep service logs out of json output · openclaw/openclaw@03f61cd fix(agent): retry transient gateway handshake closes · openclaw/openclaw@ff79299 fix(codex): keep interrupted turns visible-answer eligible (#84494) · openclaw/openclaw@8523e09 test(agents): narrow bundle mcp e2e setup · openclaw/openclaw@6bd430e test: add mocked Control UI E2E tests and playwright for local verifi… fix: land code-mode structured worker errors (#83444) (thanks @Kaspre) · openclaw/openclaw@70dd315 fix(code-mode): return structured worker error codes · openclaw/openclaw@edab653 fix: preserve route-bound direct thread events · openclaw/openclaw@0d8c9ca fix: route direct thread event wakes to main DMs · openclaw/openclaw@0acfb7b test: align exec event routing proof (#83743) (thanks @Kaspre) · openclaw/openclaw@7b48956 fix: break plugin metadata snapshot cycle · openclaw/openclaw@4ee8a2a fix heartbeat event routing for main-scoped DMs test node exec event wake metadata · openclaw/openclaw@37207c6 test(plugins): retry bundled smoke health probes
fix(codex): route node exec through OpenClaw tools · openclaw/openclaw@5cc0dbc
vincentkoc · 2026-05-22 · via Recent Commits to openclaw:main

@@ -48,7 +48,11 @@ import {

4848

type NativeHookRelayEvent,

4949

type NativeHookRelayRegistrationHandle,

5050

} from "openclaw/plugin-sdk/agent-harness-runtime";

51-

import { markAuthProfileBlockedUntil, resolveAgentDir } from "openclaw/plugin-sdk/agent-runtime";

51+

import {

52+

markAuthProfileBlockedUntil,

53+

resolveAgentConfig,

54+

resolveAgentDir,

55+

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

5256

import {

5357

emitTrustedDiagnosticEvent,

5458

hasPendingInternalDiagnosticEvent,

@@ -956,6 +960,7 @@ export async function runCodexAppServerAttempt(

956960

});

957961

const sandboxExecServerEnabled = isCodexSandboxExecServerEnabled(pluginConfig);

958962

const nativeToolSurfaceEnabled = shouldEnableCodexAppServerNativeToolSurface(params, sandbox, {

963+

agentId: sessionAgentId,

959964

sandboxExecServerEnabled,

960965

});

961966

for (const diagnostic of bundleMcpThreadConfig.diagnostics) {

@@ -3666,10 +3671,14 @@ async function buildDynamicTools(input: DynamicToolBuildParams) {

36663671

input.runAbortController.abort("sessions_yield");

36673672

},

36683673

});

3669-

const codexFilteredTools = addSandboxShellDynamicToolsIfAvailable(

3670-

isCodexMemoryFlushRun(params)

3671-

? filterCodexMemoryFlushDynamicTools(allTools)

3672-

: filterCodexDynamicTools(allTools, input.pluginConfig),

3674+

const codexFilteredTools = addNodeShellDynamicToolsIfNeeded(

3675+

addSandboxShellDynamicToolsIfAvailable(

3676+

isCodexMemoryFlushRun(params)

3677+

? filterCodexMemoryFlushDynamicTools(allTools)

3678+

: filterCodexDynamicTools(allTools, input.pluginConfig),

3679+

allTools,

3680+

input,

3681+

),

36733682

allTools,

36743683

input,

36753684

);

@@ -3713,11 +3722,14 @@ function includeForcedMessageToolAllow(

37133722

function shouldEnableCodexAppServerNativeToolSurface(

37143723

params: EmbeddedRunAttemptParams,

37153724

sandbox?: OpenClawSandboxContext,

3716-

options: { sandboxExecServerEnabled?: boolean } = {},

3725+

options: { agentId?: string; sandboxExecServerEnabled?: boolean } = {},

37173726

): boolean {

37183727

if (isCodexMemoryFlushRun(params)) {

37193728

return false;

37203729

}

3730+

if (isEffectiveExecHostNode(params, options.agentId)) {

3731+

return false;

3732+

}

37213733

const toolsAllow = includeForcedMessageToolAllow(params.toolsAllow, params);

37223734

if (toolsAllow === undefined) {

37233735

return canCodexAppServerNativeToolSurfaceHonorSandbox(sandbox, options);

@@ -3731,6 +3743,14 @@ function shouldEnableCodexAppServerNativeToolSurface(

37313743

);

37323744

}

373337453746+

function isEffectiveExecHostNode(params: EmbeddedRunAttemptParams, agentId?: string): boolean {

3747+

const agentExec =

3748+

params.config && agentId ? resolveAgentConfig(params.config, agentId)?.tools?.exec : undefined;

3749+

return (

3750+

(params.execOverrides?.host ?? agentExec?.host ?? params.config?.tools?.exec?.host) === "node"

3751+

);

3752+

}

3753+37343754

function canCodexAppServerNativeToolSurfaceHonorSandbox(

37353755

sandbox: OpenClawSandboxContext | undefined,

37363756

options: { sandboxExecServerEnabled?: boolean } = {},

@@ -3882,22 +3902,58 @@ function shouldExposeSandboxExecDynamicTool(input: DynamicToolBuildParams): bool

38823902

if (isCodexMemoryFlushRun(input.params)) {

38833903

return false;

38843904

}

3905+

if (isEffectiveExecHostNode(input.params, input.sessionAgentId)) {

3906+

return false;

3907+

}

38853908

const backendId = input.sandbox?.enabled ? input.sandbox.backendId.trim().toLowerCase() : "";

38863909

return Boolean(backendId && input.nativeToolSurfaceEnabled === false);

38873910

}

388839113889-

function isSandboxShellDynamicToolExcluded(config: CodexPluginConfig): boolean {

3912+

function isCodexDynamicToolExcluded(config: CodexPluginConfig, names: string[]): boolean {

3913+

const normalizedNames = new Set(names.map((name) => normalizeCodexDynamicToolName(name)));

38903914

return (config.codexDynamicToolsExclude ?? []).some((name) => {

38913915

const normalized = normalizeCodexDynamicToolName(name);

3892-

return (

3893-

normalized === "exec" ||

3894-

normalized === "sandbox_exec" ||

3895-

normalized === "process" ||

3896-

normalized === "sandbox_process"

3897-

);

3916+

return normalizedNames.has(normalized);

38983917

});

38993918

}

390039193920+

function isSandboxShellDynamicToolExcluded(config: CodexPluginConfig): boolean {

3921+

return isCodexDynamicToolExcluded(config, ["exec", "sandbox_exec", "process", "sandbox_process"]);

3922+

}

3923+3924+

function addNodeShellDynamicToolsIfNeeded(

3925+

filteredTools: OpenClawDynamicTool[],

3926+

allTools: OpenClawDynamicTool[],

3927+

input: DynamicToolBuildParams,

3928+

): OpenClawDynamicTool[] {

3929+

if (

3930+

isCodexMemoryFlushRun(input.params) ||

3931+

!isEffectiveExecHostNode(input.params, input.sessionAgentId)

3932+

) {

3933+

return filteredTools;

3934+

}

3935+

let next = filteredTools;

3936+

for (const toolName of ["exec", "process"]) {

3937+

if (isCodexDynamicToolExcluded(input.pluginConfig, [toolName])) {

3938+

continue;

3939+

}

3940+

if (next.some((tool) => normalizeCodexDynamicToolName(tool.name) === toolName)) {

3941+

continue;

3942+

}

3943+

const tool = allTools.find(

3944+

(candidate) => normalizeCodexDynamicToolName(candidate.name) === toolName,

3945+

);

3946+

if (!tool) {

3947+

continue;

3948+

}

3949+

if (next === filteredTools) {

3950+

next = [...filteredTools];

3951+

}

3952+

next.push(tool);

3953+

}

3954+

return next;

3955+

}

3956+39013957

function filterCodexDynamicToolsForAllowlist<T extends { name: string }>(

39023958

tools: T[],

39033959

toolsAllow?: string[],