DEVELOPMENT ENVIRONMENT

~liljamo/nix-arta

fe84df8b502b50e6c4b6d52de2c7e506c2edf6e4 — Jonni Liljamo 3 months ago 5290a0f
feat(roles/tailscale): add tailscale role
2 files changed, 36 insertions(+), 0 deletions(-)

M roles/default.nix
A roles/tailscale.nix
M roles/default.nix => roles/default.nix +1 -0
@@ 14,6 14,7 @@
    ./nix.nix
    ./plasma.nix
    ./qutebrowser.nix
    ./tailscale.nix
    ./zellij.nix
  ];
}

A roles/tailscale.nix => roles/tailscale.nix +35 -0
@@ 0,0 1,35 @@
{
  config,
  lib,
  ...
}: let
  cfg = config.roles.tailscale;
in {
  options.roles.tailscale = {
    enable = lib.mkEnableOption "Tailscale";
    authKeyFile = lib.mkOption {
      type = lib.types.nullOr lib.types.path;
      default = null;
    };
    interfaceName = lib.mkOption {
      type = lib.types.str;
      default = "tailscale0";
    };
    enableSSH = lib.mkOption {
      type = lib.types.bool;
      default = false;
    };
  };

  config = lib.mkIf cfg.enable {
    services.tailscale = {
      enable = true;
      authKeyFile = lib.mkIf (cfg.authKeyFile != null) cfg.authKeyFile;
      extraUpFlags = lib.mkIf (cfg.enableSSH) ["--ssh"]; # TODO: Make modular for multiple possible flags
      interfaceName = cfg.interfaceName;
      openFirewall = false;
      #port = 41641;
      useRoutingFeatures = "none";
    };
  };
}