2016-02-24 21:41:02 +00:00
|
|
|
# This module provides configuration for the OATH PAM modules.
|
|
|
|
|
2018-07-20 20:56:59 +00:00
|
|
|
{ lib, ... }:
|
2016-02-24 21:41:02 +00:00
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
|
|
|
|
security.pam.oath = {
|
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-07-28 21:19:15 +00:00
|
|
|
description = lib.mdDoc ''
|
2016-02-24 21:41:02 +00:00
|
|
|
Enable the OATH (one-time password) PAM module.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
digits = mkOption {
|
|
|
|
type = types.enum [ 6 7 8 ];
|
|
|
|
default = 6;
|
2022-07-28 21:19:15 +00:00
|
|
|
description = lib.mdDoc ''
|
2016-02-24 21:41:02 +00:00
|
|
|
Specify the length of the one-time password in number of
|
|
|
|
digits.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
window = mkOption {
|
|
|
|
type = types.int;
|
|
|
|
default = 5;
|
2022-07-28 21:19:15 +00:00
|
|
|
description = lib.mdDoc ''
|
2016-02-24 21:41:02 +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).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
usersFile = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/etc/users.oath";
|
2022-07-28 21:19:15 +00:00
|
|
|
description = lib.mdDoc ''
|
2016-02-24 21:41:02 +00:00
|
|
|
Set the path to file where the user's credentials are
|
|
|
|
stored. This file must not be world readable!
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|