about summary refs log tree commit diff
path: root/nixos/tests/pam/pam-ussh.nix
blob: ba0570dbf97d2f24aae2cdac882d7df33d642eeb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import ../make-test-python.nix ({ pkgs, lib, ... }:

let
  testOnlySSHCredentials = pkgs.runCommand "pam-ussh-test-ca" {
    nativeBuildInputs = [ pkgs.openssh ];
  } ''
    mkdir $out
    ssh-keygen -t ed25519 -N "" -f $out/ca

    ssh-keygen -t ed25519 -N "" -f $out/alice
    ssh-keygen -s $out/ca -I "alice user key" -n "alice,root" -V 19700101:forever $out/alice.pub

    ssh-keygen -t ed25519 -N "" -f $out/bob
    ssh-keygen -s $out/ca -I "bob user key" -n "bob" -V 19700101:forever $out/bob.pub
  '';
  makeTestScript = user: pkgs.writeShellScript "pam-ussh-${user}-test-script" ''
    set -euo pipefail

    eval $(${pkgs.openssh}/bin/ssh-agent)

    mkdir -p $HOME/.ssh
    chmod 700 $HOME/.ssh
    cp ${testOnlySSHCredentials}/${user}{,.pub,-cert.pub} $HOME/.ssh
    chmod 600 $HOME/.ssh/${user}
    chmod 644 $HOME/.ssh/${user}{,-cert}.pub

    set -x

    ${pkgs.openssh}/bin/ssh-add $HOME/.ssh/${user}
    ${pkgs.openssh}/bin/ssh-add -l &>2

    exec sudo id -u -n
  '';
in {
  name = "pam-ussh";
  meta.maintainers = with lib.maintainers; [ lukegb ];

  machine =
    { ... }:
    {
      users.users.alice = { isNormalUser = true; extraGroups = [ "wheel" ]; };
      users.users.bob = { isNormalUser = true; extraGroups = [ "wheel" ]; };

      security.pam.ussh = {
        enable = true;
        authorizedPrincipals = "root";
        caFile = "${testOnlySSHCredentials}/ca.pub";
      };

      security.sudo = {
        enable = true;
        extraConfig = ''
          Defaults lecture="never"
        '';
      };
    };

  testScript =
    ''
      with subtest("alice should be allowed to escalate to root"):
        machine.succeed(
            'su -c "${makeTestScript "alice"}" -l alice | grep root'
        )

      with subtest("bob should not be allowed to escalate to root"):
        machine.fail(
            'su -c "${makeTestScript "bob"}" -l bob | grep root'
        )
    '';
})