2021-04-07 14:03:52 -07:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
2021-10-28 09:32:35 -07:00
|
|
|
with lib;
|
2021-04-07 14:03:52 -07:00
|
|
|
let
|
|
|
|
primary-ip = "208.81.3.117";
|
2021-09-29 17:55:13 -07:00
|
|
|
git-server-ip = "208.81.3.118";
|
2021-04-07 14:03:52 -07:00
|
|
|
hostname = config.instance.hostname;
|
|
|
|
domain-name = config.fudo.hosts.${hostname}.domain;
|
|
|
|
domain = config.fudo.domains.${domain-name};
|
|
|
|
host-fqdn = "${hostname}.${domain-name}";
|
|
|
|
mail-hostname = "mail.fudo.org";
|
2021-11-05 07:06:08 -07:00
|
|
|
mail-directory = "/srv/mail";
|
2021-04-07 14:03:52 -07:00
|
|
|
|
2021-11-02 09:34:26 -07:00
|
|
|
secrets = config.fudo.secrets.host-secrets.france;
|
|
|
|
secret-files = config.fudo.secrets.files;
|
2021-10-28 09:32:35 -07:00
|
|
|
|
2024-01-16 19:08:38 -08:00
|
|
|
letsencrypt-full-chain = name: chain:
|
|
|
|
pkgs.stdenv.mkDerivation {
|
|
|
|
name = "${name}-letsencrypt-full-chain.pem";
|
|
|
|
phases = "installPhase";
|
|
|
|
installPhase = ''
|
|
|
|
cat ${chain} > $out
|
|
|
|
cat ${pkgs.letsencrypt-ca}/ca.pem >> $out
|
|
|
|
'';
|
|
|
|
};
|
2021-10-28 09:32:35 -07:00
|
|
|
|
2021-04-07 14:03:52 -07:00
|
|
|
in {
|
2021-11-18 09:51:41 -08:00
|
|
|
# imports = let
|
|
|
|
# is-regular-file = filename: type: type == "regular" || type == "link";
|
|
|
|
# regular-files = path:
|
|
|
|
# attrNames (filterAttrs is-regular-file (builtins.readDir path));
|
|
|
|
# is-nix-file = filename: (builtins.match "^(.+)\.nix$" filename) != null;
|
|
|
|
# nix-files = path:
|
|
|
|
# map
|
|
|
|
# (file: path + "/${file}")
|
|
|
|
# (filter is-nix-file (regular-files path));
|
|
|
|
# in nix-files ./france;
|
2021-04-07 14:03:52 -07:00
|
|
|
|
|
|
|
config = {
|
2021-11-02 09:34:26 -07:00
|
|
|
security.acme.email = "admin@fudo.org";
|
|
|
|
|
2021-11-05 07:06:08 -07:00
|
|
|
fileSystems = {
|
|
|
|
"/srv/archiva" = {
|
|
|
|
fsType = "btrfs";
|
|
|
|
label = "pool0";
|
|
|
|
options = [ "noatime" "nodiratime" "noexec" "subvol=archiva" ];
|
|
|
|
};
|
|
|
|
|
|
|
|
"/srv/grafana" = {
|
|
|
|
fsType = "btrfs";
|
|
|
|
label = "pool0";
|
|
|
|
options = [ "noatime" "nodiratime" "noexec" "subvol=grafana" ];
|
|
|
|
};
|
|
|
|
|
|
|
|
${mail-directory} = {
|
|
|
|
fsType = "btrfs";
|
|
|
|
label = "pool0";
|
|
|
|
options = [ "noatime" "nodiratime" "noexec" "subvol=mail" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
users.users.archiva = {
|
|
|
|
isSystemUser = true;
|
|
|
|
group = "nogroup";
|
|
|
|
};
|
|
|
|
|
|
|
|
virtualisation = {
|
|
|
|
lxd.enable = true;
|
|
|
|
|
|
|
|
oci-containers = {
|
|
|
|
backend = "docker";
|
|
|
|
|
|
|
|
containers = {
|
|
|
|
archiva = {
|
|
|
|
image = "xetusoss/archiva";
|
|
|
|
autoStart = true;
|
|
|
|
ports = [ "8001:8080/tcp" ];
|
|
|
|
# Ugly: name-to-uid lookup fails.
|
|
|
|
user = toString config.users.users.archiva.uid;
|
|
|
|
volumes = [ "/srv/archiva:/archiva-data" ];
|
|
|
|
environment = {
|
|
|
|
# Not directly connected to the world anyway
|
|
|
|
SSL_ENABLED = "false";
|
|
|
|
PROXY_BASE_URL = "https://archiva.fudo.org/";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
fudo = let
|
2024-01-16 19:08:38 -08:00
|
|
|
backplane-dns-password-file =
|
|
|
|
pkgs.lib.passwd.stablerandom-passwd-file "dns-service-backplane-passwd"
|
2021-11-05 07:06:08 -07:00
|
|
|
"dns-service-backplane-passwd-${config.instance.build-seed}";
|
|
|
|
in {
|
2021-10-28 09:32:35 -07:00
|
|
|
hosts.france.external-interfaces = [ "extif0" ];
|
2021-04-07 14:03:52 -07:00
|
|
|
|
2021-11-02 09:34:26 -07:00
|
|
|
acme.host-domains.france."france.fudo.org" = {
|
2024-01-16 19:08:38 -08:00
|
|
|
admin-email = "admin@fudo.org";
|
2021-11-02 09:34:26 -07:00
|
|
|
local-copies = {
|
2024-01-16 19:08:38 -08:00
|
|
|
postgres = { user = "postgres"; };
|
|
|
|
openldap = { user = config.services.openldap.user; };
|
2021-11-02 09:34:26 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
secrets.host-secrets.${hostname} = let
|
|
|
|
ldap-user = config.services.openldap.user;
|
|
|
|
ldap-group = config.services.openldap.group;
|
|
|
|
in {
|
|
|
|
ldap-keytab = {
|
|
|
|
source-file = secret-files.service-keytabs.france.ldap;
|
|
|
|
target-file = "/run/openldap/ldap.keytab";
|
|
|
|
user = ldap-user;
|
|
|
|
group = ldap-group;
|
|
|
|
};
|
|
|
|
ldap-root-passwd = {
|
2021-11-05 07:06:08 -07:00
|
|
|
source-file =
|
2021-11-28 12:39:03 -08:00
|
|
|
pkgs.lib.passwd.random-passwd-file "ldap-root-passwd" 20;
|
2021-11-02 09:34:26 -07:00
|
|
|
target-file = "/run/openldap/root.passwd";
|
|
|
|
user = ldap-user;
|
|
|
|
group = ldap-group;
|
|
|
|
};
|
|
|
|
postgres-keytab = {
|
|
|
|
source-file = secret-files.service-keytabs.france.postgres;
|
|
|
|
target-file = "/run/postgres/postgres.keytab";
|
2021-11-05 07:06:08 -07:00
|
|
|
user = "postgres"; # This is just plain hard-coded...
|
|
|
|
};
|
|
|
|
backplane-dns-password = {
|
|
|
|
source-file = backplane-dns-password-file;
|
|
|
|
target-file = "/run/backplane/dns/xmpp.passwd";
|
|
|
|
user = config.fudo.backplane.dns.user;
|
2021-11-02 09:34:26 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-04-07 14:03:52 -07:00
|
|
|
client.dns = {
|
|
|
|
ipv4 = true;
|
|
|
|
ipv6 = true;
|
2021-10-28 09:32:35 -07:00
|
|
|
user = "fudo-client";
|
2021-04-07 14:03:52 -07:00
|
|
|
external-interface = "extif0";
|
|
|
|
};
|
|
|
|
|
2024-01-16 19:08:38 -08:00
|
|
|
# france = {
|
|
|
|
# ldap = let
|
|
|
|
# cert-copy = config.fudo.acme.host-domains.france."france.fudo.org".local-copies.openldap;
|
|
|
|
# chain = "${letsencrypt-full-chain "openldap-france" cert-copy.chain}";
|
|
|
|
# in {
|
|
|
|
# ssl-certificate = cert-copy.certificate;
|
|
|
|
# ssl-private-key = cert-copy.private-key;
|
|
|
|
# ssl-ca-certificate = chain;
|
|
|
|
# keytab = secrets.ldap-keytab.target-file;
|
|
|
|
# root-password-file = secrets.ldap-root-passwd.target-file;
|
|
|
|
# };
|
|
|
|
|
|
|
|
# kdc = {
|
|
|
|
# state-directory = "/state/kerberos";
|
|
|
|
# master-key-file = secret-files.realm-master-keys."FUDO.ORG";
|
|
|
|
# listen-ips = [ primary-ip "127.0.0.1" "127.0.1.1" "::1" ];
|
|
|
|
# };
|
|
|
|
|
|
|
|
# jabber = {
|
|
|
|
# ldap-servers = [ "france.fudo.org" ];
|
|
|
|
# listen-ips = [ primary-ip ];
|
|
|
|
|
|
|
|
# backplane = {
|
|
|
|
# host-passwd-files = let
|
|
|
|
# hosts = attrNames config.fudo.hosts;
|
|
|
|
# in mapAttrs (hostname: hostOpts: hostOpts.backplane-password-file)
|
|
|
|
# config.fudo.hosts;
|
|
|
|
# service-passwd-files = {
|
|
|
|
# dns = backplane-dns-password-file;
|
|
|
|
# };
|
|
|
|
# };
|
|
|
|
# };
|
|
|
|
|
|
|
|
# backplane-server = {
|
|
|
|
# listen-ips = [ primary-ip ];
|
|
|
|
# backplane-dns-password-file =
|
|
|
|
# secrets.backplane-dns-password.target-file;
|
|
|
|
# };
|
|
|
|
|
|
|
|
# mail = {
|
|
|
|
# mail-directory = "${mail-directory}/mailboxes";
|
|
|
|
# state-directory = "${mail-directory}/var";
|
|
|
|
# ldap-server-urls = [
|
|
|
|
# "ldap://france.fudo.org"
|
|
|
|
# ];
|
|
|
|
# };
|
|
|
|
|
|
|
|
# webmail = {
|
|
|
|
# mail-server = mail-hostname;
|
|
|
|
# database.hostname = "localhost";
|
|
|
|
# };
|
|
|
|
|
|
|
|
# git = {
|
|
|
|
# repository-directory = "/state/gitea/repo";
|
|
|
|
# state-directory = "/state/gitea/state";
|
|
|
|
# ssh.listen-ip = git-server-ip;
|
|
|
|
# database-host = "localhost";
|
|
|
|
# };
|
|
|
|
|
|
|
|
# postgresql = let
|
|
|
|
# cert-copy = config.fudo.acme.host-domains.france."france.fudo.org".local-copies.postgres;
|
|
|
|
# in {
|
|
|
|
# keytab = secrets.postgres-keytab.target-file;
|
|
|
|
# ssl-certificate = cert-copy.certificate;
|
|
|
|
# ssl-private-key = cert-copy.private-key;
|
|
|
|
# };
|
|
|
|
|
|
|
|
# dns = {
|
|
|
|
# default-host = primary-ip;
|
|
|
|
# listen-ip = primary-ip;
|
|
|
|
# mail-hosts = [ "mail.fudo.org" ];
|
|
|
|
# };
|
|
|
|
|
|
|
|
# chat = {
|
|
|
|
# chat-hostname = "chat.fudo.org";
|
|
|
|
# mail-server = "mail.fudo.org";
|
|
|
|
# database-host = "localhost";
|
|
|
|
# };
|
|
|
|
# };
|
|
|
|
|
|
|
|
# minecraft-server = {
|
|
|
|
# enable = true;
|
|
|
|
# package = pkgs.minecraft-current;
|
|
|
|
# data-dir = "/state/minecraft/selbyland";
|
|
|
|
# world-name = "selbyland";
|
|
|
|
# motd = "Welcome to the Selby Minecraft server.";
|
|
|
|
# };
|
2021-04-07 14:03:52 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
networking = {
|
2021-11-02 09:34:26 -07:00
|
|
|
interfaces = {
|
|
|
|
intif0 = {
|
|
|
|
ipv4.addresses = [{
|
|
|
|
address = "192.168.11.1";
|
|
|
|
prefixLength = 24;
|
|
|
|
}];
|
|
|
|
};
|
|
|
|
extif0 = {
|
2024-01-16 19:08:38 -08:00
|
|
|
ipv4.addresses = [{
|
|
|
|
address = primary-ip;
|
|
|
|
prefixLength = 28;
|
|
|
|
}];
|
2021-11-02 09:34:26 -07:00
|
|
|
};
|
2021-04-07 14:03:52 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
nginx = {
|
|
|
|
enable = true;
|
|
|
|
recommendedGzipSettings = true;
|
2021-11-02 09:34:26 -07:00
|
|
|
recommendedOptimisation = true;
|
2021-04-07 14:03:52 -07:00
|
|
|
recommendedTlsSettings = true;
|
|
|
|
recommendedProxySettings = true;
|
|
|
|
|
|
|
|
virtualHosts = {
|
|
|
|
"mail.fudo.org" = {
|
|
|
|
enableACME = true;
|
|
|
|
locations."/".return = "301 https://webmail.fudo.org$request_uri";
|
|
|
|
};
|
2021-11-05 07:06:08 -07:00
|
|
|
|
|
|
|
"archiva.fudo.org" = {
|
|
|
|
enableACME = true;
|
|
|
|
forceSSL = true;
|
|
|
|
|
|
|
|
locations."/" = {
|
|
|
|
proxyPass = "http://127.0.0.1:8001";
|
|
|
|
extraConfig = ''
|
2021-11-16 16:56:43 -08:00
|
|
|
proxy_set_header Host $host;
|
|
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
|
|
proxy_set_header X-Forwarded-By $server_addr:$server_port;
|
|
|
|
proxy_set_header X-Forwarded-For $remote_addr;
|
|
|
|
proxy_set_header X-Forwarded-Proto $scheme;
|
|
|
|
'';
|
2021-11-05 07:06:08 -07:00
|
|
|
};
|
|
|
|
};
|
2021-04-07 14:03:52 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|