tsuki/headscale: conditional config

This commit is contained in:
Oystein Kristoffer Tveit 2024-01-23 05:40:52 +01:00
parent 4d2875d168
commit b8daea8fc1
Signed by: oysteikt
GPG Key ID: 9F2F7D8250F35146

View File

@ -1,11 +1,12 @@
{ config, pkgs, ... }:
{
sops.secrets."headscale/oauth2_secret" = rec {
{ config, pkgs, lib, ... }: let
cfg = config.services.headscale;
in {
sops.secrets."headscale/oauth2_secret" = lib.mkIf cfg.enable rec {
restartUnits = [ "headscale.service" ];
owner = config.services.headscale.user;
group = config.users.users.${owner}.group;
};
sops.secrets."postgres/headscale" = rec {
sops.secrets."postgres/headscale" = lib.mkIf cfg.enable rec {
restartUnits = [ "headscale.service" ];
owner = config.services.headscale.user;
group = config.users.users.${owner}.group;
@ -44,14 +45,14 @@
};
};
systemd.services.headscale = {
systemd.services.headscale = lib.mkIf cfg.enable {
requires = [
"postgresql.service"
"kanidm.service"
];
};
services.postgresql = {
services.postgresql = lib.mkIf cfg.enable {
enable = true;
ensureDatabases = [ "headscale" ];
ensureUsers = [
@ -64,7 +65,7 @@
];
};
environment.systemPackages = with pkgs; [ headscale ];
environment.systemPackages = lib.mkIf cfg.enable [ pkgs.headscale ];
services.tailscale.enable = true;