blob: 07d1049730763f30d9ee78b88b9c8803507fc5f3 (
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
|
{ config, pkgs, ... }:
{
imports = [
./hardware-configuration.nix
# ./services/hedgedoc.nix
#./services/daemoniones.nix
./services/nginx.nix
./services/pleroma.nix
./services/cgit.nix
# ./services/surveys.nix
#./services/picarones.nix
./services/dockerhub.nix
./services/blog.nix
./services/znc.nix
./services/mail.nix
./services/trainspotter.nix
];
# Use the GRUB 2 boot loader.
boot.loader.grub.enable = true;
boot.loader.grub.version = 2;
boot.loader.grub.devices = [ "/dev/sda" ];
networking = {
hostName = "flora";
enableIPv6 = true;
defaultGateway6 = {
address = "fe80::1";
interface = "ens3";
};
interfaces.ens3.ipv6.addresses = [ {
address = "2a01:4f9:c010:df15::1";
prefixLength = 64;
} ];
useDHCP = false;
interfaces.ens3.useDHCP = true;
firewall.logRefusedConnections = false;
};
services.fail2ban = {
enable = true;
bantime-increment.enable = true;
bantime-increment.overalljails = true;
bantime-increment.maxtime = "1312m";
ignoreIP = [ "88.133.194.232" ];
};
services.logrotate = {
enable = true;
# the nginx module does stuff here, which apparently no one tells anyone about
settings.nginx = {
rotate = 2;
nocompress = true;
compress = false;
};
};
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions
# on your system were taken. It‘s perfectly fine and recommended to leave
# this value at the release version of the first install of this system.
# Before changing this value read the documentation for this option
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
system.stateVersion = "20.09"; # Did you read the comment?
}
|