Synology Chat
Status: channel pesan langsung plugin bawaan yang menggunakan webhook Synology Chat. Plugin ini menerima pesan masuk dari webhook keluar Synology Chat dan mengirim balasan melalui webhook masuk Synology Chat.Plugin bawaan
Synology Chat tersedia sebagai plugin bawaan dalam rilis OpenClaw saat ini, jadi build paket normal tidak memerlukan instalasi terpisah. Jika Anda menggunakan build lama atau instalasi kustom yang tidak menyertakan Synology Chat, instal secara manual: Instal dari checkout lokal:Penyiapan cepat
- Pastikan plugin Synology Chat tersedia.
- Rilis OpenClaw paket saat ini sudah menyertakan plugin ini.
- Instalasi lama/kustom dapat menambahkannya secara manual dari checkout sumber dengan perintah di atas.
openclaw onboardsekarang menampilkan Synology Chat dalam daftar penyiapan channel yang sama sepertiopenclaw channels add.- Penyiapan non-interaktif:
openclaw channels add --channel synology-chat --token <token> --url <incoming-webhook-url>
- Di integrasi Synology Chat:
- Buat webhook masuk dan salin URL-nya.
- Buat webhook keluar dengan token rahasia Anda.
- Arahkan URL webhook keluar ke gateway OpenClaw Anda:
https://gateway-host/webhook/synologysecara default.- Atau
channels.synology-chat.webhookPathkustom Anda.
- Selesaikan penyiapan di OpenClaw.
- Terpandu:
openclaw onboard - Langsung:
openclaw channels add --channel synology-chat --token <token> --url <incoming-webhook-url>
- Terpandu:
- Mulai ulang gateway dan kirim DM ke bot Synology Chat.
- OpenClaw menerima token webhook keluar dari
body.token, lalu?token=..., lalu header. - Bentuk header yang diterima:
x-synology-tokenx-webhook-tokenx-openclaw-tokenAuthorization: Bearer <token>
- Token yang kosong atau tidak ada akan gagal secara fail-closed.
Variabel lingkungan
Untuk akun default, Anda dapat menggunakan variabel lingkungan:SYNOLOGY_CHAT_TOKENSYNOLOGY_CHAT_INCOMING_URLSYNOLOGY_NAS_HOSTSYNOLOGY_ALLOWED_USER_IDS(dipisahkan koma)SYNOLOGY_RATE_LIMITOPENCLAW_BOT_NAME
Kebijakan DM dan kontrol akses
dmPolicy: "allowlist"adalah default yang direkomendasikan.allowedUserIdsmenerima daftar (atau string yang dipisahkan koma) ID pengguna Synology.- Dalam mode
allowlist, daftarallowedUserIdsyang kosong dianggap sebagai salah konfigurasi dan rute webhook tidak akan dimulai (gunakandmPolicy: "open"untuk mengizinkan semua). dmPolicy: "open"mengizinkan pengirim mana pun.dmPolicy: "disabled"memblokir DM.- Binding penerima balasan tetap menggunakan
user_idnumerik yang stabil secara default.channels.synology-chat.dangerouslyAllowNameMatching: trueadalah mode kompatibilitas darurat yang mengaktifkan kembali pencocokan username/nickname yang dapat berubah untuk pengiriman balasan. - Persetujuan pairing berfungsi dengan:
openclaw pairing list synology-chatopenclaw pairing approve synology-chat <CODE>
Pengiriman keluar
Gunakan ID pengguna Synology Chat numerik sebagai target. Contoh:Multi-akun
Beberapa akun Synology Chat didukung di bawahchannels.synology-chat.accounts.
Setiap akun dapat menimpa token, URL masuk, path webhook, kebijakan DM, dan batasan.
Sesi pesan langsung diisolasi per akun dan pengguna, sehingga user_id numerik yang sama
pada dua akun Synology yang berbeda tidak berbagi status transkrip.
Berikan setiap akun aktif webhookPath yang berbeda. OpenClaw sekarang menolak path persis yang duplikat
dan menolak memulai akun bernama yang hanya mewarisi satu path webhook bersama dalam penyiapan multi-akun.
Jika Anda sengaja memerlukan pewarisan lama untuk akun bernama, atur
dangerouslyAllowInheritedWebhookPath: true pada akun tersebut atau di channels.synology-chat,
tetapi path persis yang duplikat tetap ditolak secara fail-closed. Lebih baik gunakan path eksplisit per akun.
Catatan keamanan
- Jaga kerahasiaan
tokendan rotasi jika bocor. - Pertahankan
allowInsecureSsl: falsekecuali Anda secara eksplisit memercayai sertifikat NAS lokal self-signed. - Permintaan webhook masuk diverifikasi token dan dibatasi lajunya per pengirim.
- Pemeriksaan token tidak valid menggunakan perbandingan rahasia waktu konstan dan fail-closed.
- Gunakan
dmPolicy: "allowlist"untuk produksi. - Biarkan
dangerouslyAllowNameMatchingnonaktif kecuali Anda benar-benar memerlukan pengiriman balasan berbasis username lama. - Biarkan
dangerouslyAllowInheritedWebhookPathnonaktif kecuali Anda secara eksplisit menerima risiko perutean path bersama dalam penyiapan multi-akun.
Pemecahan masalah
Missing required fields (token, user_id, text):- payload webhook keluar tidak memiliki salah satu field wajib
- jika Synology mengirim token di header, pastikan gateway/proxy mempertahankan header tersebut
Invalid token:- rahasia webhook keluar tidak cocok dengan
channels.synology-chat.token - permintaan mengenai akun/path webhook yang salah
- reverse proxy menghapus header token sebelum permintaan mencapai OpenClaw
- rahasia webhook keluar tidak cocok dengan
Rate limit exceeded:- terlalu banyak percobaan token tidak valid dari sumber yang sama dapat mengunci sementara sumber tersebut
- pengirim yang terautentikasi juga memiliki batas laju pesan terpisah per pengguna
Allowlist is empty. Configure allowedUserIds or use dmPolicy=open.:dmPolicy="allowlist"aktif tetapi tidak ada pengguna yang dikonfigurasi
User not authorized:user_idnumerik pengirim tidak ada dalamallowedUserIds
Terkait
- Ikhtisar Channel — semua channel yang didukung
- Pairing — autentikasi DM dan alur pairing
- Grup — perilaku chat grup dan penyaringan mention
- Perutean Channel — perutean sesi untuk pesan
- Keamanan — model akses dan hardening