Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
diffs 是一個可選的 Plugin 工具,內建簡短的系統指引,並附帶一個配套 skill,可將變更內容轉換為供代理使用的唯讀 diff 成品。
它接受以下任一輸入:
before與after文字- 統一格式的
patch
- 用於 canvas 呈現的 Gateway 檢視器 URL
- 用於訊息傳送的已算繪檔案路徑(PNG 或 PDF)
- 在一次呼叫中同時回傳兩種輸出
快速開始
停用內建系統指引
如果你想保留啟用diffs 工具,但停用其內建的系統提示指引,請將 plugins.entries.diffs.hooks.allowPromptInjection 設為 false:
before_prompt_build hook,同時保留 Plugin、工具與配套 skill 可用。
如果你想同時停用指引與工具,請改為停用 Plugin。
典型代理工作流程
輸入範例
- Before and after
- Patch
工具輸入參考
除非另有註明,所有欄位皆為選用。原始文字。省略
patch 時,必須與 after 一起提供。更新後文字。省略
patch 時,必須與 before 一起提供。統一 diff 文字。與
before 和 after 互斥。before and after 模式的顯示檔名。
before and after 模式的語言覆寫提示。未知值會退回純文字。
檢視器標題覆寫。
輸出模式。預設為 Plugin 預設值
defaults.mode。已棄用別名:"image" 的行為與 "file" 相同,且仍為了向後相容而接受。檢視器主題。預設為 Plugin 預設值
defaults.theme。Diff 版面配置。預設為 Plugin 預設值
defaults.layout。當完整內容可用時,展開未變更區段。僅為單次呼叫選項(不是 Plugin 預設鍵)。
已算繪檔案格式。預設為 Plugin 預設值
defaults.fileFormat。PNG 或 PDF 算繪的品質預設。
裝置縮放覆寫(
1-4)。CSS 像素中的最大算繪寬度(
640-2400)。檢視器與獨立檔案輸出的成品 TTL,以秒為單位。最大 21600。
檢視器 URL 來源覆寫。會覆寫 Plugin
viewerBaseUrl。必須是 http 或 https,不可有查詢/雜湊。舊版輸入別名
舊版輸入別名
為了向後相容,仍然接受:
format->fileFormatimageFormat->fileFormatimageQuality->fileQualityimageScale->fileScaleimageMaxWidth->fileMaxWidth
驗證與限制
驗證與限制
before和after各自最大 512 KiB。patch最大 2 MiB。path最大 2048 位元組。lang最大 128 位元組。title最大 1024 位元組。- Patch 複雜度上限:最多 128 個檔案與 120000 總行數。
- 同時提供
patch與before或after會遭拒。 - 已算繪檔案安全限制(適用於 PNG 和 PDF):
fileQuality: "standard":最多 8 MP(8,000,000 個算繪像素)。fileQuality: "hq":最多 14 MP(14,000,000 個算繪像素)。fileQuality: "print":最多 24 MP(24,000,000 個算繪像素)。- PDF 另有最多 50 頁的限制。
輸出 details 合約
工具會在details 下回傳結構化中繼資料。
檢視器欄位
檢視器欄位
建立檢視器的模式所共用的欄位:
artifactIdviewerUrlviewerPathtitleexpiresAtinputKindfileCountmodecontext(可用時包含agentId、sessionId、messageChannel、agentAccountId)
檔案欄位
檔案欄位
算繪 PNG 或 PDF 時的檔案欄位:
artifactIdexpiresAtfilePathpath(與filePath相同的值,用於 message 工具相容性)fileBytesfileFormatfileQualityfileScalefileMaxWidth
相容性別名
相容性別名
也會為既有呼叫端回傳:
format(與fileFormat相同的值)imagePath(與filePath相同的值)imageBytes(與fileBytes相同的值)imageQuality(與fileQuality相同的值)imageScale(與fileScale相同的值)imageMaxWidth(與fileMaxWidth相同的值)
| 模式 | 回傳內容 |
|---|---|
"view" | 僅檢視器欄位。 |
"file" | 僅檔案欄位,沒有檢視器成品。 |
"both" | 檢視器欄位加上檔案欄位。如果檔案算繪失敗,檢視器仍會回傳,並帶有 fileError 與 imageError 別名。 |
已摺疊的未變更區段
- 檢視器可以顯示如
N unmodified lines的列。 - 這些列上的展開控制項是有條件的,並不保證每種輸入類型都有。
- 當已算繪 diff 具有可展開的內容資料時,會出現展開控制項;這通常見於 before and after 輸入。
- 對於許多統一 patch 輸入,省略的內容主體在已解析的 patch hunk 中不可用,因此該列可能會在沒有展開控制項的情況下出現。這是預期行為。
expandUnchanged僅在存在可展開內容時適用。
Plugin 預設值
在~/.openclaw/openclaw.json 中設定整個 Plugin 的預設值:
fontFamilyfontSizelineSpacinglayoutshowLineNumbersdiffIndicatorswordWrapbackgroundthemefileFormatfileQualityfileScalefileMaxWidthmodettlSeconds
持久化檢視器 URL 設定
當工具呼叫未傳入
baseUrl 時,由 Plugin 擁有、用於回傳檢視器連結的備援值。必須是 http 或 https,不可有查詢/雜湊。安全性設定
false:拒絕對檢視器路由的非 loopback 請求。true:如果 token 化路徑有效,允許遠端檢視器。成品生命週期與儲存
- 成品會儲存在暫存子資料夾下:
$TMPDIR/openclaw-diffs。 - 檢視器成品中繼資料包含:
- 隨機成品 ID(20 個十六進位字元)
- 隨機 token(48 個十六進位字元)
createdAt與expiresAt- 已儲存的
viewer.html路徑
- 未指定時,預設成品 TTL 為 30 分鐘。
- 接受的最大檢視器 TTL 為 6 小時。
- 清理會在成品建立後伺機執行。
- 過期成品會被刪除。
- 當中繼資料缺失時,備援清理會移除超過 24 小時的陳舊資料夾。
檢視器 URL 與網路行為
檢視器路由:/plugins/diffs/view/{artifactId}/{token}
/plugins/diffs/assets/viewer.js/plugins/diffs/assets/viewer-runtime.js
baseUrl 路徑前綴也會同時保留給兩個資產請求。
URL 建構行為:
- 如果提供了工具呼叫的
baseUrl,會在嚴格驗證後使用它。 - 否則,如果已設定 Plugin
viewerBaseUrl,會使用它。 - 若兩者都沒有覆寫,檢視器 URL 預設為 loopback
127.0.0.1。 - 如果 Gateway 繫結模式為
custom且已設定gateway.customBindHost,會使用該主機。
baseUrl 規則:
- 必須是
http://或https://。 - 會拒絕查詢與雜湊。
- 允許來源加上選用的基底路徑。
安全性模型
檢視器強化
檢視器強化
- 預設僅允許回送。
- 具權杖的檢視器路徑,並嚴格驗證 ID 與權杖。
- 檢視器回應 CSP:
default-src 'none'- 指令碼與資產僅來自自身
- 不允許外送
connect-src
- 啟用遠端存取時,會對遠端未命中進行節流:
- 每 60 秒 40 次失敗
- 60 秒鎖定(
429 Too Many Requests)
檔案算繪強化
檔案算繪強化
- 螢幕截圖瀏覽器請求路由預設拒絕。
- 僅允許來自
http://127.0.0.1/plugins/diffs/assets/*的本機檢視器資產。 - 外部網路請求會被封鎖。
檔案模式的瀏覽器需求
mode: "file" 與 mode: "both" 需要 Chromium 相容瀏覽器。
解析順序:
常見失敗文字:
Diff PNG/PDF rendering requires a Chromium-compatible browser...
疑難排解
輸入驗證錯誤
輸入驗證錯誤
Provide patch or both before and after text.— 同時包含before與after,或提供patch。Provide either patch or before/after input, not both.— 不要混用輸入模式。Invalid baseUrl: ...— 使用http(s)來源,可含選用路徑,但不可含查詢/雜湊。{field} exceeds maximum size (...)— 縮減酬載大小。- 大型修補檔遭拒 — 減少修補檔案數量或總行數。
檢視器可存取性
檢視器可存取性
- 檢視器 URL 預設解析為
127.0.0.1。 - 對於遠端存取情境,請擇一:
- 設定 Plugin
viewerBaseUrl,或 - 在每次工具呼叫傳入
baseUrl,或 - 使用
gateway.bind=custom與gateway.customBindHost
- 設定 Plugin
- 如果
gateway.trustedProxies包含同主機 Proxy 的回送位址(例如 Tailscale Serve),未帶轉送用戶端 IP 標頭的原始回送檢視器請求,會依設計以失敗關閉。 - 對於該 Proxy 拓撲:
- 當你只需要附件時,偏好使用
mode: "file"或mode: "both",或 - 當你需要可分享的檢視器 URL 時,明確啟用
security.allowRemoteViewer,並設定 PluginviewerBaseUrl或傳入 Proxy/公開的baseUrl
- 當你只需要附件時,偏好使用
- 只有在你確實打算允許外部檢視器存取時,才啟用
security.allowRemoteViewer。
未修改行資料列沒有展開按鈕
未修改行資料列沒有展開按鈕
當修補檔輸入未攜帶可展開的內容脈絡時,可能會發生這種情況。這是預期行為,不代表檢視器失敗。
找不到成品
找不到成品
- 成品因 TTL 到期。
- 權杖或路徑已變更。
- 清理程序移除了過期資料。
操作指引
- 對於畫布中的本機互動式檢閱,偏好使用
mode: "view"。 - 對於需要附件的外送聊天管道,偏好使用
mode: "file"。 - 除非你的部署需要遠端檢視器 URL,否則請保持停用
allowRemoteViewer。 - 針對敏感差異設定明確且短的
ttlSeconds。 - 不需要時,避免在差異輸入中傳送秘密。
- 如果你的管道會大幅壓縮圖片(例如 Telegram 或 WhatsApp),請偏好 PDF 輸出(
fileFormat: "pdf")。
差異算繪引擎由 Diffs 提供。