summaryrefslogtreecommitdiffstats
path: root/lass/2configs/otp-ssh.nix
blob: f9984e245071e4b73b30811230e9f3c725f1be7e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
{ pkgs, ... }:
# Enables second factor for ssh password login

## Usage:
#  gen-oath-safe <username> totp
## scan the qrcode with google authenticator (or FreeOTP)
## copy last line into secrets/<host>/users.oath (chmod 700)
{
  security.pam.oath = {
    # enabling it will make it a requisite of `all` services
    # enable = true;
    digits = 6;
    # TODO assert existing
    usersFile = (toString <secrets>) + "/users.oath";
  };
  # I want TFA only active for sshd with password-auth
  security.pam.services.sshd.oathAuth = true;
}