feat: add meta for tailscale ip and use it in headsale ACL parameters
Some checks failed
/ test (push) Failing after 1s

This commit is contained in:
nydragon 2025-02-08 12:47:03 +01:00
parent 7c247098cb
commit e9efefd7d2
Signed by: nydragon
SSH key fingerprint: SHA256:WcjW5NJPQ8Dx4uQDmoIlVPLWE27Od3fxoe0IUvuoPHE
3 changed files with 14 additions and 2 deletions

View file

@ -2,6 +2,7 @@
pkgs, pkgs,
options, options,
lib, lib,
self,
... ...
}: }:
let let
@ -13,6 +14,8 @@ let
action = "accept"; action = "accept";
inherit src dst users; inherit src dst users;
}; };
shanMeta = self.nixosConfigurations.shan.config.modules.meta;
in in
{ {
services.headscale.settings.policy.path = pkgs.writeTextFile { services.headscale.settings.policy.path = pkgs.writeTextFile {
@ -39,7 +42,7 @@ in
[ [
"tag:guest" "tag:guest"
] ]
[ "100.64.0.4:443" ] [ "${shanMeta.tailscale.ip}:443" ]
) )
]; ];

View file

@ -28,6 +28,9 @@
}; };
modules = { modules = {
meta = {
tailscale.ip = "100.64.0.4";
};
system.networking.bluetooth.enable = true; system.networking.bluetooth.enable = true;
container = { container = {
kitchenowl = { kitchenowl = {

View file

@ -1,7 +1,7 @@
{ lib, ... }: { lib, ... }:
let let
inherit (lib) mkOption stringLength; inherit (lib) mkOption stringLength;
inherit (lib.types) str strMatching; inherit (lib.types) str strMatching nullOr;
validateUserName = validateUserName =
x: x:
@ -24,5 +24,11 @@ in
# Should handle multiple users one day? maybe... # Should handle multiple users one day? maybe...
description = "This system's primary user."; description = "This system's primary user.";
}; };
tailscale = {
ip = mkOption {
default = null;
type = nullOr str;
};
};
}; };
} }