DEVELOPMENT ENVIRONMENT

~liljamo/nix-arta

ref: 277404e994ce4b2a464d5b31238daae5e3e63491 nix-arta/roles/tailscale.nix -rw-r--r-- 846 bytes
277404e9Jonni Liljamo feat(systems/hosts/oci): auto-update and remove registry ui port a month ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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";
    };
  };
}