-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfiguration.nix
100 lines (86 loc) · 2.18 KB
/
configuration.nix
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# Edit machine configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page
# and in the NixOS manual (accessible by running ‘nixos-help’).
{ config, pkgs, options, ... }:
let
machine = builtins.readFile( ./hostname );
in
{
imports =
[ # Include the results of the hardware scan.
./hardware-configuration.nix
./notsecret/users.nix
( ./machines + "/${machine}.nix" )
];
networking.hostName = machine;
nixpkgs.config = {
allowUnfree = true;
};
nix.nixPath =
options.nix.nixPath.default ++
[ "nixpkgs-overlays=/etc/nixos/overlays-compat/" ]
;
nixpkgs.overlays = let
unstableTarball = fetchTarball "channel:nixos-unstable";
localFork = /home/ahmad/projects/nixpkgs;
localGit = fetchGit { url = localFork; ref = "master"; };
in [
(self: super: {
unstable = import unstableTarball {
config = config.nixpkgs.config;
overlays = [];
};
})
(self: super: {
local = import localGit {
config = config.nixpkgs.config;
overlays = [];
};
})
(self: super: {
hack = import localFork {
config = config.nixpkgs.config;
overlays = [];
};
})
];
environment.systemPackages = with pkgs; [
#unstable.home-assistant
file
git
wget
vim
lm_sensors
screen
mprime
htop
iperf3
hddtemp
smartmontools
hdparm
sysstat
usbutils
parted
psmisc
stow
ncdu
tree
unzip
pciutils
lsof
];
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.mtr.enable = true;
# programs.gnupg.agent = { enable = true; enableSSHSupport = true; };
networking.firewall.enable = false;
services.openssh.enable = true;
services.openssh.permitRootLogin = "no";
programs.ssh.startAgent = true;
programs.mosh.enable = true;
i18n.defaultLocale = "en_GB.UTF-8";
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.mtr.enable = true;
# programs.gnupg.agent = { enable = true; enableSSHSupport = true; };
}