慣性聚合 高效追讀感興趣之博客、新聞、科技資訊
閱原文 以慣性聚合開啟

推薦訂閱源

博客园 - 司徒正美
V
V2EX
T
Tailwind CSS Blog
有赞技术团队
有赞技术团队
aimingoo的专栏
aimingoo的专栏
Apple Machine Learning Research
Apple Machine Learning Research
IT之家
IT之家
Blog — PlanetScale
Blog — PlanetScale
A
About on SuperTechFans
月光博客
月光博客
T
The Blog of Author Tim Ferriss
宝玉的分享
宝玉的分享
Martin Fowler
Martin Fowler
博客园 - 聂微东
The GitHub Blog
The GitHub Blog
V
Visual Studio Blog
WordPress大学
WordPress大学
酷 壳 – CoolShell
酷 壳 – CoolShell
Engineering at Meta
Engineering at Meta
GbyAI
GbyAI

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
修:播源应答终局于聊程 · 开爪/开爪@84ac31b
shakkernerd · 2026-05-24 · via Recent Commits to openclaw:main

@@ -15,7 +15,7 @@ import { resolveProviderIdForAuth } from "../../agents/provider-auth-aliases.js"

1515

import { ensureSandboxWorkspaceForSession } from "../../agents/sandbox/context.js";

1616

import { resolveAgentTimeoutMs } from "../../agents/timeout.js";

1717

import { dispatchInboundMessage } from "../../auto-reply/dispatch.js";

18-

import type { ReplyPayload } from "../../auto-reply/reply-payload.js";

18+

import { getReplyPayloadMetadata, type ReplyPayload } from "../../auto-reply/reply-payload.js";

1919

import { createReplyDispatcher } from "../../auto-reply/reply/reply-dispatcher.js";

2020

import { stageSandboxMedia } from "../../auto-reply/reply/stage-sandbox-media.js";

2121

import type { MsgContext, TemplateContext } from "../../auto-reply/templating.js";

@@ -1974,6 +1974,10 @@ function broadcastChatError(params: {

19741974

params.context.agentRunSeq.delete(params.runId);

19751975

}

197619761977+

function isSourceReplyTranscriptMirrorPayload(payload: ReplyPayload | undefined) {

1978+

return Boolean(payload && getReplyPayloadMetadata(payload)?.sourceReplyTranscriptMirror);

1979+

}

1980+19771981

export const chatHandlers: GatewayRequestHandlers = {

19781982

"chat.history": async ({ params, respond, context }) => {

19791983

if (!validateChatHistoryParams(params)) {

@@ -3067,7 +3071,90 @@ export const chatHandlers: GatewayRequestHandlers = {

30673071

message,

30683072

});

30693073

}

3070-

} else if (returnedAgentErrorPayloads.length > 0) {

3074+

} else {

3075+

const sourceReplyPayloads = deliveredReplies

3076+

.filter((entry) => entry.kind === "final")

3077+

.map((entry) => entry.payload)

3078+

.filter(isSourceReplyTranscriptMirrorPayload);

3079+

if (sourceReplyPayloads.length > 0) {

3080+

const finalPayloads = await normalizeWebchatReplyMediaPathsForDisplay({

3081+

cfg,

3082+

sessionKey,

3083+

agentId,

3084+

accountId,

3085+

payloads: sourceReplyPayloads,

3086+

});

3087+

const { storePath: latestStorePath, entry: latestEntry } =

3088+

loadSessionEntry(sessionKey);

3089+

const sessionId = latestEntry?.sessionId ?? backingSessionId ?? clientRunId;

3090+

const resolvedTranscriptPath = resolveTranscriptPath({

3091+

sessionId,

3092+

storePath: latestStorePath,

3093+

sessionFile: latestEntry?.sessionFile ?? entry?.sessionFile,

3094+

agentId,

3095+

});

3096+

const mediaLocalRoots = appendLocalMediaParentRoots(

3097+

getAgentScopedMediaLocalRoots(cfg, agentId),

3098+

resolvedTranscriptPath ? [resolvedTranscriptPath] : undefined,

3099+

);

3100+

const assistantContent = await buildAssistantDisplayContentFromReplyPayloads({

3101+

sessionKey,

3102+

payloads: finalPayloads,

3103+

managedImageLocalRoots: mediaLocalRoots,

3104+

includeSensitiveMedia: false,

3105+

onLocalAudioAccessDenied: (message) => {

3106+

context.logGateway.warn(

3107+

`webchat audio embedding denied local path: ${message}`,

3108+

);

3109+

},

3110+

onManagedImagePrepareError: (message) => {

3111+

context.logGateway.warn(

3112+

`webchat image embedding skipped attachment: ${message}`,

3113+

);

3114+

},

3115+

});

3116+

const mediaMessage = await buildWebchatAssistantMediaMessage(finalPayloads, {

3117+

localRoots: mediaLocalRoots,

3118+

onLocalAudioAccessDenied: (message) => {

3119+

context.logGateway.warn(

3120+

`webchat audio embedding denied local path: ${message}`,

3121+

);

3122+

},

3123+

});

3124+

const broadcastAssistantContent = hasAssistantDisplayMediaContent(

3125+

assistantContent,

3126+

)

3127+

? assistantContent

3128+

: hasAssistantDisplayMediaContent(mediaMessage?.content)

3129+

? mediaMessage?.content

3130+

: assistantContent;

3131+

const displayReply =

3132+

extractAssistantDisplayTextFromContent(assistantContent) ??

3133+

buildTranscriptReplyText(finalPayloads);

3134+

if (broadcastAssistantContent?.length || displayReply) {

3135+

const now = Date.now();

3136+

const message = {

3137+

role: "assistant",

3138+

...(broadcastAssistantContent?.length

3139+

? { content: broadcastAssistantContent }

3140+

: displayReply

3141+

? { content: [{ type: "text", text: displayReply }] }

3142+

: {}),

3143+

...(displayReply ? { text: displayReply } : {}),

3144+

timestamp: now,

3145+

stopReason: "stop",

3146+

usage: { input: 0, output: 0, totalTokens: 0 },

3147+

};

3148+

broadcastChatFinal({

3149+

context,

3150+

runId: clientRunId,

3151+

sessionKey,

3152+

message,

3153+

});

3154+

}

3155+

}

3156+

}

3157+

if (returnedAgentErrorPayloads.length > 0) {

30713158

if (!hasBeforeAgentRunGate) {

30723159

await emitUserTranscriptUpdateAfterAgentRun();

30733160

}