analyze-permissions

star 113

Analyze accumulated permissions and suggest smart wildcard patterns

haacked By haacked schedule Updated 2/22/2026

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, or cleanup

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:

  1. Project-local: <project-root>/.claude/settings.local.json - accumulated "Always allow" permissions (per-project, not at ~/.claude/)
  2. Global: ~/.claude/settings.json - shared/base permissions managed by the configure script
  3. 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:

  1. Check if already covered - Is there a wildcard in settings.json that covers this?

    • Bash(git commit -m "Fix bug") is covered by Bash(git commit:*)
    • Bash(curl https://api.example.com) is covered by Bash(curl:*)
  2. Identify pattern opportunities - Group similar commands:

    • Multiple kubectl commands → suggest Bash(kubectl:*)
    • Multiple docker commands → suggest Bash(docker:*)
    • Multiple WebFetch for same domain → suggest WebFetch(https://example.com/*)
  3. 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 push for a personal repo)
  4. 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.sh in 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:

  1. Add new entries to the PERMISSIONS_CONFIG JSON array
  2. Add at least one new entry to the validation if statement so the script knows to re-run
  3. Run the script to apply changes: ~/.dotfiles/ai/configure-tool-permissions.sh
  4. 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 tooling
  • Bash(python:*), Bash(python3:*), Bash(pip:*) - Python tooling
  • Bash(cargo :*), Bash(cd :* && cargo:*) - Rust tooling
  • Bash(docker compose:*), Bash(docker ps:*) - Docker
  • Bash(kubectl get:*), Bash(kubectl describe:*) - K8s read operations
  • Bash(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 utilities
  • Bash(ssh:*), Bash(tmux:*), Bash(bash:*), Bash(zsh:*) - shell/system
  • WebFetch(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
Install via CLI
npx skills add https://github.com/haacked/dotfiles --skill analyze-permissions
Repository Details
star Stars 113
call_split Forks 21
navigation Branch main
article Path SKILL.md
More from Creator