nixos/polkit: remove root from adminIdentities

Fixes https://github.com/NixOS/nixpkgs/issues/75075.

To summarize the report in the aforementioned issue, at a glance,
it's a different default than what upstream polkit has. Apparently
for 8+ years polkit defaults admin identities as members of
the wheel group [0]. This assumption would be appropriate on NixOS, where
every member of group 'wheel' is necessarily privileged.

[0]: 763faf434b
This commit is contained in:
worldofpeace 2019-12-09 01:38:33 -05:00
parent 5bd1bd08ed
commit efc1c027ad
2 changed files with 12 additions and 3 deletions

View File

@ -225,6 +225,16 @@
The fourStore and fourStoreEndpoint modules have been removed. The fourStore and fourStoreEndpoint modules have been removed.
</para> </para>
</listitem> </listitem>
<listitem>
<para>
Polkit no longer has the user of uid 0 (root) as an admin identity.
We now follow the upstream default of only having every member of the wheel
group admin privileged. Before it was root and members of wheel.
The positive outcome of this is pkexec GUI popups or terminal prompts
will no longer require the user to choose between two essentially equivalent
choices (whether to perform the action as themselves with wheel permissions, or as the root user).
</para>
</listitem>
</itemizedlist> </itemizedlist>
</section> </section>

View File

@ -42,15 +42,14 @@ in
security.polkit.adminIdentities = mkOption { security.polkit.adminIdentities = mkOption {
type = types.listOf types.str; type = types.listOf types.str;
default = [ "unix-user:0" "unix-group:wheel" ]; default = [ "unix-group:wheel" ];
example = [ "unix-user:alice" "unix-group:admin" ]; example = [ "unix-user:alice" "unix-group:admin" ];
description = description =
'' ''
Specifies which users are considered administrators, for those Specifies which users are considered administrators, for those
actions that require the user to authenticate as an actions that require the user to authenticate as an
administrator (i.e. have an <literal>auth_admin</literal> administrator (i.e. have an <literal>auth_admin</literal>
value). By default, this is the <literal>root</literal> value). By default, this is all users in the <literal>wheel</literal> group.
user and all users in the <literal>wheel</literal> group.
''; '';
}; };