Tools
Perbedaan
diffs adalah tool plugin opsional dengan panduan sistem bawaan singkat dan skill pendamping yang mengubah konten perubahan menjadi artefak diff baca-saja untuk agen.
Tool ini menerima salah satu dari:
- teks
beforedanafter patchterpadu
Tool ini dapat mengembalikan:
- URL penampil Gateway untuk presentasi kanvas
- path file yang dirender (PNG atau PDF) untuk pengiriman pesan
- kedua output dalam satu panggilan
Saat diaktifkan, plugin ini menambahkan panduan penggunaan ringkas ke ruang system-prompt dan juga mengekspos skill mendetail untuk kasus ketika agen membutuhkan instruksi yang lebih lengkap.
Mulai cepat
Install the plugin
openclaw plugins install diffs
Enable the plugin
{
plugins: {
entries: {
diffs: {
enabled: true,
},
},
},
}
Pick a mode
view
Alur yang mengutamakan kanvas: agen memanggil diffs dengan mode: "view" dan membuka details.viewerUrl dengan canvas present.
file
Pengiriman file chat: agen memanggil diffs dengan mode: "file" dan mengirim details.filePath dengan message menggunakan path atau filePath.
both
Gabungan: agen memanggil diffs dengan mode: "both" untuk mendapatkan kedua artefak dalam satu panggilan.
Nonaktifkan panduan sistem bawaan
Jika Anda ingin tetap mengaktifkan tool diffs tetapi menonaktifkan panduan system-prompt bawaannya, atur plugins.entries.diffs.hooks.allowPromptInjection ke false:
{
plugins: {
entries: {
diffs: {
enabled: true,
hooks: {
allowPromptInjection: false,
},
},
},
},
}
Ini memblokir hook before_prompt_build milik plugin diffs sambil tetap menyediakan plugin, tool, dan skill pendamping.
Jika Anda ingin menonaktifkan panduan dan tool sekaligus, nonaktifkan pluginnya.
Alur kerja agen umum
Call diffs
Agen memanggil tool diffs dengan input.
Read details
Agen membaca bidang details dari respons.
Present
Agen membuka details.viewerUrl dengan canvas present, mengirim details.filePath dengan message menggunakan path atau filePath, atau melakukan keduanya.
Contoh input
Before and after
{
"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"
}
Referensi input tool
Semua bidang bersifat opsional kecuali dinyatakan lain.
beforestringTeks asli. Wajib bersama after ketika patch dihilangkan.
afterstringTeks yang diperbarui. Wajib bersama before ketika patch dihilangkan.
patchstringTeks diff terpadu. Saling eksklusif dengan before dan after.
pathstringNama file tampilan untuk mode sebelum dan sesudah.
langstringPetunjuk penimpaan bahasa untuk mode sebelum dan sesudah. Nilai yang tidak diketahui akan kembali ke teks polos.
titlestringPenimpaan judul penampil.
mode"view" | "file" | "both"Mode output. Default ke default plugin defaults.mode. Alias usang: "image" berperilaku seperti "file" dan masih diterima untuk kompatibilitas mundur.
theme"light" | "dark"Tema penampil. Default ke default plugin defaults.theme.
layout"unified" | "split"Tata letak diff. Default ke default plugin defaults.layout.
expandUnchangedbooleanPerluas bagian yang tidak berubah ketika konteks lengkap tersedia. Opsi per panggilan saja (bukan kunci default plugin).
fileFormat"png" | "pdf"Format file yang dirender. Default ke default plugin defaults.fileFormat.
fileQuality"standard" | "hq" | "print"Preset kualitas untuk rendering PNG atau PDF.
fileScalenumberPenimpaan skala perangkat (1-4).
fileMaxWidthnumberLebar render maksimum dalam piksel CSS (640-2400).
ttlSecondsnumberTTL artefak dalam detik untuk output penampil dan file mandiri. Maks 21600.
baseUrlstringPenimpaan asal URL penampil. Menimpa viewerBaseUrl plugin. Harus berupa http atau https, tanpa query/hash.
Legacy input aliases
Masih diterima untuk kompatibilitas mundur:
format->fileFormatimageFormat->fileFormatimageQuality->fileQualityimageScale->fileScaleimageMaxWidth->fileMaxWidth
Validation and limits
beforedanaftermasing-masing maks 512 KiB.patchmaks 2 MiB.pathmaks 2048 byte.langmaks 128 byte.titlemaks 1024 byte.- Batas kompleksitas patch: maks 128 file dan total 120000 baris.
patchdanbeforeatauafterbersama-sama ditolak.- Batas keamanan file yang dirender (berlaku untuk PNG dan PDF):
fileQuality: "standard": maks 8 MP (8.000.000 piksel yang dirender).fileQuality: "hq": maks 14 MP (14.000.000 piksel yang dirender).fileQuality: "print": maks 24 MP (24.000.000 piksel yang dirender).- PDF juga memiliki maksimum 50 halaman.
Kontrak detail output
Tool mengembalikan metadata terstruktur di bawah details.
Viewer fields
Bidang bersama untuk mode yang membuat penampil:
artifactIdviewerUrlviewerPathtitleexpiresAtinputKindfileCountmodecontext(agentId,sessionId,messageChannel,agentAccountIdjika tersedia)
File fields
Bidang file ketika PNG atau PDF dirender:
artifactIdexpiresAtfilePathpath(nilai yang sama denganfilePath, untuk kompatibilitas tool pesan)fileBytesfileFormatfileQualityfileScalefileMaxWidth
Compatibility aliases
Juga dikembalikan untuk pemanggil yang sudah ada:
format(nilai yang sama denganfileFormat)imagePath(nilai yang sama denganfilePath)imageBytes(nilai yang sama denganfileBytes)imageQuality(nilai yang sama denganfileQuality)imageScale(nilai yang sama denganfileScale)imageMaxWidth(nilai yang sama denganfileMaxWidth)
Ringkasan perilaku mode:
| Mode | Yang dikembalikan |
|---|---|
"view" |
Hanya bidang penampil. |
"file" |
Hanya bidang file, tanpa artefak penampil. |
"both" |
Bidang penampil ditambah bidang file. Jika rendering file gagal, penampil tetap dikembalikan dengan alias fileError dan imageError. |
Bagian tidak berubah yang diciutkan
- Penampil dapat menampilkan baris seperti
N unmodified lines. - Kontrol perluas pada baris tersebut bersifat kondisional dan tidak dijamin untuk setiap jenis input.
- Kontrol perluas muncul ketika diff yang dirender memiliki data konteks yang dapat diperluas, yang umum untuk input sebelum dan sesudah.
- Untuk banyak input patch terpadu, isi konteks yang dihilangkan tidak tersedia dalam hunk patch yang diurai, sehingga baris dapat muncul tanpa kontrol perluas. Ini adalah perilaku yang diharapkan.
expandUnchangedhanya berlaku ketika konteks yang dapat diperluas ada.
Default plugin
Atur default di seluruh plugin dalam ~/.openclaw/openclaw.json:
{
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",
},
},
},
},
},
}
Default yang didukung:
fontFamilyfontSizelineSpacinglayoutshowLineNumbersdiffIndicatorswordWrapbackgroundthemefileFormatfileQualityfileScalefileMaxWidthmode
Parameter tool eksplisit menimpa default ini.
Konfigurasi URL penampil persisten
viewerBaseUrlstringFallback milik plugin untuk tautan penampil yang dikembalikan ketika panggilan tool tidak meneruskan baseUrl. Harus berupa http atau https, tanpa query/hash.
{
plugins: {
entries: {
diffs: {
enabled: true,
config: {
viewerBaseUrl: "https://gateway.example.com/openclaw",
},
},
},
},
}
Konfigurasi keamanan
security.allowRemoteViewerbooleanfalse: permintaan non-loopback ke rute penampil ditolak. true: penampil jarak jauh diizinkan jika path bertoken valid.
{
plugins: {
entries: {
diffs: {
enabled: true,
config: {
security: {
allowRemoteViewer: false,
},
},
},
},
},
}
Siklus hidup dan penyimpanan artefak
- Artefak disimpan di bawah subfolder temp:
$TMPDIR/openclaw-diffs. - Metadata artefak penampil berisi:
- ID artefak acak (20 karakter hex)
- token acak (48 karakter hex)
createdAtdanexpiresAt- path
viewer.htmlyang disimpan
- TTL artefak default adalah 30 menit ketika tidak ditentukan.
- TTL penampil maksimum yang diterima adalah 6 jam.
- Pembersihan berjalan secara oportunistik setelah pembuatan artefak.
- Artefak kedaluwarsa dihapus.
- Pembersihan fallback menghapus folder lama yang lebih dari 24 jam ketika metadata tidak ada.
URL penampil dan perilaku jaringan
Rute penampil:
/plugins/diffs/view/{artifactId}/{token}
Aset penampil:
/plugins/diffs/assets/viewer.js/plugins/diffs/assets/viewer-runtime.js
Dokumen penampil menyelesaikan aset tersebut relatif terhadap URL penampil, sehingga prefiks path baseUrl opsional juga dipertahankan untuk kedua permintaan aset.
Perilaku konstruksi URL:
- Jika
baseUrlpanggilan tool disediakan, nilai tersebut digunakan setelah validasi ketat. - Jika tidak, jika
viewerBaseUrlplugin dikonfigurasi, nilai tersebut digunakan. - Tanpa salah satu penimpaan, URL penampil default ke loopback
127.0.0.1. - Jika mode bind Gateway adalah
customdangateway.customBindHostdiatur, host tersebut digunakan.
Aturan baseUrl:
- Harus berupa
http://atauhttps://. - Query dan hash ditolak.
- Origin ditambah path dasar opsional diizinkan.
Model keamanan
Penguatan penampil
- Hanya loopback secara default.
- Path penampil bertoken dengan validasi ID dan token yang ketat.
- CSP respons penampil:
default-src 'none'- skrip dan aset hanya dari self
- tanpa
connect-srckeluar
- Pembatasan miss jarak jauh saat akses jarak jauh diaktifkan:
- 40 kegagalan per 60 detik
- penguncian 60 detik (
429 Too Many Requests)
Penguatan perenderan file
- Perutean permintaan browser tangkapan layar bersifat tolak-secara-default.
- Hanya aset penampil lokal dari
http://127.0.0.1/plugins/diffs/assets/*yang diizinkan. - Permintaan jaringan eksternal diblokir.
Persyaratan browser untuk mode file
mode: "file" dan mode: "both" memerlukan browser yang kompatibel dengan Chromium.
Urutan resolusi:
Konfigurasi
browser.executablePath dalam konfigurasi OpenClaw.
Variabel lingkungan
OPENCLAW_BROWSER_EXECUTABLE_PATHBROWSER_EXECUTABLE_PATHPLAYWRIGHT_CHROMIUM_EXECUTABLE_PATH
Fallback platform
Fallback penemuan perintah/path platform.
Teks kegagalan umum:
Diff PNG/PDF rendering requires a Chromium-compatible browser...
Perbaiki dengan menginstal Chrome, Chromium, Edge, atau Brave, atau mengatur salah satu opsi path executable di atas.
Pemecahan masalah
Kesalahan validasi input
Provide patch or both before and after text.— sertakanbeforedanafter, atau berikanpatch.Provide either patch or before/after input, not both.— jangan mencampur mode input.Invalid baseUrl: ...— gunakan originhttp(s)dengan path opsional, tanpa query/hash.{field} exceeds maximum size (...)— kurangi ukuran payload.- Penolakan patch besar — kurangi jumlah file patch atau total baris.
Aksesibilitas penampil
- URL penampil secara default mengarah ke
127.0.0.1. - Untuk skenario akses jarak jauh, lakukan salah satu:
- atur
viewerBaseUrlPlugin, atau - teruskan
baseUrlper pemanggilan alat, atau - gunakan
gateway.bind=customdangateway.customBindHost
- atur
- Jika
gateway.trustedProxiesmenyertakan loopback untuk proxy pada host yang sama (misalnya Tailscale Serve), permintaan penampil loopback mentah tanpa header IP klien yang diteruskan akan gagal tertutup sesuai desain. - Untuk topologi proxy tersebut:
- pilih
mode: "file"ataumode: "both"saat Anda hanya membutuhkan lampiran, atau - aktifkan
security.allowRemoteViewersecara sengaja dan aturviewerBaseUrlPlugin atau teruskanbaseUrlproxy/publik saat Anda membutuhkan URL penampil yang dapat dibagikan
- pilih
- Aktifkan
security.allowRemoteViewerhanya saat Anda memang membutuhkan akses penampil eksternal.
Baris tanpa perubahan tidak memiliki tombol perluas
Ini dapat terjadi untuk input patch saat patch tidak membawa konteks yang dapat diperluas. Ini diharapkan dan tidak menunjukkan kegagalan penampil.
Artefak tidak ditemukan
- Artefak kedaluwarsa karena TTL.
- Token atau path berubah.
- Pembersihan menghapus data usang.
Panduan operasional
- Pilih
mode: "view"untuk ulasan interaktif lokal di kanvas. - Pilih
mode: "file"untuk kanal obrolan keluar yang membutuhkan lampiran. - Biarkan
allowRemoteViewerdinonaktifkan kecuali deployment Anda memerlukan URL penampil jarak jauh. - Tetapkan
ttlSecondssingkat secara eksplisit untuk diff sensitif. - Hindari mengirim rahasia dalam input diff jika tidak diperlukan.
- Jika kanal Anda mengompresi gambar secara agresif (misalnya Telegram atau WhatsApp), pilih output PDF (
fileFormat: "pdf").