2020-04-24 23:36:52 +00:00
|
|
|
# This module provides configuration for the OATH PAM modules.
|
|
|
|
{ lib, ... }:
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
|
|
|
|
security.pam.oath = {
|
2024-09-19 14:19:46 +00:00
|
|
|
enable = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
2020-04-24 23:36:52 +00:00
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Enable the OATH (one-time password) PAM module.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
digits = lib.mkOption {
|
|
|
|
type = lib.types.enum [ 6 7 8 ];
|
2020-04-24 23:36:52 +00:00
|
|
|
default = 6;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2024-09-19 14:19:46 +00:00
|
|
|
Specify the lib.length of the one-time password in number of
|
2020-04-24 23:36:52 +00:00
|
|
|
digits.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
window = lib.mkOption {
|
|
|
|
type = lib.types.int;
|
2020-04-24 23:36:52 +00:00
|
|
|
default = 5;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Specify the number of one-time passwords to check in order
|
|
|
|
to accommodate for situations where the system and the
|
|
|
|
client are slightly out of sync (iteration for HOTP or time
|
|
|
|
steps for TOTP).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
usersFile = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
2020-04-24 23:36:52 +00:00
|
|
|
default = "/etc/users.oath";
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Set the path to file where the user's credentials are
|
|
|
|
stored. This file must not be world readable!
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|