{{Header}}
{{title|title=
sudo / doas / sudoless
}}
{{#seo:
|description=sudo replacement development considerations - doas / sudoless
}}
{{devwiki}}
{{intro|
sudo replacement development considerations - doas / sudoless
}}
= Changes =
* based on https://forums.whonix.org/t/replace-sudo-with-doas/17482/18
* removed commented out
* removed resolved cases
= goals =
* sudoless
= non-goals =
* doas
= List =
== kicksecure/live-config-dist/etc/sudoers.d/live-config-dist
==
* doas:
** More commands with nopasswd
exceptions.
* sudoless:
** start calamares only in sysmaint (form sysmaint-panel) or in unrestricted admin mode
== kicksecure/sdwdate/etc/sudoers.d/sdwdate
==
* doas:
** This one's a problem. Whereas the previous files provide nopasswd
exceptions to specific users and groups, this file allows *anyone* to run /usr/sbin/sdwdate-clock-jump
as root. doas lacks the ability to express a universal exception such as this, you can only grant exceptions to specific users or groups. The only files that actually attempt to use sdwdate-clock-jump
via sudo are:
*** kicksecure/sdwdate-gui/usr/lib/python3/dist-packages/sdwdate_gui/sdwdate_gui.py
*** kicksecure/sdwdate-gui/usr/lib/python3/dist-packages/sdwdate_gui/sdwdate_gui_qubes.py
*** kicksecure/sdwdate-gui/etc/qubes-rpc/whonix.GatewayCommand
** It's likely that all of these can be coped with by using doas's configuration by simply determining the users or groups these run as, and adding them to the configuration file. Adding the users
group to the config would also be advisable as Debian's adduser
tool will automatically add new "standard" user accounts to this group. Unfortunately useradd
doesn't do this, but the end-user can probably resolve this themselves if they so choose.
*** ALL ALL=NOPASSWD: /usr/sbin/sdwdate-clock-jump
** Translates roughly to:
*** permit nopass :users cmd /usr/sbin/sdwdate-clock-jump
* sudoless:
** Use capabilities?
** OR don't allow user to set the clock? Tell users to boot into sysmaint mode instead?
== kicksecure/sdwdate-gui/etc/sudoers.d/sdwdate-gui
==
* doas:
** User-specific nopasswd
exceptions for specific commands. Easy to translate.
* sudoless:
** Same as above.
== kicksecure/security-misc/etc/sudoers.d/security-misc
==
* doas:
** One user-specific and one group-specific nopasswd
exception, easily translatable.
* sudoless:
** Could be re-implemented using a .done
file and systemd unit files.
== kicksecure/setup-dist/etc/sudoers.d/setup-dist
==
* doas:
** Simple group-specific nopasswd
exception, easily translatable.
* sudoless:
** setup-dist does not do much anymore anyhow. The done file could be moved to user home location.
== kicksecure/systemcheck/etc/sudoers.d/systemcheck
==
* doas:
** Complex, but looks doable. Many user-specific nopasswd
exceptions, however some of these are targeted to allow the user to execute a command as another user *other than root*. Thankfully doas supports this.
*** user ALL=(sdwdate) NOPASSWD: /usr/libexec/helper-scripts/onion-time-pre-script
** Translates to:
*** permit nopass user as sdwdate cmd /usr/libexec/helper-scripts/onion-time-pre-script
* sudoless:
** Only sysmaint would be able to run systemcheck.
== kicksecure/tb-starter/etc/sudoers.d/tb-starter
==
* doas:
** A user-specific nopasswd
exception with some environment variable allowances. Can be handled using techniques mentioned earlier.
* sudoless:
** Could be re-implemented using systemd unit files and/or Debian maintainer scripts.
== kicksecure/tb-updater/etc/sudoers.d/tpo-downloader
==
* doas:
** More user- and group-specific nopasswd
exceptions. Easily translatable.
* sudoless:
** Same as above.
== kicksecure/usability-misc/etc/sudoers.d/upgrade-passwordless
==
* doas:
** Group-specific nopasswd
exception, easily translatable.
* sudoless:
** Only sysmaint should be able to run upgrade-nonroot.
== whonix/anon-gw-anonymizer-config/etc/sudoers.d/anonymizer-config-gateway
==
* doas:
** More user-specific nopasswd
exceptions. Easily translatable.
* sudoless:
** Whonix issue only. Not a Kicksecure issue. Whonix-Gateway could always boot into unrestricted admin mode?
== /etc/sudoers.d/qt_x11_no_mitshm
==
* doas:
** Specifies an environment variable to be preserved that affects all utilities on the system that leverage Qt. Depending on how exactly this rule is used, this could be trivial to translate, or it could be slightly tricky.
*** Defaults env_keep += "QT_X11_NO_MITSHM"
** Translates to (roughly):
*** permit setenv { QT_X11_NO_MITSHM } :sudo
* sudoless:
** Only user "sysmaint".
== /etc/sudoers.d/qubes
==
* doas:
** This looks like a generic account-wide nopasswd
exception for the qubes
group. There's some SELinux stuff going on with it that can't be ported, but since Kicksecure is based on Debian, I don't expect this to be a problem (I don't believe SELinux is even *used* in Whonix or other Debian-based Qubes).
* sudoless:
** Not an issue since also not an issue for doas.
== /etc/sudoers.d/qubes-input-trigger
==
* doas:
** Contains several NOPASSWD
exceptions for starting various Qubes input-related services as root. There are four sets of nine services each, each set is handled by one line of sudoers config, which covers all nine services with the help of a regex match. We don't get regex matching in doas, so this would have to be replaced with 36 lines of doas configuration. Not great, but not horrible.
*** user ALL=(root) NOPASSWD:/bin/systemctl --no-block start qubes-input-sender-keyboard@event[0-9].service
** Translates to:
*** permit nopass user as root cmd /bin/systemctl args --no-block start qubes-input-sender-keyboard@event0.service
, plus eight more lines with event1.service
, event2.service
, etc.
* sudoless:
** TODO
== /etc/sudoers.d/umask
==
* doas:
** Trouble. This one changes umask settings for sudo commands in general. doas handles umask configuration entirely on its own and does not allow the end-user to configure it. Thus this cannot be translated. Depending on what doas's umask settings are and how vital this configuration is, this may or may not be a blocker.
* sudoless:
** TODO
== pkexec ==
* sudoless:
** List of affected applications summarized from https://forums.whonix.org/t/cannot-use-pkexec/8129 already:
*** gdebi -> use sysmaint
*** synaptic -> use sysmaint
*** partition manager -> use sysmaint
*** xfce auto mounter -> TODO
** Only sysmaint should be able to use pkexec?
{{Footer}}