Edit the sudoers file.
## user is allowed to execute halt and reboot
whateverusername ALL=NOPASSWD: /sbin/halt, sbin/reboot, /sbin/poweroff
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
Edit the sudoers file.
## user is allowed to execute halt and reboot
whateverusername ALL=NOPASSWD: /sbin/halt, sbin/reboot, /sbin/poweroff
Just make sure to use visudo
Indeed
The relevant polkit policies should be defined here: https://github.com/systemd/systemd/blob/main/src/login/org.freedesktop.login1.policy
Disabling is done with some rules like this: https://bbs.archlinux.org/viewtopic.php?id=152565
polkit.addRule(function(action, subject) {
if (action.id.indexOf("org.freedesktop.login1.power-off") == 0) {
return polkit.Result.AUTH_ADMIN;
}
});
Some other examples: https://gist.github.com/grawity/3886114
Thank you, it works! But I got weird behavior:
systemctl restart sddm
from tty and it will work again)
How can I fix this bugs?Sorry, I have no idea.
SDDM main process is running as root and ignores all policies. So only way is modifying SDDM source code(
What if you try another interface, like shutdown -P now
or poweroff -p
?
They all operates some way through systemd, so if operation is disabled via policy you cannot bypass it.
sasha@fedora:~$ /sbin/halt
Call to Halt failed: Interactive authentication required.
What about systemctl poweroff
?
Well, the logic in polkit is, if you have direct physical access to the machine (not SSH, actual keyboard, and so on), in general nothing stops you from just pressing and holding the power button. So giving a local user the right doesn't make worse.
To disable the behaviour you need to find the appropriate polkit rule in /usr/{lib,share}/polkit-1/rules.d
and create a file with the same name in /etc/polkit-1/rules.d
pointing to /dev/null
.