name: analyze-permissions description: Analyze accumulated permissions and suggest smart wildcard patterns argument-hint: [analyze|apply|cleanup] disable-model-invocation: true model: sonnet
Analyze Claude Code Permissions
Analyze accumulated permissions in settings.local.json and suggest smart wildcard patterns to add to the shared configuration.
Arguments (parsed from user input)
- action: What to do -
analyze(default),apply, orcleanup
Example invocations:
/analyze-permissions→ analyze and suggest patterns/analyze-permissions apply→ apply suggested patterns to shared config/analyze-permissions cleanup→ just run the cleanup script
Your Task
Step 1: Read Current Permissions
Read these files:
- Project-local:
<project-root>/.claude/settings.local.json- accumulated "Always allow" permissions (per-project, not at~/.claude/) - Global:
~/.claude/settings.json- shared/base permissions managed by the configure script - Configure script:
~/.dotfiles/ai/configure-tool-permissions.sh- canonical source for global permissions
Note: settings.local.json is project-specific. Each repo has its own at <repo>/.claude/settings.local.json. The global ~/.claude/settings.json is shared across all projects.
Step 2: Analyze Patterns
For each entry in settings.local.json:
Check if already covered - Is there a wildcard in
settings.jsonthat covers this?Bash(git commit -m "Fix bug")is covered byBash(git commit:*)Bash(curl https://api.example.com)is covered byBash(curl:*)
Identify pattern opportunities - Group similar commands:
- Multiple
kubectlcommands → suggestBash(kubectl:*) - Multiple
dockercommands → suggestBash(docker:*) - Multiple WebFetch for same domain → suggest
WebFetch(https://example.com/*)
- Multiple
Decide global vs local - Where should the pattern live?
- Global (configure script): General-purpose tools used across projects (
npx,python,docker compose, etc.) - Local (settings.local.json): Project-specific commands, or write operations you only want for that project (e.g.,
git pushfor a personal repo)
- Global (configure script): General-purpose tools used across projects (
Assess safety - Consider if the pattern is safe for auto-approval:
- Read-only commands: Generally safe
- Commands with side effects: Flag for review
- Overly broad patterns: Warn about security implications
Step 3: Present Analysis
Output a structured report:
## Permission Analysis
### Settings Overview
- settings.local.json: X entries
- settings.json: Y entries (Z wildcards)
### Already Covered (can be removed)
These entries in settings.local.json are redundant:
| Entry | Covered by |
|-------|------------|
| Bash(git commit -m "...") | Bash(git commit:*) |
### Suggested New Patterns
These patterns would consolidate multiple specific entries:
| Pattern | Covers | Safety |
|---------|--------|--------|
| Bash(kubectl:*) | 4 entries | ✅ Safe (read-heavy) |
| Bash(docker exec:*) | 3 entries | ⚠️ Review (can modify) |
### Uncategorized
These entries don't fit a pattern (one-offs):
- Bash(some-specific-command)
Step 4: Handle Actions
Based on the action argument:
analyze (default):
- Present the report
- Ask if user wants to apply suggestions
apply:
- For each suggested pattern, ask for confirmation
- Add approved patterns to
configure-tool-permissions.shin the PERMISSIONS_CONFIG section - Run the cleanup script to remove now-redundant entries
cleanup:
- Just run
~/.claude/skills/analyze-permissions/scripts/cleanup-settings-local.sh
Step 5: Update Shared Config (if applying)
When adding patterns to configure-tool-permissions.sh:
- Add new entries to the
PERMISSIONS_CONFIGJSON array - Add at least one new entry to the validation
ifstatement so the script knows to re-run - Run the script to apply changes:
~/.dotfiles/ai/configure-tool-permissions.sh - Run cleanup to remove now-redundant entries from the current project's local settings:
~/.dotfiles/ai/skills/analyze-permissions/scripts/cleanup-settings-local.sh
Important: The configure script merges new entries into settings.json but never removes existing ones. This means settings.json also accumulates "don't ask again" entries over time. The cleanup script only cleans settings.local.json. To fully clean settings.json, you'd need to manually remove redundant entries or rebuild it from the script.
Pattern Safety Guidelines
Safe to auto-approve (commonly needed):
Bash(npx:*),Bash(node:*),Bash(npm:*),Bash(pnpm:*)- JS/Node toolingBash(python:*),Bash(python3:*),Bash(pip:*)- Python toolingBash(cargo :*),Bash(cd :* && cargo:*)- Rust toolingBash(docker compose:*),Bash(docker ps:*)- DockerBash(kubectl get:*),Bash(kubectl describe:*)- K8s read operationsBash(git:*)subcommands (add, commit, log, diff, etc.)Bash(gh:*)read operations (pr view, issue list, api, etc.)Bash(chmod:*),Bash(ln:*),Bash(wc:*),Bash(which:*)- basic utilitiesBash(ssh:*),Bash(tmux:*),Bash(bash:*),Bash(zsh:*)- shell/systemWebFetch(domain:*),WebSearch- web access
Require review (side effects):
Bash(kubectl delete:*),Bash(kubectl apply:*)Bash(docker rm:*),Bash(docker exec:*)Bash(aws s3 rm:*)Bash(rm:*),Bash(mv:*)Bash(git push:*)- consider keeping per-project in local settings
Never auto-approve:
Bash(sudo:*)Bash(chmod 777:*)- Patterns that could leak secrets