3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/nixos/modules/services/networking/pdnsd.nix

92 lines
2.2 KiB
Nix
Raw Normal View History

2016-02-11 11:02:11 +00:00
{ 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 (lib.mdDoc "pdnsd");
2016-02-11 11:02:11 +00:00
cacheDir = mkOption {
type = types.str;
default = "/var/cache/pdnsd";
description = lib.mdDoc "Directory holding the pdnsd cache";
2016-02-11 11:02:11 +00:00
};
globalConfig = mkOption {
type = types.lines;
default = "";
description = lib.mdDoc ''
2016-02-11 11:02:11 +00:00
Global configuration that should be added to the global directory
of `pdnsd.conf`.
2016-02-11 11:02:11 +00:00
'';
};
serverConfig = mkOption {
type = types.lines;
default = "";
description = lib.mdDoc ''
2016-02-11 11:02:11 +00:00
Server configuration that should be added to the server directory
of `pdnsd.conf`.
2016-02-11 11:02:11 +00:00
'';
};
extraConfig = mkOption {
type = types.lines;
default = "";
description = lib.mdDoc ''
2016-02-11 11:02:11 +00:00
Extra configuration directives that should be added to
`pdnsd.conf`.
2016-02-11 11:02:11 +00:00
'';
};
};
};
config = mkIf cfg.enable {
users.users.${pdnsdUser} = {
2016-02-11 11:02:11 +00:00
uid = config.ids.uids.pdnsd;
group = pdnsdGroup;
description = "pdnsd user";
};
users.groups.${pdnsdGroup} = {
2016-02-11 11:02:11 +00:00
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}";
};
};
};
}