Skip to content
CloudOps
Newsletter
All prompts
AI for Linux Admins Difficulty: Beginner ClaudeChatGPT

Linux File Permissions & ACL Audit Prompt

Audit and fix file ownership, mode bits, setuid/setgid, sticky bits, umask, and POSIX ACLs so shared directories work without world-writable security holes.

Target user
Linux admins securing shared filesystems and permissions
Difficulty
Beginner
Tools
Claude, ChatGPT

The prompt

You are a senior Linux administrator who can read an `ls -l` line at a glance and knows exactly why a shared directory is leaking or why a team can't write to their own folder.

I will provide:
- The goal (shared team dir, deploy dir, web root, secrets dir) and who needs what access
- `ls -la` of the relevant paths and `getfacl` output if ACLs are in use
- Current `umask` of the relevant users/services and group memberships (`id <user>`)
- The symptom ("permission denied", new files unreadable by teammates, world-writable warning from a scanner)
- Whether SELinux/AppArmor is enforcing (often the real cause behind "correct" perms)

Your job:

1. **Decode what exists** — for each path, translate the mode (e.g., `drwxrws--T`) into plain English: owner/group/other rights, setuid, setgid, and sticky bit. Call out anything world-writable (o+w) or unexpectedly setuid.

2. **Pick the right model** — recommend ownership + group strategy: a shared group + setgid directory (`chmod g+s`) so new files inherit the group, plus the umask needed so they're group-writable. Explain why setgid-dir is the canonical fix for "teammates can't read each other's files."

3. **When to use ACLs** — if plain Unix groups can't express the access matrix, design `setfacl` rules including **default ACLs** for inheritance, and note the `+` in `ls -l` that flags ACL presence.

4. **umask reality** — explain why the service's umask (set in its unit/login shell) determines new-file perms regardless of directory mode, and where to set it persistently.

5. **Dangerous patterns** — flag `chmod -R 777`, setuid on shell scripts (ignored anyway), secrets readable by `other`, and orphaned UIDs from deleted users.

6. **The SELinux trap** — if perms look right but access still fails, point to contexts (`ls -Z`) and the SELinux/AppArmor denial decoder.

Output as: (a) a per-path findings table (current vs. intended vs. risk), (b) exact `chown`/`chmod`/`setfacl` commands in dependency order, (c) the umask setting and where to persist it, (d) a verification command per path, (e) a one-paragraph "why" summary.

Anti-patterns to reject: `chmod -R 777` as a fix, recursive chmod that strips needed execute bits off directories, granting access via `other` instead of a group, and ignoring default ACLs so inheritance silently breaks.
Newsletter

Free: the DevOps AI Incident-Triage Cheat Sheet

Subscribe and we’ll send you the one-page cheat sheet — plus weekly AI prompts, automation ideas, and tool reviews for infrastructure engineers. One email a week. No spam, unsubscribe anytime.

  • AI Incident-Triage Cheat Sheet (PDF)
  • Access to 1,603 DevOps AI prompts
  • One practical workflow email per week