AugmentClaude

Permissions Analyzer

Analyze permissions and suggest wildcard patterns to optimize access settings.

Installation

  1. Make sure Claude is on your device and in your terminal.

    Skills load from ~/.claude/skills/ when Claude Code starts up — so you need it on your machine first. If you don't have it yet, install it once with the command below, then run claude in any terminal to verify.

    One-time setup
    npm i -g @anthropic-ai/claude-code

    Already have it? Skip ahead.

  2. Paste into Claude Code or into your terminal.

    This copies the whole skill folder into ~/.claude/skills/analyze-permissions-haacked/ — the SKILL.md plus any scripts, reference docs, or templates the skill ships with. Safe default: works for every skill.

    Faster alternative (instruction-only skills)

    Skips the clone and grabs only the SKILL.md file. Don't use this if the skill ships Python scripts, reference markdowns, or asset templates — they won't be downloaded and the skill will fail when it tries to load them.

    Quick install (SKILL.md only)
    Sign up to copy
  3. Restart Claude Code.

    Quit and reopen Claude Code (or any other agent that loads from ~/.claude/skills/). New skills are picked up on startup.

  4. Just ask Claude.

    Skills auto-activate when your request matches the skill's description — no slash command needed. Trigger phrases live in the skill's own frontmatter; you can read them in the “What this skill does” section above.

Prefer to read the source first? Open on GitHub.

When Claude uses it

Analyze accumulated permissions and suggest smart wildcard patterns

What this skill does

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

Related skills