Aplikasi Android (Node)
Catatan: Aplikasi Android belum dirilis secara publik. Kode sumber tersedia di repositori OpenClaw di bawahapps/android. Anda dapat membangunnya sendiri menggunakan Java 17 dan Android SDK (./gradlew :app:assemblePlayDebug). Lihat apps/android/README.md untuk instruksi build.
Ringkasan dukungan
- Peran: aplikasi node pendamping (Android tidak meng-host Gateway).
- Gateway diperlukan: ya (jalankan di macOS, Linux, atau Windows melalui WSL2).
- Instalasi: Getting Started + Pairing.
- Gateway: Runbook + Konfigurasi.
- Protokol: Protokol Gateway (node + control plane).
Kontrol sistem
Kontrol sistem (launchd/systemd) berada di host Gateway. Lihat Gateway.Runbook Koneksi
Aplikasi node Android ⇄ (mDNS/NSD + WebSocket) ⇄ Gateway Android terhubung langsung ke Gateway WebSocket dan menggunakan pairing perangkat (role: node).
Untuk host Tailscale atau publik, Android memerlukan endpoint yang aman:
- Disarankan: Tailscale Serve / Funnel dengan
https://<magicdns>/wss://<magicdns> - Juga didukung: URL Gateway
wss://lain dengan endpoint TLS nyata ws://cleartext tetap didukung pada alamat LAN privat / host.local, sertalocalhost,127.0.0.1, dan bridge emulator Android (10.0.2.2)
Prasyarat
- Anda dapat menjalankan Gateway di mesin “master”.
- Perangkat/emulator Android dapat menjangkau gateway WebSocket:
- LAN yang sama dengan mDNS/NSD, atau
- Tailnet Tailscale yang sama menggunakan Wide-Area Bonjour / unicast DNS-SD (lihat di bawah), atau
- Host/port gateway manual (fallback)
- Pairing seluler tailnet/publik tidak menggunakan endpoint
ws://IP tailnet mentah. Gunakan Tailscale Serve atau URLwss://lain sebagai gantinya. - Anda dapat menjalankan CLI (
openclaw) di mesin gateway (atau melalui SSH).
1) Mulai Gateway
listening on ws://0.0.0.0:18789
wss:// / https:// yang aman. Penyiapan gateway.bind: "tailnet" biasa saja tidak cukup untuk pairing Android jarak jauh pertama kali kecuali Anda juga mengakhiri TLS secara terpisah.
2) Verifikasi penemuan (opsional)
Dari mesin gateway:local. plus domain wide-area yang dikonfigurasi dalam satu kali jalan dan menggunakan
endpoint layanan yang telah di-resolve alih-alih petunjuk hanya-TXT.
Penemuan tailnet (Wina ⇄ London) melalui unicast DNS-SD
Penemuan Android NSD/mDNS tidak akan lintas jaringan. Jika node Android dan gateway Anda berada di jaringan berbeda tetapi terhubung melalui Tailscale, gunakan Wide-Area Bonjour / unicast DNS-SD sebagai gantinya. Penemuan saja tidak cukup untuk pairing Android tailnet/publik. Rute yang ditemukan tetap memerlukan endpoint aman (wss:// atau Tailscale Serve):
- Siapkan zona DNS-SD (contoh
openclaw.internal.) di host gateway dan publikasikan record_openclaw-gw._tcp. - Konfigurasikan split DNS Tailscale untuk domain pilihan Anda yang menunjuk ke server DNS tersebut.
3) Terhubung dari Android
Di aplikasi Android:- Aplikasi menjaga koneksi gateway tetap hidup melalui foreground service (notifikasi persisten).
- Buka tab Connect.
- Gunakan mode Setup Code atau Manual.
- Jika penemuan terblokir, gunakan host/port manual di Advanced controls. Untuk host LAN privat,
ws://tetap berfungsi. Untuk host Tailscale/publik, aktifkan TLS dan gunakan endpointwss:/// Tailscale Serve.
- Endpoint manual (jika diaktifkan), jika tidak
- Gateway terakhir yang ditemukan (best-effort).
4) Setujui pairing (CLI)
Di mesin gateway:5) Verifikasi node terhubung
-
Melalui status node:
-
Melalui Gateway:
6) Chat + riwayat
Tab Chat Android mendukung pemilihan sesi (defaultmain, plus sesi lain yang sudah ada):
- Riwayat:
chat.history(dinormalisasi untuk tampilan; tag direktif inline dihapus dari teks yang terlihat, payload XML panggilan tool teks-biasa — termasuk<tool_call>...</tool_call>,<function_call>...</function_call>,<tool_calls>...</tool_calls>,<function_calls>...</function_calls>, dan blok panggilan tool yang terpotong — serta token kontrol model ASCII/full-width yang bocor dihapus, baris asisten token-senyap murni sepertiNO_REPLY/no_replyyang persis sama dihilangkan, dan baris yang terlalu besar dapat diganti dengan placeholder) - Kirim:
chat.send - Push update (best-effort):
chat.subscribe→event:"chat"
7) Canvas + kamera
Host Canvas Gateway (direkomendasikan untuk konten web)
Jika Anda ingin node menampilkan HTML/CSS/JS nyata yang dapat diedit agent di disk, arahkan node ke host canvas Gateway. Catatan: node memuat canvas dari server HTTP Gateway (port yang sama dengangateway.port, default 18789).
-
Buat
~/.openclaw/workspace/canvas/index.htmldi host gateway. - Arahkan node ke sana (LAN):
.local, misalnya http://<gateway-magicdns>:18789/__openclaw__/canvas/.
Server ini menyuntikkan klien live-reload ke HTML dan memuat ulang saat file berubah.
Host A2UI berada di http://<gateway-host>:18789/__openclaw__/a2ui/.
Perintah canvas (hanya foreground):
canvas.eval,canvas.snapshot,canvas.navigate(gunakan{"url":""}atau{"url":"/"}untuk kembali ke scaffold default).canvas.snapshotmengembalikan{ format, base64 }(defaultformat="jpeg").- A2UI:
canvas.a2ui.push,canvas.a2ui.reset(alias legacycanvas.a2ui.pushJSONL)
camera.snap(jpg)camera.clip(mp4)
8) Voice + permukaan perintah Android yang diperluas
- Voice: Android menggunakan satu alur mic nyala/mati di tab Voice dengan penangkapan transkrip dan pemutaran
talk.speak. TTS sistem lokal hanya digunakan saattalk.speaktidak tersedia. Voice berhenti saat aplikasi keluar dari foreground. - Toggle voice wake/talk-mode saat ini dihapus dari UX/runtime Android.
- Keluarga perintah Android tambahan (ketersediaan bergantung pada perangkat + izin):
device.status,device.info,device.permissions,device.healthnotifications.list,notifications.actions(lihat Penerusan notifikasi di bawah)photos.latestcontacts.search,contacts.addcalendar.events,calendar.addcallLog.searchsms.searchmotion.activity,motion.pedometer
Entrypoint asisten
Android mendukung peluncuran OpenClaw dari pemicu asisten sistem (Google Assistant). Jika dikonfigurasi, menahan tombol home atau mengucapkan “Hey Google, ask OpenClaw…” akan membuka aplikasi dan menyerahkan prompt ke penyusun chat. Ini menggunakan metadata Android App Actions yang dideklarasikan dalam manifest aplikasi. Tidak ada konfigurasi tambahan yang diperlukan di sisi gateway — intent asisten ditangani sepenuhnya oleh aplikasi Android dan diteruskan sebagai pesan chat biasa.Ketersediaan App Actions bergantung pada perangkat, versi Google Play Services,
dan apakah pengguna telah menetapkan OpenClaw sebagai aplikasi asisten default.
Penerusan notifikasi
Android dapat meneruskan notifikasi perangkat ke gateway sebagai event. Beberapa kontrol memungkinkan Anda membatasi notifikasi mana yang diteruskan dan kapan.| Key | Type | Description |
|---|---|---|
notifications.allowPackages | string[] | Hanya teruskan notifikasi dari nama paket ini. Jika disetel, semua paket lainnya diabaikan. |
notifications.denyPackages | string[] | Jangan pernah teruskan notifikasi dari nama paket ini. Diterapkan setelah allowPackages. |
notifications.quietHours.start | string (HH:mm) | Awal jendela jam tenang (waktu lokal perangkat). Notifikasi ditekan selama jendela ini. |
notifications.quietHours.end | string (HH:mm) | Akhir jendela jam tenang. |
notifications.rateLimit | number | Jumlah maksimum notifikasi yang diteruskan per paket per menit. Notifikasi berlebih dibuang. |
Penerusan notifikasi memerlukan izin Android Notification Listener. Aplikasi akan meminta izin ini saat penyiapan.