Systemd, de fato, lidar com o shutdown
, reboot
e outros comandos, e os privilégios padrão atribuídas são permissivos. Para mudar isso, você precisa criar uma regra do Polkit. Crie um .pkla
arquivo /etc/polkit-1/localauthority/50-local.d
(digamos confirm-shutdown.pkla
) contendo:
[Confirm shutdown]
Identity=unix-user:*
Action=org.freedesktop.login1.*
ResultActive=auth_admin_keep
Os vários desligar, reiniciar, etc. comandos são, em termos polkit, ações em org.freedesktop.login1
, por exemplo, org.freedesktop.login1.power-off
, org.freedesktop.login1.reboot
, etc. O problema específico aqui é a configuração padrão, que é em /usr/share/polkit-1/actions/org.freedesktop.login1.policy
:
<action id="org.freedesktop.login1.power-off">
<description>Power off the system</description>
...
<defaults>
<allow_any>auth_admin_keep</allow_any>
<allow_inactive>auth_admin_keep</allow_inactive>
<allow_active>yes</allow_active>
</defaults>
Observe que ele permite que o usuário ativo desligue, reinicie etc.
pkaction | grep login1
para outras regras de interesse)