This process was automated by [my fork of `nix-doc-munge`]; thanks
to @pennae for writing this tool! It automatically checks that the
resulting documentation doesn't change, although my fork loosens
this a little to ignore some irrelevant whitespace and typographical
differences.
As of this commit there is no DocBook remaining in the options
documentation.
You can play along at home if you want to reproduce this commit:
$ NIX_PATH=nixpkgs=flake:nixpkgs/c1bca7fe84c646cfd4ebf3482c0e6317a0b13f22 \
nix shell nixpkgs#coreutils \
-c find . -name '*.nix' \
-exec nix run github:emilazy/nix-doc-munge/0a7190f600027bf7baf6cb7139e4d69ac2f51062 \
{} +
[my fork of `nix-doc-munge`]: https://github.com/emilazy/nix-doc-munge
71 lines
1.9 KiB
Nix
71 lines
1.9 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.tailscale;
|
|
|
|
in
|
|
{
|
|
options.services.tailscale = {
|
|
domain = mkOption {
|
|
type = types.str;
|
|
default = "";
|
|
description = lib.mdDoc "The Tailscale domain. This is displayed at the top left of https://login.tailscale.com/admin, next to the Tailscale logo.";
|
|
};
|
|
|
|
enable = mkEnableOption (lib.mdDoc "Tailscale client daemon");
|
|
|
|
package = mkOption {
|
|
type = types.package;
|
|
default = pkgs.tailscale;
|
|
defaultText = literalExpression "pkgs.tailscale";
|
|
description = lib.mdDoc "The package to use for tailscale";
|
|
};
|
|
|
|
magicDNS = {
|
|
enable = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
example = true;
|
|
description = lib.mdDoc "Whether to configure networking to work with Tailscale's MagicDNS.";
|
|
};
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
assertions = [ {
|
|
assertion = !cfg.magicDNS.enable || config.networking.dns != [ "100.100.100.100" ];
|
|
message = ''
|
|
When MagicDNS is enabled, fallback DNS servers need to be set with `networking.dns`.
|
|
|
|
Otherwise, Tailscale will take a long time to connect and all DNS queries
|
|
will fail until Tailscale has connected.
|
|
'';
|
|
} ];
|
|
|
|
environment.systemPackages = [ cfg.package ];
|
|
|
|
launchd.daemons.tailscaled = {
|
|
# derived from
|
|
# https://github.com/tailscale/tailscale/blob/main/cmd/tailscaled/install_darwin.go#L30
|
|
serviceConfig = {
|
|
Label = "com.tailscale.tailscaled";
|
|
ProgramArguments = [
|
|
"/bin/sh" "-c"
|
|
"/bin/wait4path ${cfg.package} && ${cfg.package}/bin/tailscaled"
|
|
];
|
|
RunAtLoad = true;
|
|
};
|
|
};
|
|
|
|
networking = mkIf cfg.magicDNS.enable {
|
|
dns = [ "100.100.100.100" ];
|
|
search =
|
|
if cfg.domain == "" then
|
|
[ ]
|
|
else
|
|
[ "${cfg.domain}.beta.tailscale.net" ];
|
|
};
|
|
};
|
|
}
|