Konum komutu (düğümler)¶
TL;DR¶
location.getbir düğüm komutudur (node.invokearacılığıyla).- Varsayılan olarak kapalıdır.
- Ayarlar bir seçici kullanır: Kapalı / Kullanım Sırasında / Her Zaman.
- Ayrı bir anahtar: Hassas Konum.
Neden bir seçici (sadece bir anahtar değil)¶
İşletim sistemi izinleri çok seviyelidir. Uygulama içinde bir seçici sunabiliriz, ancak gerçek yetkilendirmeyi OS belirler.
- iOS/macOS: kullanıcı sistem istemlerinde/Ayarlar’da Kullanım Sırasında veya Her Zaman seçebilir. Uygulama yükseltme isteyebilir, ancak OS Ayarlar’ı gerektirebilir.
- Android: arka plan konumu ayrı bir izindir; Android 10+’ta çoğu zaman bir Ayarlar akışı gerektirir.
- Hassas konum ayrı bir izindir (iOS 14+ “Precise”, Android’de “fine” vs “coarse”).
UI’daki seçici, talep edilen modu belirler; gerçek yetki OS ayarlarında bulunur.
Ayarlar modeli¶
Düğüm cihazı başına:
location.enabledMode:off | whileUsing | alwayslocation.preciseEnabled: bool
UI davranışı:
whileUsingseçildiğinde ön plan izni talep edilir.alwaysseçildiğinde öncewhileUsingsağlanır, ardından arka plan izni istenir (gerekirse kullanıcı Ayarlar’a yönlendirilir).- OS istenen seviyeyi reddederse, verilen en yüksek seviyeye geri dönülür ve durum gösterilir.
İzin eşlemesi (node.permissions)¶
İsteğe bağlıdır. macOS düğümü izinler haritası üzerinden location bildirir; iOS/Android bunu atlayabilir.
Komut: location.get¶
node.invoke aracılığıyla çağrılır.
Parametreler (önerilen):
{
"timeoutMs": 10000,
"maxAgeMs": 15000,
"desiredAccuracy": "coarse|balanced|precise"
}
Yanıt yükü:
{
"lat": 48.20849,
"lon": 16.37208,
"accuracyMeters": 12.5,
"altitudeMeters": 182.0,
"speedMps": 0.0,
"headingDeg": 270.0,
"timestamp": "2026-01-03T12:34:56.000Z",
"isPrecise": true,
"source": "gps|wifi|cell|unknown"
}
Hatalar (sabit kodlar):
LOCATION_DISABLED: seçici kapalı.LOCATION_PERMISSION_REQUIRED: istenen mod için izin eksik.LOCATION_BACKGROUND_UNAVAILABLE: uygulama arka planda ancak yalnızca Kullanım Sırasında izinli.LOCATION_TIMEOUT: zamanında konum alınamadı.LOCATION_UNAVAILABLE: sistem hatası / sağlayıcı yok.
Arka plan davranışı (gelecek)¶
Amaç: model, düğüm arka plandayken bile konum isteyebilsin, ancak yalnızca şu durumlarda:
- Kullanıcı Her Zaman’ı seçtiyse.
- OS arka plan konumunu verdiyse.
- Uygulamanın konum için arka planda çalışmasına izin veriliyorsa (iOS arka plan modu / Android foreground service veya özel izin).
Push tetiklemeli akış (gelecek):
- Gateway düğüme bir push gönderir (sessiz push veya FCM veri).
- Düğüm kısa süreliğine uyanır ve cihazdan konum ister.
- Düğüm yükü Gateway’e iletir.
Notlar:
- iOS: Her Zaman izni + arka plan konum modu gereklidir. Sessiz push kısıtlanabilir; aralıklı başarısızlıklar beklenir.
- Android: arka plan konumu bir foreground service gerektirebilir; aksi halde reddedilmesi beklenir.
Model/araç entegrasyonu¶
- Araç yüzeyi:
nodesaracılocation_geteylemini ekler (düğüm gereklidir). - CLI:
openclaw nodes location get --node <id>. - Ajan yönergeleri: yalnızca kullanıcı konumu etkinleştirdiğinde ve kapsamı anladığında çağırın.
UX metni (önerilen)¶
- Kapalı: “Konum paylaşımı devre dışı.”
- Kullanım Sırasında: “Yalnızca OpenClaw açıkken.”
- Her Zaman: “Arka plan konumuna izin ver. Sistem izni gerektirir.”
- Hassas: “Hassas GPS konumu kullan. Yaklaşık konum paylaşmak için kapatın.”