move fingerprint settings to a module
Signed-off-by: ahuston-0 <aliceghuston@gmail.com>
This commit is contained in:
parent
d293c28145
commit
3ca5051fc9
64
modules/pam-fingerprint-swap.nix
Normal file
64
modules/pam-fingerprint-swap.nix
Normal file
@ -0,0 +1,64 @@
|
||||
{
|
||||
config,
|
||||
lib,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
|
||||
# borrowed from https://github.com/NixOS/nixpkgs/issues/171136
|
||||
# and https://wiki.archlinux.org/title/fprint#Login_configuration
|
||||
# and also this internal/experimental feature:
|
||||
# https://github.com/NixOS/nixpkgs/pull/255547
|
||||
#
|
||||
# This should allow fprintd to go after pam_unix (so it asks for your password first!)
|
||||
let
|
||||
cfg = config.security.pam.fprintd-order;
|
||||
in
|
||||
{
|
||||
options = {
|
||||
security.pam.fprintd-order = {
|
||||
enable = lib.mkEnableOption "fprintd-order";
|
||||
order = lib.mkOption {
|
||||
type = lib.types.int;
|
||||
default = 11501;
|
||||
description = ''
|
||||
the ordering for fprintd used in pam.d service files.
|
||||
11300 is the current default as of 2024-04-02 (subject to change with auto-ordering rules)
|
||||
11501 places it just after pam_unix (ie. password prompt, then fingerprint)
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf (cfg.enable) {
|
||||
|
||||
# to generate this its going to look something like this
|
||||
# rg "fprintd" --follow /etc/pam.d | sed -nr 's/\/etc\/pam.d\/(\w+)/\1/p' | cut -d ':' -f 1 | awk '{printf "security.pam.services.%s.rules.auth.fprintd.order=11501;\n",$1}'
|
||||
|
||||
# need to check if this one is needed... file doesnt exist when this module is disabled
|
||||
#security.pam.services.auth.rules.auth.fprintd.order = cfg.order;
|
||||
|
||||
security.pam.services.passwd.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.chpasswd.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.groupdel.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.groupadd.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.useradd.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.i3lock.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.systemd-user.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.sudo.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.userdel.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.chfn.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.su.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.usermod.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.groupmems.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.chsh.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.i3lock-color.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.xscreensaver.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.xlock.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.polkit-1.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.vlock.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.runuser-l.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.groupmod.rules.auth.fprintd.order = cfg.order;
|
||||
security.pam.services.runuser.rules.auth.fprintd.order = cfg.order;
|
||||
};
|
||||
}
|
@ -4,40 +4,13 @@
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
|
||||
# borrowed from https://github.com/NixOS/nixpkgs/issues/171136
|
||||
# and https://wiki.archlinux.org/title/fprint#Login_configuration
|
||||
# and also this internal/experimental feature:
|
||||
# https://github.com/NixOS/nixpkgs/pull/255547
|
||||
#
|
||||
# This should allow fprintd to go after pam_unix (so it asks for your password first!)
|
||||
{
|
||||
|
||||
# to generate this its going to look something like this
|
||||
# rg "fprintd" --follow /etc/pam.d | sed -nr 's/\/etc\/pam.d\/(\w+)/\1/p' | cut -d ':' -f 1 | awk '{printf "security.pam.services.%s.rules.auth.fprintd.order=11501;\n",$1}'
|
||||
security.pam.services.passwd.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.auth.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.chpasswd.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.groupdel.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.groupadd.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.useradd.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.i3lock.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.systemd-user.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.sudo.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.userdel.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.chfn.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.su.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.usermod.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.groupmems.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.chsh.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.i3lock-color.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.xscreensaver.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.xlock.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.polkit-1.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.vlock.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.runuser-l.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.groupmod.rules.auth.fprintd.order = 11501;
|
||||
security.pam.services.runuser.rules.auth.fprintd.order = 11501;
|
||||
# custom module from modules/pam-fingerprint-swap.nix
|
||||
# swaps password and fingerprint in pam ordering
|
||||
security.pam.fprintd-order = {
|
||||
enable = false;
|
||||
order = 11501;
|
||||
};
|
||||
|
||||
# to auto-flip to password when the laptop lid is closed (ie. docked)
|
||||
services.acpid = {
|
||||
|
Loading…
x
Reference in New Issue
Block a user