Platforms overview
Aplikacja na Androida
Migawka wsparcia
- Rola: aplikacja węzła towarzyszącego (Android nie hostuje Gateway).
- Wymagany Gateway: tak (uruchom go na macOS, Linux lub Windows przez WSL2).
- Instalacja: Google Play dla aplikacji, Pierwsze kroki dla Gateway, a następnie Parowanie.
- Gateway: Instrukcja operacyjna + Konfiguracja.
- Protokoły: protokół Gateway (węzły + płaszczyzna sterowania).
Sterowanie systemem
Sterowanie systemem (launchd/systemd) znajduje się na hoście Gateway. Zobacz Gateway.
Instrukcja połączenia
Aplikacja węzła Android ⇄ (mDNS/NSD + WebSocket) ⇄ Gateway
Android łączy się bezpośrednio z WebSocket Gateway i używa parowania urządzeń (role: node).
W przypadku Tailscale lub hostów publicznych Android wymaga bezpiecznego punktu końcowego:
- Preferowane: Tailscale Serve / Funnel z
https://<magicdns>/wss://<magicdns> - Obsługiwane także: dowolny inny URL Gateway
wss://z rzeczywistym punktem końcowym TLS - Jawny tekst
ws://pozostaje obsługiwany na prywatnych adresach LAN / hostach.local, a takżelocalhost,127.0.0.1i most emulatora Androida (10.0.2.2)
Wymagania wstępne
- Możesz uruchomić Gateway na maszynie „master”.
- Urządzenie/emulator Android może połączyć się z WebSocket Gateway:
- Ta sama sieć LAN z mDNS/NSD, albo
- Ta sama sieć tailnet Tailscale z Wide-Area Bonjour / unicast DNS-SD (zobacz niżej), albo
- Ręczny host/port Gateway (awaryjnie)
- Parowanie mobilne w sieci tailnet/publiczne nie używa surowych punktów końcowych IP tailnet
ws://. Zamiast tego użyj Tailscale Serve lub innego URLwss://. - Możesz uruchomić CLI (
openclaw) na maszynie Gateway (lub przez SSH).
1) Uruchom Gateway
openclaw gateway --port 18789 --verbosePotwierdź w logach, że widzisz coś w rodzaju:
listening on ws://0.0.0.0:18789
Do zdalnego dostępu Androida przez Tailscale preferuj Serve/Funnel zamiast surowego powiązania z tailnet:
openclaw gateway --tailscale serveDaje to Androidowi bezpieczny punkt końcowy wss:// / https://. Zwykła konfiguracja gateway.bind: "tailnet" nie wystarcza do pierwszego zdalnego parowania Androida, chyba że osobno kończysz też TLS.
2) Zweryfikuj wykrywanie (opcjonalnie)
Z maszyny Gateway:
dns-sd -B _openclaw-gw._tcp local.Więcej uwag debugowania: Bonjour.
Jeśli skonfigurowano też domenę wykrywania szerokiego obszaru, porównaj z:
openclaw gateway discover --jsonPokazuje to local. oraz skonfigurowaną domenę szerokiego obszaru w jednym przebiegu i używa rozwiązanego
punktu końcowego usługi zamiast wskazówek wyłącznie z TXT.
Wykrywanie w tailnet (Wiedeń ⇄ Londyn) przez unicast DNS-SD
Wykrywanie Android NSD/mDNS nie przechodzi między sieciami. Jeśli węzeł Android i Gateway są w różnych sieciach, ale są połączone przez Tailscale, użyj zamiast tego Wide-Area Bonjour / unicast DNS-SD.
Samo wykrywanie nie wystarcza do parowania Androida w sieci tailnet/publicznie. Wykryta trasa nadal wymaga bezpiecznego punktu końcowego (wss:// lub Tailscale Serve):
- Skonfiguruj strefę DNS-SD (przykład
openclaw.internal.) na hoście Gateway i opublikuj rekordy_openclaw-gw._tcp. - Skonfiguruj Tailscale split DNS dla wybranej domeny, wskazując ten serwer DNS.
Szczegóły i przykładowa konfiguracja CoreDNS: Bonjour.
3) Połącz z Androida
W aplikacji Android:
- Aplikacja utrzymuje połączenie z Gateway przy życiu przez usługę pierwszoplanową (stałe powiadomienie).
- Otwórz kartę Połącz.
- Użyj trybu Kod konfiguracji lub Ręcznie.
- Jeśli wykrywanie jest zablokowane, użyj ręcznego hosta/portu w Kontrolkach zaawansowanych. Dla prywatnych hostów LAN
ws://nadal działa. Dla hostów Tailscale/publicznych włącz TLS i użyj punktu końcowegowss:/// Tailscale Serve.
Po pierwszym udanym parowaniu Android automatycznie łączy się ponownie przy uruchomieniu:
- Ręczny punkt końcowy (jeśli włączony), w przeciwnym razie
- Ostatnio wykryty Gateway (najlepsza próba).
Beacony aktywnej obecności
Po połączeniu uwierzytelnionej sesji węzła oraz gdy aplikacja przechodzi do tła, a
usługa pierwszoplanowa jest nadal połączona, Android wywołuje node.event z
event: "node.presence.alive". Gateway zapisuje to jako lastSeenAtMs/lastSeenReason w
metadanych sparowanego węzła/urządzenia dopiero po poznaniu tożsamości uwierzytelnionego urządzenia węzła.
Aplikacja uznaje beacon za pomyślnie zapisany tylko wtedy, gdy odpowiedź Gateway zawiera
handled: true. Starsze Gateway mogą potwierdzać node.event za pomocą { "ok": true }; ta odpowiedź jest
zgodna, ale nie liczy się jako trwała aktualizacja ostatniej aktywności.
4) Zatwierdź parowanie (CLI)
Na maszynie Gateway:
openclaw devices listopenclaw devices approve <requestId>openclaw devices reject <requestId>Szczegóły parowania: Parowanie.
Opcjonalnie: jeśli węzeł Android zawsze łączy się z ściśle kontrolowanej podsieci, możesz włączyć automatyczne zatwierdzanie pierwszego parowania węzła za pomocą jawnych CIDR lub dokładnych IP:
{ gateway: { nodes: { pairing: { autoApproveCidrs: ["192.168.1.0/24"], }, }, },}Domyślnie jest to wyłączone. Dotyczy tylko świeżego parowania role: node bez
żądanych zakresów. Parowanie operatora/przeglądarki oraz każda zmiana roli, zakresu, metadanych lub
klucza publicznego nadal wymaga ręcznego zatwierdzenia.
5) Zweryfikuj, że węzeł jest połączony
-
Przez status węzłów:
bash openclaw nodes status -
Przez Gateway:
bash openclaw gateway call node.list --params "{}"
6) Czat + historia
Karta Czat w Androidzie obsługuje wybór sesji (domyślnie main oraz inne istniejące sesje):
- Historia:
chat.history(znormalizowana do wyświetlania; wbudowane znaczniki dyrektyw są usuwane z widocznego tekstu, ładunki XML wywołań narzędzi w postaci zwykłego tekstu (w tym<tool_call>...</tool_call>,<function_call>...</function_call>,<tool_calls>...</tool_calls>,<function_calls>...</function_calls>oraz ucięte bloki wywołań narzędzi) i ujawnione tokeny sterujące modelu ASCII/pełnej szerokości są usuwane, czyste wiersze asystenta z cichymi tokenami, takie jak dokładneNO_REPLY/no_reply, są pomijane, a zbyt duże wiersze mogą być zastępowane placeholderami) - Wysyłanie:
chat.send - Aktualizacje push (najlepsza próba):
chat.subscribe→event:"chat"
7) Canvas + kamera
Host Canvas Gateway (zalecany dla treści WWW)
Jeśli chcesz, aby węzeł pokazywał prawdziwy HTML/CSS/JS, który agent może edytować na dysku, skieruj węzeł na host Canvas Gateway.
-
Utwórz
~/.openclaw/workspace/canvas/index.htmlna hoście Gateway. -
Przekieruj do niego węzeł (LAN):
openclaw nodes invoke --node "<Android Node>" --command canvas.navigate --params '{"url":"http://<gateway-hostname>.local:18789/__openclaw__/canvas/"}'Tailnet (opcjonalnie): jeśli oba urządzenia są w Tailscale, użyj nazwy MagicDNS lub IP tailnet zamiast .local, np. http://<gateway-magicdns>:18789/__openclaw__/canvas/.
Ten serwer wstrzykuje klienta live-reload do HTML i przeładowuje po zmianach plików.
Gateway udostępnia też /__openclaw__/a2ui/, ale aplikacja Android traktuje zdalne strony A2UI jako tylko do renderowania. Polecenia A2UI zdolne do akcji używają dołączonej strony A2UI należącej do aplikacji przed zastosowaniem wiadomości.
Polecenia Canvas (tylko na pierwszym planie):
canvas.eval,canvas.snapshot,canvas.navigate(użyj{"url":""}lub{"url":"/"}, aby wrócić do domyślnego szkieletu).canvas.snapshotzwraca{ format, base64 }(domyślnieformat="jpeg").- A2UI:
canvas.a2ui.push,canvas.a2ui.reset(canvas.a2ui.pushJSONLto starszy alias). Te polecenia używają dołączonej strony A2UI należącej do aplikacji do renderowania zdolnego do akcji.
Polecenia kamery (tylko na pierwszym planie; wymagają uprawnienia):
camera.snap(jpg)camera.clip(mp4)
Parametry i pomocniki CLI znajdziesz w Węzeł kamery.
8) Głos + rozszerzona powierzchnia poleceń Androida
- Karta Głos: Android ma dwa jawne tryby przechwytywania. Mikrofon to ręczna sesja karty Głos, która wysyła każdą pauzę jako turę czatu i zatrzymuje się, gdy aplikacja opuszcza pierwszy plan lub użytkownik opuszcza kartę Głos. Rozmowa to ciągły tryb Talk Mode i nasłuchuje, dopóki nie zostanie wyłączony lub węzeł się nie rozłączy.
- Talk Mode promuje istniejącą usługę pierwszoplanową z
connectedDevicedoconnectedDevice|microphoneprzed rozpoczęciem przechwytywania, a następnie degraduje ją po zatrzymaniu Talk Mode. Usługa węzła deklarujeFOREGROUND_SERVICE_CONNECTED_DEVICEzCHANGE_NETWORK_STATE; Android 14+ wymaga też deklaracjiFOREGROUND_SERVICE_MICROPHONE, nadania uprawnienia runtimeRECORD_AUDIOoraz typu usługi mikrofonu w czasie działania. - Domyślnie Android Talk używa natywnego rozpoznawania mowy, czatu Gateway i
talk.speakprzez skonfigurowanego dostawcę Talk Gateway. Lokalny systemowy TTS jest używany tylko wtedy, gdytalk.speakjest niedostępne. - Android Talk używa przekaźnika Gateway w czasie rzeczywistym tylko wtedy, gdy
talk.realtime.modema wartośćrealtime, atalk.realtime.transportma wartośćgateway-relay. - Wybudzanie głosem pozostaje wyłączone w UX/czasie działania Androida.
- Dodatkowe rodziny poleceń Androida (dostępność zależy od urządzenia, uprawnień i ustawień użytkownika):
device.status,device.info,device.permissions,device.healthdevice.appstylko wtedy, gdy włączone jest Ustawienia > Możliwości telefonu > Zainstalowane aplikacje; domyślnie wyświetla aplikacje widoczne w launcherze.notifications.list,notifications.actions(zobacz niżej Przekazywanie powiadomień)photos.latestcontacts.search,contacts.addcalendar.events,calendar.addcallLog.searchsms.searchmotion.activity,motion.pedometer
Punkty wejścia asystenta
Android obsługuje uruchamianie OpenClaw z systemowego wyzwalacza asystenta (Google Assistant). Po skonfigurowaniu przytrzymanie przycisku ekranu głównego lub powiedzenie „Hey Google, ask OpenClaw...” otwiera aplikację i przekazuje prompt do kompozytora czatu.
Używa to metadanych Android App Actions zadeklarowanych w manifeście aplikacji. Po stronie Gateway nie jest potrzebna dodatkowa konfiguracja -- intencja asystenta jest obsługiwana całkowicie przez aplikację Android i przekazywana jako normalna wiadomość czatu.
Przekazywanie powiadomień
Android może przekazywać powiadomienia urządzenia do Gateway jako zdarzenia. Kilka kontrolek pozwala określić, które powiadomienia są przekazywane i kiedy.
| Klucz | Typ | Opis |
|---|---|---|
notifications.allowPackages |
string[] | Przekazuj tylko powiadomienia z tych nazw pakietów. Jeśli ustawione, wszystkie inne pakiety są ignorowane. |
notifications.denyPackages |
string[] | Nigdy nie przekazuj powiadomień z tych nazw pakietów. Stosowane po allowPackages. |
notifications.quietHours.start |
string (HH:mm) | Początek okna godzin ciszy (lokalny czas urządzenia). Powiadomienia są tłumione w tym oknie. |
notifications.quietHours.end |
string (HH:mm) | Koniec okna godzin ciszy. |
notifications.rateLimit |
number | Maksymalna liczba przekazanych powiadomień na pakiet na minutę. Nadmiarowe powiadomienia są odrzucane. |
Selektor powiadomień używa też bezpieczniejszego zachowania dla przekazywanych zdarzeń powiadomień, zapobiegając przypadkowemu przekazywaniu wrażliwych powiadomień systemowych.
Przykładowa konfiguracja:
{ notifications: { allowPackages: ["com.slack", "com.whatsapp"], denyPackages: ["com.android.systemui"], quietHours: { start: "22:00", end: "07:00", }, rateLimit: 5, },}