nixcfg/node/caribou.nix

72 lines
1.7 KiB
Nix
Raw Normal View History

2021-11-01 21:56:32 +00:00
# Configuration file local to this node
{ config, pkgs, ... }:
{
2021-11-18 13:38:48 +00:00
# Use the systemd-boot EFI boot loader.
boot.loader.systemd-boot.enable = true;
boot.loader.timeout = 20;
boot.loader.efi.canTouchEfiVariables = true;
2021-11-01 21:56:32 +00:00
networking.hostName = "caribou"; # Define your hostname.
networking.interfaces.eno1.useDHCP = false;
networking.interfaces.eno1.ipv4.addresses = [
{
address = "192.168.1.23";
prefixLength = 24;
}
];
2021-12-13 10:30:41 +00:00
networking.interfaces.eno1.ipv6.addresses = [
{
address = "2a01:e0a:c:a720::23";
prefixLength = 64;
}
];
2021-11-02 09:45:09 +00:00
2021-11-16 16:39:23 +00:00
networking.wireguard.interfaces.wg0 = {
ips = [ "10.42.0.23/16" ];
listenPort = 33723;
};
2021-11-02 09:45:09 +00:00
# OR use USB modem plugged in here
#networking.interfaces.enp0s20u1.useDHCP = true;
2021-11-01 21:56:32 +00:00
2021-12-04 20:55:48 +00:00
# Activate as Nomad and Consul server node
services.nomad.settings.server.enabled = true;
services.consul.extraConfig.server = true;
2021-11-18 13:38:48 +00:00
# Enable netdata monitoring
services.netdata.enable = true;
# ----
2021-11-01 21:56:32 +00:00
# Enable nix-serve
services.nix-serve = {
enable = true;
secretKeyFile = "/var/cache-priv-key.pem";
};
# Configure a Nginx web server to serve NixOS cache
services.nginx = {
enable = true;
virtualHosts = {
"binarycache.home.adnab.me" = {
serverAliases = [ "binarycache" ];
2021-12-08 17:02:21 +00:00
listen = [ {
addr = "0.0.0.0";
port = 7980;
} ];
2021-11-01 21:56:32 +00:00
locations."/".extraConfig = ''
proxy_pass http://localhost:${toString config.services.nix-serve.port};
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
'';
};
};
};
2021-12-08 17:02:21 +00:00
networking.firewall.allowedTCPPorts = [ 7980 ];
2021-11-01 21:56:32 +00:00
}