blob: 3278f24070b0f64efdcf73a67b236962899dfaf7 (
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
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
100
101
102
103
104
105
106
107
108
109
|
{ modulesPath, config, pkgs, lib, ... }:
let
myLib = import ./lib.nix { inherit pkgs lib; };
myPkgs = import ./pkgs.nix { inherit pkgs lib myLib; };
hostname = "legosi";
myKey = "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDNMQvmOfon956Z0ZVdp186YhPHtSBrXsBwaCt0JAbkf/U/P+4fG0OROA++fHDiFM4RrRHH6plsGY3W6L26mSsCM2LtlHJINFZtVILkI26MDEIKWEsfBatDW+XNAvkfYEahy16P5CBtTVNKEGsTcPD+VDistHseFNKiVlSLDCvJ0vMwOykHhq+rdJmjJ8tkUWC2bNqTIH26bU0UbhMAtJstWqaTUGnB0WVutKmkZbnylLMICAvnFoZLoMPmbvx8efgLYY2vD1pRd8Uwnq9MFV1EPbkJoinTf1XSo8VUo7WCjL79aYSIvHmXG+5qKB9ed2GWbBLolAoXkZ00E4WsVp9H philip@nyx";
in {
imports = [
./base-server.nix
"${modulesPath}/profiles/qemu-guest.nix"
];
config = {
vuizvui.modifyNixPath = false;
nix = {
nixPath = [
"vuizvui=/root/vuizvui"
"nixpkgs=/root/nixpkgs"
# todo: nicer?
"nixos-config=${pkgs.writeText "legosi-configuration.nix" ''
(import <vuizvui/machines>).profpatsch.legosi.config
''}"
];
extraOptions = ''
auto-optimise-store = true
min-free = ${toString (3 * 1024 * 1024 * 1024)}
'';
};
vuizvui.user.profpatsch.server.sshPort = 7001;
boot.loader.grub.device = "/dev/sda";
# VPN support
boot.extraModulePackages = [ config.boot.kernelPackages.wireguard ];
fileSystems = {
"/" = {
device = "/dev/sda1";
fsType = "ext4";
};
};
networking = {
hostName = hostname;
firewall = {
allowedTCPPorts = [
80 443
];
};
interfaces.ens3 = {
ipv6.addresses = [{
address = "2a01:4f8:c0c:70aa::1";
prefixLength = 64;
}];
};
defaultGateway6 = {
address = "fe80::1";
interface = "ens3";
};
};
users.users = {
root.openssh.authorizedKeys.keys = [ myKey ];
};
vuizvui.programs.profpatsch.weechat = {
enable = true;
authorizedKeys = [ myKey ];
# redirect the bitlbee unix socket to a fake domain
# because weechat is unable to connect to unix sockets.
wrapExecStart = [
"${pkgs.ip2unix}/bin/ip2unix"
"-r"
"addr=1.2.3.4,port=6667,path=${config.vuizvui.services.profpatsch.bitlbee.socketFile}"
];
};
users.users.weechat.extraGroups = [ "bitlbee" ];
vuizvui.services.profpatsch.bitlbee = {
enable = true;
};
security.acme.acceptTerms = true;
security.acme.email = "mail@profpatsch.de";
services.nginx = {
enable = true;
virtualHosts.${"profpatsch.de"} = {
forceSSL = true;
enableACME = true;
locations."/" = {
index = "index.html";
root = pkgs.vuizvui.profpatsch.websiteStatic;
};
};
};
};
}
|