Geht wählen! Am 26. September 2021 ist Bundestagswahl in Deutschland, wählt Annalena Baerbock für zukunftssichere Klima-, Digital- und Sozialpolitik.. Mehr infos zum Wahlprogramm auf 🗳💚🌻

Gotcha: Dots in /etc/sudoers.d filenames

A tale of facepalms

Written by Kevin Gimbel on , 🍿 1 min. read

While reviewing some Ansible modules with a colleague we stumbled upon an issue with our user creation module, and for a briefe time couldn't understand what was going on.

The module in question creates multiple Linux users, adds them to groups, and enables some to use password less sudo via the /etc/sudoers.d config directory. For some reasons after we logged in with the newly created users, they were not able to use sudo without entering passwords.

We checked the directory and all files were there, just as expected. The content of the files was also OK for every user, yet none could use sudo without entering a password.

After some time I wondered if the dot in the filename may be the problem, since the files were named like passwordless_sudo_kevin.gimbel but this couldn't be it, right? Wrong. That's the problem, quote from the sudo man page:

sudo will read each file in /etc/sudoers.d, skipping file names that end in ‘~’ or contain a ‘.’ character to avoid causing problems with package manager or editor temporary/backup files.

And that's why sudo config files cannot contain dots. Questionable, but that's how it is. 🤷

Our solution was to strip out any dots using regex, since the Ansible role can potentially support any amount of users and we cannot control what names will be used.

Hi, I'm Kevin!

I'm a DevOps Engineer with a focus on automation and security. Before shifting into DevOps and cloud computing I worked as Front-End Developer, which is still a hobby and field of interest for me.

Hand-made vector avatar of Kevin Gimbel

I'm very passionated about a variety of games - digital, boardgames, and pen & paper; and also interested in Sci-Fi, Cyberpunk, and dystopian books. You can find out more on the about page.