peekaboo permissions
May 31, 2026 · View on GitHub
peekaboo permissions centralizes entitlement checks. The default status subcommand reports the runtime view of Screen Recording, Accessibility, and Event Synthesizing. grant prints the same table plus human-readable steps so you can fix issues without hunting through docs.
Subcommands
| Name | Purpose |
|---|---|
status (default) | Fetches the current permission set and prints each entry (granted, denied, etc.). Honors --json so agents can block proactively. Add --all-sources to compare Bridge and local CLI permissions side by side. |
grant | Reuses the same snapshot but focuses on remediation: when in text mode it prints the exact System Settings pane/location for each missing entitlement. |
request-event-synthesizing | Triggers the macOS Event Synthesizing prompt needed by background input such as default click, type, hotkey, press, and paste delivery. With the default remote runtime it requests the permission for the selected bridge host; use --no-remote to request it for the local CLI process. |
Implementation notes
- All subcommands conform to
RuntimeOptionsConfigurable, so they inherit global--json/--verboseflags even when invoked from compound commands likepeekaboo learn. - The command executes entirely on the main actor, avoiding extra prompts or sandbox warnings—the same code path runs at CLI startup to warn if entitlements are missing.
- JSON mode uses
outputSuccessCodable, which means status results include apermissionsarray with{name, isRequired, isGranted, grantInstructions}entries that can be diffed over time. --all-sources --jsonreturns{selectedSource, sources}so callers can distinguish Bridge TCC grants from local CLI grants.
Examples
# Quick sanity check before running UI automation
peekaboo permissions
# Feed the status into an agent to ensure entitlements are set
peekaboo permissions --json | jq '.data.permissions[] | select(.isGranted == false)'
# Compare Bridge and local CLI TCC state
peekaboo permissions status --all-sources
# Hand someone clear remediation steps
peekaboo permissions grant
# Request Event Synthesizing for background input
peekaboo permissions request-event-synthesizing
Troubleshooting
- Verify Screen Recording + Accessibility permissions (
peekaboo permissions status). - Check the printed
Source:line. If it saysPeekaboo Bridge, the status reflects the selected host app's TCC grants. Grant Screen Recording to that host, or force local capture with--no-remote --capture-engine cgwhen the caller process already has permission. - Confirm your target (app/window/selector) with
peekaboo list/peekaboo seebefore rerunning. - Re-run with
--jsonor--verboseto surface detailed errors.