6afb255d97
these changes were generated with nixq 0.0.2, by running nixq ">> lib.mdDoc[remove] Argument[keep]" --batchmode nixos/**.nix nixq ">> mdDoc[remove] Argument[keep]" --batchmode nixos/**.nix nixq ">> Inherit >> mdDoc[remove]" --batchmode nixos/**.nix two mentions of the mdDoc function remain in nixos/, both of which are inside of comments. Since lib.mdDoc is already defined as just id, this commit is a no-op as far as Nix (and the built manual) is concerned.
91 lines
2.1 KiB
Nix
91 lines
2.1 KiB
Nix
{ config, pkgs, lib, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.pdnsd;
|
|
pdnsd = pkgs.pdnsd;
|
|
pdnsdUser = "pdnsd";
|
|
pdnsdGroup = "pdnsd";
|
|
pdnsdConf = pkgs.writeText "pdnsd.conf"
|
|
''
|
|
global {
|
|
run_as=${pdnsdUser};
|
|
cache_dir="${cfg.cacheDir}";
|
|
${cfg.globalConfig}
|
|
}
|
|
|
|
server {
|
|
${cfg.serverConfig}
|
|
}
|
|
${cfg.extraConfig}
|
|
'';
|
|
in
|
|
|
|
{ options =
|
|
{ services.pdnsd =
|
|
{ enable = mkEnableOption "pdnsd";
|
|
|
|
cacheDir = mkOption {
|
|
type = types.str;
|
|
default = "/var/cache/pdnsd";
|
|
description = "Directory holding the pdnsd cache";
|
|
};
|
|
|
|
globalConfig = mkOption {
|
|
type = types.lines;
|
|
default = "";
|
|
description = ''
|
|
Global configuration that should be added to the global directory
|
|
of `pdnsd.conf`.
|
|
'';
|
|
};
|
|
|
|
serverConfig = mkOption {
|
|
type = types.lines;
|
|
default = "";
|
|
description = ''
|
|
Server configuration that should be added to the server directory
|
|
of `pdnsd.conf`.
|
|
'';
|
|
};
|
|
|
|
extraConfig = mkOption {
|
|
type = types.lines;
|
|
default = "";
|
|
description = ''
|
|
Extra configuration directives that should be added to
|
|
`pdnsd.conf`.
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
users.users.${pdnsdUser} = {
|
|
uid = config.ids.uids.pdnsd;
|
|
group = pdnsdGroup;
|
|
description = "pdnsd user";
|
|
};
|
|
|
|
users.groups.${pdnsdGroup} = {
|
|
gid = config.ids.gids.pdnsd;
|
|
};
|
|
|
|
systemd.services.pdnsd =
|
|
{ wantedBy = [ "multi-user.target" ];
|
|
after = [ "network.target" ];
|
|
preStart =
|
|
''
|
|
mkdir -p "${cfg.cacheDir}"
|
|
touch "${cfg.cacheDir}/pdnsd.cache"
|
|
chown -R ${pdnsdUser}:${pdnsdGroup} "${cfg.cacheDir}"
|
|
'';
|
|
description = "pdnsd";
|
|
serviceConfig =
|
|
{
|
|
ExecStart = "${pdnsd}/bin/pdnsd -c ${pdnsdConf}";
|
|
};
|
|
};
|
|
};
|
|
}
|