Tools
Unterschiede
diffs ist ein optionales Plugin-Tool mit kurzer integrierter Systemanleitung und einer begleitenden Skill, die Änderungsinhalte in ein schreibgeschütztes Diff-Artefakt für Agents umwandelt.
Es akzeptiert entweder:
before- undafter-Text- einen vereinheitlichten
patch
Es kann zurückgeben:
- eine Gateway-Viewer-URL für Canvas-Präsentationen
- einen gerenderten Dateipfad (PNG oder PDF) für die Nachrichtenzustellung
- beide Ausgaben in einem Aufruf
Wenn es aktiviert ist, stellt das Plugin dem System-Prompt-Bereich eine knappe Nutzungsanleitung voran und stellt außerdem eine detaillierte Skill für Fälle bereit, in denen der Agent ausführlichere Anweisungen benötigt.
Schnellstart
Plugin installieren
openclaw plugins install diffsPlugin aktivieren
{ plugins: { entries: { diffs: { enabled: true, }, }, },}Modus auswählen
view
Canvas-zuerst-Abläufe: Agents rufen diffs mit mode: "view" auf und öffnen details.viewerUrl mit canvas present.
file
Chat-Dateizustellung: Agents rufen diffs mit mode: "file" auf und senden details.filePath mit message unter Verwendung von path oder filePath.
both
Kombiniert: Agents rufen diffs mit mode: "both" auf, um beide Artefakte in einem Aufruf zu erhalten.
Integrierte Systemanleitung deaktivieren
Wenn Sie das diffs-Tool aktiviert lassen, aber seine integrierte System-Prompt-Anleitung deaktivieren möchten, setzen Sie plugins.entries.diffs.hooks.allowPromptInjection auf false:
{ plugins: { entries: { diffs: { enabled: true, hooks: { allowPromptInjection: false, }, }, }, },}Dies blockiert den before_prompt_build-Hook des diffs-Plugins, während Plugin, Tool und begleitende Skill verfügbar bleiben.
Wenn Sie sowohl die Anleitung als auch das Tool deaktivieren möchten, deaktivieren Sie stattdessen das Plugin.
Typischer Agent-Workflow
diffs aufrufen
Der Agent ruft das diffs-Tool mit Eingabe auf.
Details lesen
Der Agent liest details-Felder aus der Antwort.
Präsentieren
Der Agent öffnet entweder details.viewerUrl mit canvas present, sendet details.filePath mit message unter Verwendung von path oder filePath oder tut beides.
Eingabebeispiele
Vorher und nachher
{ "before": "# Hello\n\nOne", "after": "# Hello\n\nTwo", "path": "docs/example.md", "mode": "view"}Patch
{ "patch": "diff --git a/src/example.ts b/src/example.ts\n--- a/src/example.ts\n+++ b/src/example.ts\n@@ -1 +1 @@\n-const x = 1;\n+const x = 2;\n", "mode": "both"}Tool-Eingabereferenz
Alle Felder sind optional, sofern nicht anders angegeben.
beforestringUrsprünglicher Text. Erforderlich mit after, wenn patch ausgelassen wird.
afterstringAktualisierter Text. Erforderlich mit before, wenn patch ausgelassen wird.
patchstringVereinheitlichter Diff-Text. Schließt sich gegenseitig mit before und after aus.
pathstringAnzuzeigender Dateiname für den Vorher-und-nachher-Modus.
langstringSprachüberschreibungshinweis für den Vorher-und-nachher-Modus. Unbekannte Werte fallen auf Nur-Text zurück.
titlestringÜberschreibung des Viewer-Titels.
mode"view" | "file" | "both"Ausgabemodus. Standardmäßig der Plugin-Standardwert defaults.mode. Veralteter Alias: "image" verhält sich wie "file" und wird aus Gründen der Abwärtskompatibilität weiterhin akzeptiert.
theme"light" | "dark"Viewer-Theme. Standardmäßig der Plugin-Standardwert defaults.theme.
layout"unified" | "split"Diff-Layout. Standardmäßig der Plugin-Standardwert defaults.layout.
expandUnchangedbooleanUnveränderte Abschnitte erweitern, wenn vollständiger Kontext verfügbar ist. Nur Option pro Aufruf (kein Plugin-Standardschlüssel).
fileFormat"png" | "pdf"Gerendertes Dateiformat. Standardmäßig der Plugin-Standardwert defaults.fileFormat.
fileQuality"standard" | "hq" | "print"Qualitätsvorgabe für PNG- oder PDF-Rendering.
fileScalenumberÜberschreibung der Geräteskalierung (1-4).
fileMaxWidthnumberMaximale Renderbreite in CSS-Pixeln (640-2400).
ttlSecondsnumberdefault: 1800Artefakt-TTL in Sekunden für Viewer- und eigenständige Dateiausgaben. Max. 21600.
baseUrlstringÜberschreibung des Viewer-URL-Ursprungs. Überschreibt Plugin viewerBaseUrl. Muss http oder https sein, keine Abfrage/kein Hash.
Legacy-Eingabealiase
Aus Gründen der Abwärtskompatibilität weiterhin akzeptiert:
format->fileFormatimageFormat->fileFormatimageQuality->fileQualityimageScale->fileScaleimageMaxWidth->fileMaxWidth
Validierung und Grenzwerte
beforeundafterjeweils max. 512 KiB.patchmax. 2 MiB.pathmax. 2048 Byte.langmax. 128 Byte.titlemax. 1024 Byte.- Obergrenze für Patch-Komplexität: max. 128 Dateien und insgesamt 120000 Zeilen.
patchzusammen mitbeforeoderafterwird abgelehnt.- Sicherheitsgrenzwerte für gerenderte Dateien (gelten für PNG und PDF):
fileQuality: "standard": max. 8 MP (8.000.000 gerenderte Pixel).fileQuality: "hq": max. 14 MP (14.000.000 gerenderte Pixel).fileQuality: "print": max. 24 MP (24.000.000 gerenderte Pixel).- PDF hat außerdem ein Maximum von 50 Seiten.
Vertrag für Ausgabedetails
Das Tool gibt strukturierte Metadaten unter details zurück.
Viewer-Felder
Gemeinsame Felder für Modi, die einen Viewer erstellen:
artifactIdviewerUrlviewerPathtitleexpiresAtinputKindfileCountmodecontext(agentId,sessionId,messageChannel,agentAccountId, wenn verfügbar)
Dateifelder
Dateifelder, wenn PNG oder PDF gerendert wird:
artifactIdexpiresAtfilePathpath(derselbe Wert wiefilePath, für Kompatibilität mit dem message-Tool)fileBytesfileFormatfileQualityfileScalefileMaxWidth
Kompatibilitätsaliase
Für bestehende Aufrufer ebenfalls zurückgegeben:
format(derselbe Wert wiefileFormat)imagePath(derselbe Wert wiefilePath)imageBytes(derselbe Wert wiefileBytes)imageQuality(derselbe Wert wiefileQuality)imageScale(derselbe Wert wiefileScale)imageMaxWidth(derselbe Wert wiefileMaxWidth)
Zusammenfassung des Modusverhaltens:
| Modus | Was zurückgegeben wird |
|---|---|
"view" |
Nur Viewer-Felder. |
"file" |
Nur Dateifelder, kein Viewer-Artefakt. |
"both" |
Viewer-Felder plus Dateifelder. Wenn das Datei-Rendering fehlschlägt, wird der Viewer dennoch mit fileError und dem Alias imageError zurückgegeben. |
Eingeklappte unveränderte Abschnitte
- Der Viewer kann Zeilen wie
N unmodified linesanzeigen. - Erweiterungssteuerelemente in diesen Zeilen sind bedingt und nicht für jede Eingabeart garantiert.
- Erweiterungssteuerelemente erscheinen, wenn der gerenderte Diff erweiterbare Kontextdaten enthält, was für Vorher-und-nachher-Eingaben typisch ist.
- Bei vielen vereinheitlichten Patch-Eingaben sind ausgelassene Kontextkörper in den geparsten Patch-Hunks nicht verfügbar, sodass die Zeile ohne Erweiterungssteuerelemente erscheinen kann. Dies ist erwartetes Verhalten.
expandUnchangedgilt nur, wenn erweiterbarer Kontext vorhanden ist.
Plugin-Standardwerte
Legen Sie Plugin-weite Standardwerte in ~/.openclaw/openclaw.json fest:
{ plugins: { entries: { diffs: { enabled: true, config: { defaults: { fontFamily: "Fira Code", fontSize: 15, lineSpacing: 1.6, layout: "unified", showLineNumbers: true, diffIndicators: "bars", wordWrap: true, background: true, theme: "dark", fileFormat: "png", fileQuality: "standard", fileScale: 2, fileMaxWidth: 960, mode: "both", ttlSeconds: 21600, }, }, }, }, },}Unterstützte Standardwerte:
fontFamilyfontSizelineSpacinglayoutshowLineNumbersdiffIndicatorswordWrapbackgroundthemefileFormatfileQualityfileScalefileMaxWidthmodettlSeconds
Explizite Tool-Parameter überschreiben diese Standardwerte.
Persistente Viewer-URL-Konfiguration
viewerBaseUrlstringPlugin-eigene Rückfalloption für zurückgegebene Viewer-Links, wenn ein Tool-Aufruf baseUrl nicht übergibt. Muss http oder https sein, keine Abfrage/kein Hash.
{ plugins: { entries: { diffs: { enabled: true, config: { viewerBaseUrl: "https://gateway.example.com/openclaw", }, }, }, },}Sicherheitskonfiguration
security.allowRemoteViewerbooleandefault: falsefalse: Nicht-local-loopback-Anfragen an Viewer-Routen werden verweigert. true: Remote-Viewer sind erlaubt, wenn der tokenisierte Pfad gültig ist.
{ plugins: { entries: { diffs: { enabled: true, config: { security: { allowRemoteViewer: false, }, }, }, }, },}Artefaktlebenszyklus und Speicherung
- Artefakte werden im temporären Unterordner gespeichert:
$TMPDIR/openclaw-diffs. - Viewer-Artefaktmetadaten enthalten:
- zufällige Artefakt-ID (20 Hex-Zeichen)
- zufälliges Token (48 Hex-Zeichen)
createdAtundexpiresAt- gespeicherter
viewer.html-Pfad
- Die standardmäßige Artefakt-TTL beträgt 30 Minuten, wenn sie nicht angegeben wird.
- Die maximal akzeptierte Viewer-TTL beträgt 6 Stunden.
- Die Bereinigung wird nach der Artefakterstellung opportunistisch ausgeführt.
- Abgelaufene Artefakte werden gelöscht.
- Die Rückfallbereinigung entfernt veraltete Ordner, die älter als 24 Stunden sind, wenn Metadaten fehlen.
Viewer-URL und Netzwerkverhalten
Viewer-Route:
/plugins/diffs/view/{artifactId}/{token}
Viewer-Assets:
/plugins/diffs/assets/viewer.js/plugins/diffs/assets/viewer-runtime.js
Das Viewer-Dokument löst diese Assets relativ zur Viewer-URL auf, sodass ein optionales baseUrl-Pfadpräfix auch für beide Asset-Anfragen beibehalten wird.
URL-Konstruktionsverhalten:
- Wenn Tool-Aufruf-
baseUrlangegeben ist, wird es nach strenger Validierung verwendet. - Andernfalls, wenn Plugin
viewerBaseUrlkonfiguriert ist, wird es verwendet. - Ohne eine der beiden Überschreibungen ist die Viewer-URL standardmäßig local loopback
127.0.0.1. - Wenn der Gateway-Bind-Modus
customist undgateway.customBindHostgesetzt ist, wird dieser Host verwendet.
baseUrl-Regeln:
- Muss
http://oderhttps://sein. - Abfrage und Hash werden abgelehnt.
- Ursprung plus optionaler Basispfad ist erlaubt.
Sicherheitsmodell
Härtung des Viewers
- Standardmäßig nur Loopback.
- Tokenisierte Viewer-Pfade mit strenger ID- und Token-Validierung.
- CSP für Viewer-Antworten:
default-src 'none'- Skripte und Assets nur von derselben Quelle
- kein ausgehendes
connect-src
- Drosselung von Remote-Fehlversuchen, wenn Remote-Zugriff aktiviert ist:
- 40 Fehlversuche pro 60 Sekunden
- 60 Sekunden Sperre (
429 Too Many Requests)
Härtung des Datei-Renderings
- Das Routing von Screenshot-Browseranfragen ist standardmäßig verweigernd.
- Nur lokale Viewer-Assets von
http://127.0.0.1/plugins/diffs/assets/*sind erlaubt. - Externe Netzwerkanfragen werden blockiert.
Browseranforderungen für den Dateimodus
mode: "file" und mode: "both" benötigen einen Chromium-kompatiblen Browser.
Auflösungsreihenfolge:
Konfiguration
browser.executablePath in der OpenClaw-Konfiguration.
Umgebungsvariablen
OPENCLAW_BROWSER_EXECUTABLE_PATHBROWSER_EXECUTABLE_PATHPLAYWRIGHT_CHROMIUM_EXECUTABLE_PATH
Plattform-Fallback
Fallback für plattformspezifische Befehls-/Pfaderkennung.
Häufiger Fehlertext:
Diff PNG/PDF rendering requires a Chromium-compatible browser...
Beheben Sie dies, indem Sie Chrome, Chromium, Edge oder Brave installieren oder eine der oben genannten Optionen für den ausführbaren Pfad festlegen.
Fehlerbehebung
Eingabevalidierungsfehler
Provide patch or both before and after text.— geben Sie sowohlbeforeals auchafteran, oder geben Siepatchan.Provide either patch or before/after input, not both.— mischen Sie die Eingabemodi nicht.Invalid baseUrl: ...— verwenden Sie einenhttp(s)-Ursprung mit optionalem Pfad, ohne Query/Hash.{field} exceeds maximum size (...)— reduzieren Sie die Payload-Größe.- Ablehnung großer Patches — reduzieren Sie die Anzahl der Patch-Dateien oder die Gesamtzahl der Zeilen.
Viewer-Zugänglichkeit
- Die Viewer-URL wird standardmäßig zu
127.0.0.1aufgelöst. - Für Remote-Zugriffsszenarien entweder:
- Plugin-
viewerBaseUrlfestlegen, oder baseUrlpro Tool-Aufruf übergeben, odergateway.bind=customundgateway.customBindHostverwenden
- Plugin-
- Wenn
gateway.trustedProxiesLoopback für einen Proxy auf demselben Host enthält (zum Beispiel Tailscale Serve), schlagen rohe Loopback-Viewer-Anfragen ohne weitergeleitete Client-IP-Header absichtlich geschlossen fehl. - Für diese Proxy-Topologie:
- bevorzugen Sie
mode: "file"odermode: "both", wenn Sie nur einen Anhang benötigen, oder - aktivieren Sie bewusst
security.allowRemoteViewerund legen Sie Plugin-viewerBaseUrlfest oder übergeben Sie eine Proxy-/öffentlichebaseUrl, wenn Sie eine teilbare Viewer-URL benötigen
- bevorzugen Sie
- Aktivieren Sie
security.allowRemoteViewernur, wenn Sie externen Viewer-Zugriff beabsichtigen.
Zeile mit unveränderten Zeilen hat keine Aufklappschaltfläche
Dies kann bei Patch-Eingaben passieren, wenn der Patch keinen erweiterbaren Kontext enthält. Dies ist erwartet und deutet nicht auf einen Viewer-Fehler hin.
Artefakt nicht gefunden
- Artefakt ist aufgrund der TTL abgelaufen.
- Token oder Pfad wurde geändert.
- Bereinigung hat veraltete Daten entfernt.
Betriebliche Hinweise
- Bevorzugen Sie
mode: "view"für lokale interaktive Reviews in Canvas. - Bevorzugen Sie
mode: "file"für ausgehende Chat-Kanäle, die einen Anhang benötigen. - Lassen Sie
allowRemoteViewerdeaktiviert, sofern Ihre Bereitstellung keine Remote-Viewer-URLs erfordert. - Legen Sie für vertrauliche Diffs explizit kurze
ttlSecondsfest. - Vermeiden Sie es, Geheimnisse in Diff-Eingaben zu senden, wenn dies nicht erforderlich ist.
- Wenn Ihr Kanal Bilder stark komprimiert (zum Beispiel Telegram oder WhatsApp), bevorzugen Sie PDF-Ausgabe (
fileFormat: "pdf").