Gateway
Autentikasi proksi tepercaya
Kapan digunakan
Gunakan mode autentikasi trusted-proxy ketika:
- Anda menjalankan OpenClaw di belakang proxy yang sadar identitas (Pomerium, Caddy + OAuth, nginx + oauth2-proxy, Traefik + forward auth).
- Proxy Anda menangani semua autentikasi dan meneruskan identitas pengguna melalui header.
- Anda berada di lingkungan Kubernetes atau kontainer tempat proxy adalah satu-satunya jalur ke Gateway.
- Anda mengalami galat WebSocket
1008 unauthorizedkarena browser tidak dapat meneruskan token dalam payload WS.
Kapan TIDAK digunakan
- Jika proxy Anda tidak mengautentikasi pengguna (hanya terminator TLS atau load balancer).
- Jika ada jalur apa pun ke Gateway yang melewati proxy (celah firewall, akses jaringan internal).
- Jika Anda tidak yakin apakah proxy Anda menghapus/menimpa header terusan dengan benar.
- Jika Anda hanya memerlukan akses pribadi satu pengguna (pertimbangkan Tailscale Serve + loopback untuk penyiapan yang lebih sederhana).
Cara kerjanya
Proxy mengautentikasi pengguna
Reverse proxy Anda mengautentikasi pengguna (OAuth, OIDC, SAML, dll.).
Proxy menambahkan header identitas
Proxy menambahkan header dengan identitas pengguna yang telah diautentikasi (misalnya, x-forwarded-user: nick@example.com).
Gateway memverifikasi sumber tepercaya
OpenClaw memeriksa bahwa permintaan berasal dari IP proxy tepercaya (dikonfigurasi di gateway.trustedProxies).
Gateway mengekstrak identitas
OpenClaw mengekstrak identitas pengguna dari header yang dikonfigurasi.
Otorisasi
Jika semuanya valid, permintaan diotorisasi.
Perilaku pemasangan Control UI
Ketika gateway.auth.mode = "trusted-proxy" aktif dan permintaan lolos pemeriksaan trusted-proxy, sesi WebSocket Control UI dapat terhubung tanpa identitas pemasangan perangkat.
Implikasi cakupan:
- Sesi WebSocket Control UI tanpa perangkat dapat terhubung tetapi secara default tidak menerima cakupan operator. OpenClaw mengosongkan daftar cakupan yang diminta menjadi
[]sehingga sesi yang tidak terikat ke perangkat/token terpasang yang disetujui tidak dapat mendeklarasikan izin sendiri. - Jika metode gagal dengan
missing scopesetelah koneksi WebSocket berhasil, gunakan HTTPS agar browser dapat menghasilkan identitas perangkat dan menyelesaikan pemasangan. Lihat HTTP tidak aman Control UI. - Hanya untuk break-glass:
gateway.controlUi.dangerouslyDisableDeviceAuth=truemempertahankan cakupan yang diminta bahkan tanpa identitas perangkat. Ini adalah penurunan keamanan yang parah; kembalikan segera. Lihat HTTP tidak aman Control UI.
Pembatasan cakupan reverse proxy:
- Jika proxy Anda mengirim
x-openclaw-scopespada permintaan upgrade WebSocket Control UI, OpenClaw membatasi cakupan sesi ke irisan antara cakupan yang diminta dan cakupan yang dinyatakan. Header ini tidak memberikan cakupan; header ini hanya mempersempit apa yang dapat dimiliki sesi.
Implikasi:
- Pemasangan tidak lagi menjadi gerbang utama untuk akses Control UI dalam mode ini.
- Kebijakan autentikasi reverse proxy Anda dan
allowUsersmenjadi kontrol akses efektif. - Kunci ingress gateway hanya ke IP proxy tepercaya (
gateway.trustedProxies+ firewall).
Klien WebSocket kustom bukan sesi Control UI. gateway.controlUi.dangerouslyDisableDeviceAuth tidak memberikan cakupan ke klien arbitrer client.mode: "backend" atau klien berbentuk CLI. Otomasi kustom harus menggunakan identitas/pemasangan perangkat, jalur helper backend direct-local tercadangkan client.id: "gateway-client", atau plugin RPC HTTP admin ketika permukaan permintaan/respons HTTP lebih sesuai.
Konfigurasi
{ gateway: { // Trusted-proxy auth expects requests from a non-loopback trusted proxy source by default bind: "lan", // CRITICAL: Only add your proxy's IP(s) here trustedProxies: ["10.0.0.1", "172.17.0.1"], auth: { mode: "trusted-proxy", trustedProxy: { // Header containing authenticated user identity (required) userHeader: "x-forwarded-user", // Optional: headers that MUST be present (proxy verification) requiredHeaders: ["x-forwarded-proto", "x-forwarded-host"], // Optional: restrict to specific users (empty = allow all) allowUsers: ["nick@example.com", "admin@company.org"], // Optional: allow a same-host loopback proxy after explicit opt-in allowLoopback: false, }, }, },}Referensi konfigurasi
gateway.trustedProxiesstring[]requiredArray alamat IP proxy yang dipercaya. Permintaan dari IP lain ditolak.
gateway.auth.modestringrequiredHarus berupa "trusted-proxy".
gateway.auth.trustedProxy.userHeaderstringrequiredNama header yang berisi identitas pengguna yang telah diautentikasi.
gateway.auth.trustedProxy.requiredHeadersstring[]Header tambahan yang harus ada agar permintaan dipercaya.
gateway.auth.trustedProxy.allowUsersstring[]Daftar izin identitas pengguna. Kosong berarti mengizinkan semua pengguna yang telah diautentikasi.
gateway.auth.trustedProxy.allowLoopbackbooleanDukungan opt-in untuk reverse proxy loopback pada host yang sama. Defaultnya false.
Terminasi TLS dan HSTS
Gunakan satu titik terminasi TLS dan terapkan HSTS di sana.
Terminasi TLS proxy (direkomendasikan)
Ketika reverse proxy Anda menangani HTTPS untuk https://control.example.com, tetapkan Strict-Transport-Security di proxy untuk domain tersebut.
- Cocok untuk deployment yang menghadap internet.
- Menjaga kebijakan sertifikat + pengerasan HTTP di satu tempat.
- OpenClaw dapat tetap berada pada HTTP loopback di belakang proxy.
Contoh nilai header:
Strict-Transport-Security: max-age=31536000; includeSubDomainsTerminasi TLS Gateway
Jika OpenClaw sendiri melayani HTTPS secara langsung (tanpa proxy yang melakukan terminasi TLS), tetapkan:
{ gateway: { tls: { enabled: true }, http: { securityHeaders: { strictTransportSecurity: "max-age=31536000; includeSubDomains", }, }, },}strictTransportSecurity menerima nilai header string, atau false untuk menonaktifkan secara eksplisit.
Panduan rollout
- Mulai dengan usia maksimum singkat terlebih dahulu (misalnya
max-age=300) saat memvalidasi lalu lintas. - Tingkatkan ke nilai berumur panjang (misalnya
max-age=31536000) hanya setelah keyakinan tinggi. - Tambahkan
includeSubDomainshanya jika setiap subdomain siap HTTPS. - Gunakan preload hanya jika Anda sengaja memenuhi persyaratan preload untuk seluruh kumpulan domain Anda.
- Pengembangan lokal khusus loopback tidak mendapat manfaat dari HSTS.
Contoh penyiapan proxy
Pomerium
Pomerium meneruskan identitas dalam x-pomerium-claim-email (atau header klaim lain) dan JWT dalam x-pomerium-jwt-assertion.
{ gateway: { bind: "lan", trustedProxies: ["10.0.0.1"], // Pomerium's IP auth: { mode: "trusted-proxy", trustedProxy: { userHeader: "x-pomerium-claim-email", requiredHeaders: ["x-pomerium-jwt-assertion"], }, }, },}Cuplikan konfigurasi Pomerium:
routes: - from: https://openclaw.example.com to: http://openclaw-gateway:18789 policy: - allow: or: - email: is: nick@example.com pass_identity_headers: trueCaddy dengan OAuth
Caddy dengan plugin caddy-security dapat mengautentikasi pengguna dan meneruskan header identitas.
{ gateway: { bind: "lan", trustedProxies: ["10.0.0.1"], // Caddy/sidecar proxy IP auth: { mode: "trusted-proxy", trustedProxy: { userHeader: "x-forwarded-user", }, }, },}Cuplikan Caddyfile:
openclaw.example.com { authenticate with oauth2_provider authorize with policy1 reverse_proxy openclaw:18789 { header_up X-Forwarded-User {http.auth.user.email} }}nginx + oauth2-proxy
oauth2-proxy mengautentikasi pengguna dan meneruskan identitas dalam x-auth-request-email.
{ gateway: { bind: "lan", trustedProxies: ["10.0.0.1"], // nginx/oauth2-proxy IP auth: { mode: "trusted-proxy", trustedProxy: { userHeader: "x-auth-request-email", }, }, },}Cuplikan konfigurasi nginx:
location / { auth_request /oauth2/auth; auth_request_set $user $upstream_http_x_auth_request_email; proxy_pass http://openclaw:18789; proxy_set_header X-Auth-Request-Email $user; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade";}Traefik dengan forward auth
{ gateway: { bind: "lan", trustedProxies: ["172.17.0.1"], // Traefik container IP auth: { mode: "trusted-proxy", trustedProxy: { userHeader: "x-forwarded-user", }, }, },}Konfigurasi token campuran
OpenClaw menolak konfigurasi ambigu ketika gateway.auth.token (atau OPENCLAW_GATEWAY_TOKEN) dan mode trusted-proxy sama-sama aktif pada saat yang sama. Konfigurasi token campuran dapat menyebabkan permintaan loopback diam-diam diautentikasi melalui jalur autentikasi yang salah.
Jika Anda melihat galat mixed_trusted_proxy_token saat startup:
- Hapus token bersama saat menggunakan mode trusted-proxy, atau
- Alihkan
gateway.auth.modeke"token"jika Anda bermaksud menggunakan autentikasi berbasis token.
Header identitas trusted-proxy loopback tetap gagal tertutup: pemanggil dari host yang sama tidak diautentikasi secara diam-diam sebagai pengguna proxy. Pemanggil internal OpenClaw yang melewati proxy dapat menggunakan gateway.auth.password / OPENCLAW_GATEWAY_PASSWORD sebagai gantinya. Fallback token tetap sengaja tidak didukung dalam mode trusted-proxy.
Header cakupan operator
Autentikasi trusted-proxy adalah mode HTTP yang membawa identitas, sehingga pemanggil dapat secara opsional mendeklarasikan cakupan operator dengan x-openclaw-scopes pada permintaan HTTP API.
Catatan: Cakupan WebSocket ditentukan oleh handshake protokol Gateway dan pengikatan identitas perangkat. Pada permintaan upgrade WebSocket Control UI, x-openclaw-scopes hanya merupakan batas atas untuk cakupan sesi yang dinegosiasikan, bukan pemberian izin. Untuk perilaku cakupan WebSocket dengan trusted-proxy, lihat perilaku pairing Control UI.
Contoh:
x-openclaw-scopes: operator.readx-openclaw-scopes: operator.read,operator.writex-openclaw-scopes: operator.admin,operator.write
Perilaku:
- Ketika header ada, OpenClaw menghormati set cakupan yang dideklarasikan.
- Ketika header ada tetapi kosong, permintaan mendeklarasikan tanpa cakupan operator.
- Ketika header tidak ada, HTTP API normal yang membawa identitas menggunakan fallback ke set cakupan default operator standar.
- Rute HTTP plugin dengan autentikasi Gateway lebih sempit secara default: ketika
x-openclaw-scopestidak ada, cakupan runtime-nya menggunakan fallback keoperator.write. - Permintaan HTTP dari asal browser tetap harus lolos
gateway.controlUi.allowedOrigins(atau mode fallback Host-header yang disengaja) bahkan setelah autentikasi trusted-proxy berhasil. - Untuk sesi WebSocket Control UI,
x-openclaw-scopesadalah batas cakupan saat ada pada permintaan upgrade. Nilai kosong menghasilkan tanpa cakupan.
Aturan praktis: kirim x-openclaw-scopes secara eksplisit ketika Anda ingin permintaan trusted-proxy lebih sempit daripada default, atau ketika rute plugin dengan autentikasi gateway memerlukan sesuatu yang lebih kuat daripada cakupan tulis.
Daftar periksa keamanan
Sebelum mengaktifkan autentikasi trusted-proxy, verifikasi:
- [ ] Proxy adalah satu-satunya jalur: Port Gateway dibatasi firewall dari semuanya kecuali proxy Anda.
- [ ] trustedProxies minimal: Hanya IP proxy Anda yang sebenarnya, bukan seluruh subnet.
- [ ] Sumber proxy loopback disengaja: autentikasi trusted-proxy gagal tertutup untuk permintaan bersumber loopback kecuali
gateway.auth.trustedProxy.allowLoopbackdiaktifkan secara eksplisit untuk proxy pada host yang sama. - [ ] Proxy menghapus header: Proxy Anda menimpa (bukan menambahkan) header
x-forwarded-*dari klien. - [ ] Terminasi TLS: Proxy Anda menangani TLS; pengguna terhubung melalui HTTPS.
- [ ] allowedOrigins eksplisit: Control UI non-loopback menggunakan
gateway.controlUi.allowedOriginseksplisit. - [ ] allowUsers disetel (direkomendasikan): Batasi ke pengguna yang dikenal, alih-alih mengizinkan siapa pun yang terautentikasi.
- [ ] Tidak ada konfigurasi token campuran: Jangan setel
gateway.auth.tokendangateway.auth.mode: "trusted-proxy"sekaligus. - [ ] Fallback kata sandi lokal bersifat privat: Jika Anda mengonfigurasi
gateway.auth.passworduntuk pemanggil langsung internal, pastikan port Gateway dibatasi firewall agar klien jarak jauh non-proxy tidak dapat mengaksesnya secara langsung.
Audit keamanan
openclaw security audit akan menandai autentikasi trusted-proxy dengan temuan tingkat keparahan kritis. Ini disengaja — ini adalah pengingat bahwa Anda mendelegasikan keamanan ke penyiapan proxy Anda.
Audit memeriksa:
- Peringatan/pengingat kritis dasar
gateway.trusted_proxy_auth - Konfigurasi
trustedProxiesyang hilang - Konfigurasi
userHeaderyang hilang allowUserskosong (mengizinkan pengguna terautentikasi mana pun)allowLoopbackdiaktifkan untuk sumber proxy pada host yang sama- Kebijakan asal browser wildcard atau hilang pada permukaan Control UI yang terekspos
Pemecahan masalah
trusted_proxy_untrusted_source
Permintaan tidak berasal dari IP dalam gateway.trustedProxies. Periksa:
- Apakah IP proxy benar? (IP kontainer Docker dapat berubah.)
- Apakah ada load balancer di depan proxy Anda?
- Gunakan
docker inspectataukubectl get pods -o wideuntuk menemukan IP sebenarnya.
trusted_proxy_loopback_source
OpenClaw menolak permintaan trusted-proxy bersumber loopback.
Periksa:
- Apakah proxy terhubung dari
127.0.0.1/::1? - Apakah Anda mencoba menggunakan autentikasi trusted-proxy dengan reverse proxy loopback pada host yang sama?
Perbaikan:
- Utamakan autentikasi token/kata sandi untuk klien internal pada host yang sama yang tidak melalui proxy, atau
- Rutekan melalui alamat proxy tepercaya non-loopback dan simpan IP tersebut dalam
gateway.trustedProxies, atau - Untuk reverse proxy pada host yang sama yang disengaja, setel
gateway.auth.trustedProxy.allowLoopback = true, simpan alamat loopback dalamgateway.trustedProxies, dan pastikan proxy menghapus atau menimpa header identitas.
trusted_proxy_user_missing
Header pengguna kosong atau hilang. Periksa:
- Apakah proxy Anda dikonfigurasi untuk meneruskan header identitas?
- Apakah nama header benar? (tidak peka huruf besar/kecil, tetapi ejaan tetap penting)
- Apakah pengguna benar-benar terautentikasi di proxy?
trusted_proxy_missing_header_*
Header wajib tidak ada. Periksa:
- Konfigurasi proxy Anda untuk header spesifik tersebut.
- Apakah header dihapus di suatu tempat dalam rantai.
trusted_proxy_user_not_allowed
Pengguna terautentikasi tetapi tidak ada dalam allowUsers. Tambahkan pengguna tersebut atau hapus allowlist.
trusted_proxy_origin_not_allowed
Autentikasi trusted-proxy berhasil, tetapi header Origin browser tidak lolos pemeriksaan asal Control UI.
Periksa:
gateway.controlUi.allowedOriginsmencakup asal browser yang tepat.- Anda tidak mengandalkan asal wildcard kecuali Anda memang sengaja menginginkan perilaku izinkan-semua.
- Jika Anda sengaja menggunakan mode fallback Host-header,
gateway.controlUi.dangerouslyAllowHostHeaderOriginFallback=truedisetel secara sengaja.
Connection succeeds but methods report missing scope
WebSocket terhubung, tetapi chat.history, sessions.list, atau
models.list gagal dengan missing scope: operator.read.
Penyebab umum:
- Sesi Control UI tanpa perangkat: autentikasi trusted-proxy dapat mengizinkan koneksi WebSocket tanpa identitas perangkat, tetapi OpenClaw menghapus cakupan pada sesi tanpa perangkat sesuai desain.
- Klien backend kustom:
gateway.controlUi.dangerouslyDisableDeviceAuthmemiliki cakupan Control UI dan tidak memberikan cakupan ke klien WebSocket backend arbitrer atau berbentuk CLI. x-openclaw-scopesterlalu sempit: jika proxy Anda menyuntikkan header ini pada permintaan upgrade WebSocket Control UI, cakupan sesi dibatasi ke set tersebut. Nilai header kosong menghasilkan tanpa cakupan.
Perbaikan:
- Untuk Control UI, gunakan HTTPS agar browser dapat menghasilkan identitas perangkat dan menyelesaikan pairing.
- Untuk automasi kustom, gunakan identitas/pairing perangkat, jalur pembantu backend
gateway-clientdirect-local yang dicadangkan, atau admin HTTP RPC. - Gunakan
gateway.controlUi.dangerouslyDisableDeviceAuth: truehanya sebagai jalur darurat sementara untuk Control UI.
WebSocket still failing
Pastikan proxy Anda:
- Mendukung upgrade WebSocket (
Upgrade: websocket,Connection: upgrade). - Meneruskan header identitas pada permintaan upgrade WebSocket (bukan hanya HTTP).
- Tidak memiliki jalur autentikasi terpisah untuk koneksi WebSocket.
Migrasi dari autentikasi token
Jika Anda berpindah dari autentikasi token ke trusted-proxy:
Configure the proxy
Konfigurasikan proxy Anda untuk mengautentikasi pengguna dan meneruskan header.
Test the proxy independently
Uji penyiapan proxy secara terpisah (curl dengan header).
Update OpenClaw config
Perbarui konfigurasi OpenClaw dengan autentikasi trusted-proxy.
Restart the Gateway
Mulai ulang Gateway.
Test WebSocket
Uji koneksi WebSocket dari Control UI.
Audit
Jalankan openclaw security audit dan tinjau temuannya.
Terkait
- Konfigurasi — referensi konfigurasi
- Akses jarak jauh — pola akses jarak jauh lainnya
- Keamanan — panduan keamanan lengkap
- Tailscale — alternatif yang lebih sederhana untuk akses khusus tailnet