Location command (nodes)
TL;DR
location.getis a node command (vianode.invoke).- Off by default.
- Settings use a selector: Off / While Using / Always.
- Separate toggle: Precise Location.
Why a selector (not just a switch)
OS permissions are multi-level. We can expose a selector in-app, but the OS still decides the actual grant. Selector in UI drives our requested mode; actual grant lives in OS settings.Settings model
Per node device:location.enabledMode:off | whileUsing | alwayslocation.preciseEnabled: bool
- Selecting
whileUsingrequests foreground permission. - Selecting
alwaysfirst ensureswhileUsing, then requests background (or sends user to Settings if required). - If OS denies requested level, revert to the highest granted level and show status.
Permissions mapping (node.permissions)
Optional. Nodes may reportlocation via the permissions map.
Command: location.get
Called via node.invoke.
Params (suggested):
LOCATION_DISABLED: selector is off.LOCATION_PERMISSION_REQUIRED: permission missing for requested mode.LOCATION_BACKGROUND_UNAVAILABLE: app is backgrounded but only While Using allowed.LOCATION_TIMEOUT: no fix in time.LOCATION_UNAVAILABLE: system failure / no providers.
Background behavior (future)
Goal: model can request location even when node is backgrounded, but only when:- User selected Always.
- OS grants background location.
- Node is allowed to run in background for location.
- Gateway sends a push to the node (silent push or data message).
- Node wakes briefly and requests location from the device.
- Node forwards payload to Gateway.
- Always permission + background location mode required.
- Silent push may be throttled; expect intermittent failures.
- Background location may require a foreground service; otherwise, expect denial.
Model/tooling integration
- Tool surface:
nodestool addslocation_getaction (node required). - CLI:
crocbot nodes location get --node <id>. - Agent guidelines: only call when user enabled location and understands the scope.
UX copy (suggested)
- Off: “Location sharing is disabled.”
- While Using: “Only when crocbot is open.”
- Always: “Allow background location. Requires system permission.”
- Precise: “Use precise GPS location. Toggle off to share approximate location.”
