mirror of
https://github.com/Stunkymonkey/nixos.git
synced 2025-05-24 09:54:40 +02:00
service/vpn: init headscale
This commit is contained in:
parent
7be56eb5c3
commit
ed03795561
2 changed files with 91 additions and 0 deletions
|
@ -41,5 +41,6 @@
|
||||||
./sonarr
|
./sonarr
|
||||||
./ssh-server
|
./ssh-server
|
||||||
./tandoor-recipes
|
./tandoor-recipes
|
||||||
|
./vpn
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
90
modules/services/vpn/default.nix
Normal file
90
modules/services/vpn/default.nix
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
# self-hosted vpn
|
||||||
|
{ config, lib, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.my.services.vpn;
|
||||||
|
inherit (config.networking) domain;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.my.services.vpn = with lib; {
|
||||||
|
enable = mkEnableOption "Headscale VPN";
|
||||||
|
isMaster = mkEnableOption "Headscale Master";
|
||||||
|
port = mkOption {
|
||||||
|
type = types.port;
|
||||||
|
default = 8099;
|
||||||
|
example = 8080;
|
||||||
|
description = "Internal port";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable (
|
||||||
|
lib.mkMerge [
|
||||||
|
{
|
||||||
|
services.tailscale.enable = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
(lib.mkIf cfg.isMaster {
|
||||||
|
|
||||||
|
services.headscale = {
|
||||||
|
enable = true;
|
||||||
|
inherit (cfg) port;
|
||||||
|
settings = {
|
||||||
|
dns.base_domain = "buehler.internal";
|
||||||
|
server_url = "https://vpn.${domain}";
|
||||||
|
metrics_listen_addr = "127.0.0.1:8095";
|
||||||
|
log.level = "warn";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.prometheus = {
|
||||||
|
scrapeConfigs = [
|
||||||
|
{
|
||||||
|
job_name = "headscale";
|
||||||
|
static_configs = [
|
||||||
|
{
|
||||||
|
targets = [ "localhost:8095" ];
|
||||||
|
labels = {
|
||||||
|
instance = config.networking.hostName;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
# Proxy to Headscale
|
||||||
|
my.services = {
|
||||||
|
nginx.virtualHosts = [
|
||||||
|
{
|
||||||
|
subdomain = "vpn";
|
||||||
|
inherit (cfg) port;
|
||||||
|
extraConfig = {
|
||||||
|
locations = {
|
||||||
|
"/" = {
|
||||||
|
proxyWebsockets = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
prometheus.rules = {
|
||||||
|
HeadscaleHighErrorRate = {
|
||||||
|
condition = ''rate(headscale_http_requests_total{status=~"5.."}[5m]) > 0.1'';
|
||||||
|
description = "The error rate for Headscale server {{ $labels.instance }} is above 10% in the last 2 minutes.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# waiting for a nice web-ui
|
||||||
|
# webapps.apps.vpn = {
|
||||||
|
# dashboard = {
|
||||||
|
# name = "VPN";
|
||||||
|
# category = "infra";
|
||||||
|
# icon = "shield-halved";
|
||||||
|
# url = "https://vpn.${domain}";
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
})
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue