Location command for nodes (location.get), permission modes, and background behavior

Read when…
  • Adding location node support or permissions UI
  • Designing background location + push flows

位置命令 (节点)

概述

  • location.get 是一个节点命令(通过 node.invoke)。
  • 默认关闭。
  • 设置使用选择器:关闭 / 使用中 / 始终。
  • 单独开关:精确位置。

为什么使用选择器(而不是简单的开关)

操作系统权限是多级的。我们可以在应用中暴露一个选择器,但最终的授权由操作系统决定。

  • iOS/macOS: 用户可以在系统提示/设置中选择 使用中始终。应用可以请求升级,但操作系统可能需要用户进入设置。
  • Android: 后台位置是一个单独的权限;在 Android 10+ 上,它通常需要一个设置流程。
  • 精确位置是一个单独的授权(iOS 14+ “精确”,Android “精细” 对比 “粗略”)。

UI 中的选择器驱动我们的请求模式;实际授权存在于操作系统设置中。

设置模型

每个节点设备:

  • location.enabledMode: off | whileUsing | always
  • location.preciseEnabled: bool

UI 行为:

  • 选择 whileUsing 请求前台权限。
  • 选择 always 首先确保 whileUsing,然后请求后台(如果需要,将用户发送到设置)。
  • 如果操作系统拒绝请求的级别,则回退到最高已授予权限并显示状态。

权限映射 (node.permissions)

可选。macOS 节点通过权限映射报告 location;iOS/Android 可能省略它。

命令: location.get

通过 node.invoke 调用。

参数(建议):

{
  "timeoutMs": 10000,
  "maxAgeMs": 15000,
  "desiredAccuracy": "coarse|balanced|precise"
}

响应负载:

{
  "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"
}

错误(稳定代码):

  • LOCATION_DISABLED: 选择器关闭。
  • LOCATION_PERMISSION_REQUIRED: 请求模式缺少权限。
  • LOCATION_BACKGROUND_UNAVAILABLE: 应用处于后台但仅允许“使用中”。
  • LOCATION_TIMEOUT: 无法及时修复。
  • LOCATION_UNAVAILABLE: 系统故障 / 无提供者。

后台行为(未来)

目标:即使节点处于后台,模型也可以请求位置,但仅当:

  • 用户选择了 始终
  • 操作系统授予后台位置权限。
  • 应用被允许在后台运行以获取位置(iOS 后台模式 / Android 前台服务或特殊许可)。

推送触发流程(未来):

  1. 网关向节点发送推送(静默推送或 FCM 数据)。
  2. 节点短暂唤醒并从设备请求位置。
  3. 节点将负载转发给网关。

注意:

  • iOS: 需要“始终”权限 + 后台位置模式。静默推送可能会被限制;预期会出现间歇性失败。
  • Android: 后台位置可能需要前台服务;否则,预期会被拒绝。

模型/工具集成

  • 工具界面: nodes 工具添加 location_get 动作(需要节点)。
  • CLI: openclaw nodes location get --node <id>
  • 代理指南:仅在用户启用位置并理解范围时调用。

用户体验文案(建议)

  • 关闭: “位置共享已禁用。”
  • 使用中: “仅当 OpenClaw 打开时。”
  • 始终: “允许后台位置。需要系统权限。”
  • 精确: “使用精确 GPS 位置。关闭以共享近似位置。”