SUDO / SUDOERS / VISUDO
- In this exercise a Linux Debian server is used:
data:image/s3,"s3://crabby-images/de52f/de52fa3e344ad065233e74f79c30e758150b007f" alt=""
1 - Introduction
- sudo is a program for Unix-like computer operating systems that allows users to run programs with the security privileges of another user, by default the superuser.
- It originally stood for "superuser do" as the older versions of sudo were designed to run commands only as the superuser.
- However, the later versions added support for running commands not only as the superuser but also as other (restricted) users, and thus it is also commonly expanded as "substitute user do".
- Unlike the similar command su, users must, by default, supply their own password for authentication, rather than the password of the target user.
- After authentication, and if the configuration file, which is typically located at /etc/sudoers, permits the user access, the system invokes the requested command.
- The configuration file sudoers offers detailed access permissions, including enabling commands only from the invoking terminal; requiring a password per user or group; requiring re-entry of a password every time or never requiring a password at all for a particular command line. It can also be configured to permit passing arguments or multiple commands.
https://en.wikipedia.org/wiki/sudo
- Installing sudo (in case it is not already installed by default):
data:image/s3,"s3://crabby-images/3cebb/3cebb46a7722bf62074cf33ba903a8e22f88561c" alt=""
- Properties of sudo:
data:image/s3,"s3://crabby-images/e1102/e110204b3bf117ae3b95d127e908cc1451011f0d" alt=""
data:image/s3,"s3://crabby-images/3d168/3d168d7de0787c1b4c5b0c6ef82f70d14906eea4" alt=""
- visudo is a command-line utility that allows editing the configuration file sudoers in a fail-safe manner.
- It prevents multiple simultaneous edits with locks and performs sanity and syntax checks.
data:image/s3,"s3://crabby-images/55379/55379104496c6b8873befb18edba78948190ba11" alt=""
data:image/s3,"s3://crabby-images/4b0d8/4b0d8385e071e9898ba01c7b00f39bbd9368dd17" alt=""
data:image/s3,"s3://crabby-images/5eaf3/5eaf3b19c8944627bf8c7154e59036a6ae8773be" alt=""
data:image/s3,"s3://crabby-images/b39c3/b39c37136d39e702f7aa4b9616fee7201e96b8ee" alt=""
- In my Debian system visudo opens nano editor by default, but it could be changed to another preferred editor:
data:image/s3,"s3://crabby-images/b2c3d/b2c3d4084c2d3c249fafa79dd283a28c949d8873" alt=""
2 - Editing "sudoers" for users
- Editing sudoers and adding a configuration line for the user roch:
data:image/s3,"s3://crabby-images/cb1c2/cb1c2769c0d6ce4235cab8be4069595e643cfffd" alt=""
data:image/s3,"s3://crabby-images/343d1/343d1bb2baf63d4fcb0468e25e3b14b35eec00f1" alt=""
- If sudo is not used roch cannot perform the apt-get update command:
data:image/s3,"s3://crabby-images/ccf4d/ccf4debc97f6a46f8b20b641488590fd6a801181" alt=""
- However, now with the new line added to the file sudoers, the command sudo allows roch to update the system:
data:image/s3,"s3://crabby-images/41ca9/41ca9d5d3e240828633560f530a9aebef69ff8af" alt=""
- Adding another line for the user johndoe. For instance in this example johndoe will be allowed to reload the Apache server:
data:image/s3,"s3://crabby-images/777c9/777c9eb193d5d5274095eea45f92332678a75c79" alt=""
- Going to the johndoe user account:
data:image/s3,"s3://crabby-images/fd6d9/fd6d9f24a5ce98b1127b13d513f4b7aa40fbd584" alt=""
- When trying to reload Apache without sudo it fails:
data:image/s3,"s3://crabby-images/049b3/049b3ae1674cf367add1120ba54add257837e887" alt=""
- Using sudo it works:
data:image/s3,"s3://crabby-images/6ba39/6ba396ea1593bfa9878945821d5847ce1853e655" alt=""
3 - Editing "sudoers" for groups
- Creating the group team:
data:image/s3,"s3://crabby-images/81d9c/81d9cd7768325e3b15f79cef9fd937019fd16905" alt=""
- Adding the user johndoe to the group team:
data:image/s3,"s3://crabby-images/1ce3a/1ce3a3a458fad21268f68e92239c3a93ab129aa5" alt=""
- Checking that the group team has been correctly created:
data:image/s3,"s3://crabby-images/84223/842231fe085b762820f66ac307a4c13bed5665b0" alt=""
data:image/s3,"s3://crabby-images/a24a3/a24a3f1cf8643670f0a3b5df6c3e0ce3fa23779b" alt=""
- Editing sudoers, let's add a line for the group team, allowing its members to update the system without using any password (NOPASSWD option):
data:image/s3,"s3://crabby-images/be5c2/be5c2588c230ed1b6e03e2745daad2d6f4147bf0" alt=""
data:image/s3,"s3://crabby-images/b9522/b95225362b5a547645a1e6dcdaf8a3ac18aa3de9" alt=""
- Going back to jonhdoe (member of the group team):
data:image/s3,"s3://crabby-images/cf490/cf490468724bbf1d487b7a5c54d25b123951b390" alt=""
- Not allowed updating without sudo:
data:image/s3,"s3://crabby-images/60ece/60ece64da68fb2526547776aa53642f20d2c25ae" alt=""
- However updating is successful for johndoe with sudo:
data:image/s3,"s3://crabby-images/52b09/52b096adac377990b1111e3f6f263428f9371524" alt=""
4 - Editing "sudoers" for alias
- Editing sudoers and i) creating the group alias TEAMER , ii) adding johndoe:
data:image/s3,"s3://crabby-images/99ad9/99ad9d0175ffd86cbe016e198e2fdf22e8911fd0" alt=""
data:image/s3,"s3://crabby-images/4c421/4c4211513f99f1bafd5df90a8aadb0ba26961521" alt=""
- Adding the command alias ON_OFF for both reboot and shutdown commands:
data:image/s3,"s3://crabby-images/f81be/f81be3b224ddf4856ab9200d27bbc6372bd8e36f" alt=""
- Assigning ON_OFF to TEAMER:
data:image/s3,"s3://crabby-images/9fe76/9fe76a199d252270f63d0cfa676df107cb83d9b8" alt=""
- Going back to johndoe:
data:image/s3,"s3://crabby-images/8922f/8922f61f021ed90e49c968d25ff2e62df81e18c9" alt=""
- Now johndoe can reboot the system successfully:
data:image/s3,"s3://crabby-images/5a0c5/5a0c5735cca01f71e7b292b1ece0f3012a48358e" alt=""
data:image/s3,"s3://crabby-images/e6e24/e6e243a6c5625abd6cd37f36650dfc6d6e9054fe" alt=""
5 - Checking sudo configurations for users
- The sudo command with options (-l = list, -U = users) allows to consult the list of allowed/forbidden command for each user:
data:image/s3,"s3://crabby-images/710ae/710ae9abbbdde6c8ecf0cb4d1297a9ecb7082674" alt=""
- Let's see some examples, like users root and johndoe who are part of the sudoers file:
data:image/s3,"s3://crabby-images/43b5f/43b5fe6d886058e72e34c4e735babd08738acab3" alt=""
data:image/s3,"s3://crabby-images/45b6e/45b6e61accec1aab30adb47be9374906a24f7eaa" alt=""
- If the user is not part of the sudoers file, like marie:
data:image/s3,"s3://crabby-images/17e70/17e70de06ff587679c8319ab5123a527ed19b3e4" alt=""