blob: 59cc264b38a02cc56b77a208b05627a403f41d22 (
plain)
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
71
72
73
74
75
76
77
78
79
80
81
|
{ config, pkgs, ... }:
{
imports =
[
./bragi-hw.nix
./autofs.nix
];
boot.loader.grub.enable = true;
boot.loader.grub.version = 2;
boot.loader.grub.device = "/dev/sda";
boot.loader.grub.extraConfig = "serial; terminal_output.serial";
boot.kernelParams = [ "console=ttyS0,115200"
];
networking.hostName = "bragi";
networking.hostId = "2af11085";
networking.wireless.enable = true;
networking.firewall = {
allowPing = true;
allowedUDPPortRanges = [ { from = 60000; to = 61000; } # mosh-server
];
};
environment.systemPackages = with pkgs; [
git
mosh
rsync
jack1
tmux
nfs-utils
];
# List services that you want to enable:
services.openssh.enable = true;
services.fcron = {
enable = true;
systab = ''
%weekly * * nix-collect-garbage --delete-older-than '7d'
'';
};
services.autofs = {
enable = true;
autoMaster = let
mapConf = pkgs.writeText "auto" ''
odin -fstype=nfs,ro odin.asgard.yggdrasil:/srv/media
'';
in ''
/media file:${mapConf}
'';
};
users.extraUsers.guest = {
name = "gkleen";
isNormalUser = true;
uid = 1000;
createHome = true;
home = "/home/gkleen";
shell = "${pkgs.zsh}/bin/zsh";
openssh.authorizedKeys.keys = [ "ecdsa-sha2-nistp521 AAAAE2VjZHNhLXNoYTItbmlzdHA1MjEAAAAIbmlzdHA1MjEAAACFBABVMu+0txXdxdTSY8POAYVXbuOEDW6VxJzaYwQljc9kzM63VUZuE606R0g2ZGr9A+Gk6qO6fpCiq4SM+1Yygz5yHgGlbO750TOGaTe6KSGw+u3miaeDviejmxTqetGmiJe7BTLRAbYHjRgD5SkK/Ovos0cDSyOfZ5aha/ehox+proQKGA== gkleen@cathy"
];
extraGroups = [ "wheel" "audio" ];
hashedPassword = "$6$MBq4kwM68$Eg8O6m76mM2905VppNZO67J3EHqJVBuIWQkz.MFFa7afVQKhGuSSYHl50WkkFYXHEY5MIM7IjWYZ0UJwq2IDJ0";
};
security.setuidPrograms = ["mount.nfs"];
security.pam.loginLimits =
[
{ domain = "@audio"; item = "memlock"; type = "-"; value = "unlimited"; }
{ domain = "@audio"; item = "rtprio"; type = "-"; value = "99"; }
{ domain = "@audio"; item = "nofile"; type = "soft"; value = "99999"; }
{ domain = "@audio"; item = "nofile"; type = "hard"; value = "99999"; }
];
}
|