forked from mirrors/nixpkgs
Merge branch 'pdnsd-service' of https://github.com/nfjinjing/nixpkgs
Closes #12932
This commit is contained in:
commit
1c8a21dfad
|
@ -224,6 +224,7 @@
|
||||||
nathan-gs = "Nathan Bijnens <nathan@nathan.gs>";
|
nathan-gs = "Nathan Bijnens <nathan@nathan.gs>";
|
||||||
nckx = "Tobias Geerinckx-Rice <tobias.geerinckx.rice@gmail.com>";
|
nckx = "Tobias Geerinckx-Rice <tobias.geerinckx.rice@gmail.com>";
|
||||||
nequissimus = "Tim Steinbach <tim@nequissimus.com>";
|
nequissimus = "Tim Steinbach <tim@nequissimus.com>";
|
||||||
|
nfjinjing = "Jinjing Wang <nfjinjing@gmail.com>";
|
||||||
nico202 = "Nicolò Balzarotti <anothersms@gmail.com>";
|
nico202 = "Nicolò Balzarotti <anothersms@gmail.com>";
|
||||||
notthemessiah = "Brian Cohen <brian.cohen.88@gmail.com>";
|
notthemessiah = "Brian Cohen <brian.cohen.88@gmail.com>";
|
||||||
np = "Nicolas Pouillard <np.nix@nicolaspouillard.fr>";
|
np = "Nicolas Pouillard <np.nix@nicolaspouillard.fr>";
|
||||||
|
|
|
@ -41,6 +41,7 @@ nixos.path = ./nixpkgs-unstable-2015-12-06/nixos;
|
||||||
|
|
||||||
<itemizedlist>
|
<itemizedlist>
|
||||||
<listitem><para><literal>services/monitoring/longview.nix</literal></para></listitem>
|
<listitem><para><literal>services/monitoring/longview.nix</literal></para></listitem>
|
||||||
|
<listitem><para><literal>services/networking/pdnsd.nix</literal></para></listitem>
|
||||||
<listitem><para><literal>services/web-apps/pump.io.nix</literal></para></listitem>
|
<listitem><para><literal>services/web-apps/pump.io.nix</literal></para></listitem>
|
||||||
<listitem><para><literal>services/security/haka.nix</literal></para></listitem>
|
<listitem><para><literal>services/security/haka.nix</literal></para></listitem>
|
||||||
</itemizedlist>
|
</itemizedlist>
|
||||||
|
|
|
@ -250,6 +250,7 @@
|
||||||
rmilter = 226;
|
rmilter = 226;
|
||||||
cfdyndns = 227;
|
cfdyndns = 227;
|
||||||
gammu-smsd = 228;
|
gammu-smsd = 228;
|
||||||
|
pdnsd = 229;
|
||||||
|
|
||||||
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
||||||
|
|
||||||
|
@ -476,6 +477,7 @@
|
||||||
rspamd = 225;
|
rspamd = 225;
|
||||||
rmilter = 226;
|
rmilter = 226;
|
||||||
cfdyndns = 227;
|
cfdyndns = 227;
|
||||||
|
pdnsd = 229;
|
||||||
|
|
||||||
# When adding a gid, make sure it doesn't match an existing
|
# When adding a gid, make sure it doesn't match an existing
|
||||||
# uid. Users and groups with the same name should have equal
|
# uid. Users and groups with the same name should have equal
|
||||||
|
|
|
@ -342,6 +342,7 @@
|
||||||
./services/networking/openntpd.nix
|
./services/networking/openntpd.nix
|
||||||
./services/networking/openvpn.nix
|
./services/networking/openvpn.nix
|
||||||
./services/networking/ostinato.nix
|
./services/networking/ostinato.nix
|
||||||
|
./services/networking/pdnsd.nix
|
||||||
./services/networking/polipo.nix
|
./services/networking/polipo.nix
|
||||||
./services/networking/prayer.nix
|
./services/networking/prayer.nix
|
||||||
./services/networking/privoxy.nix
|
./services/networking/privoxy.nix
|
||||||
|
|
93
nixos/modules/services/networking/pdnsd.nix
Normal file
93
nixos/modules/services/networking/pdnsd.nix
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
{ 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 <literal>pdnsd.conf</literal>.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
serverConfig = mkOption {
|
||||||
|
type = types.lines;
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Server configuration that should be added to the server directory
|
||||||
|
of <literal>pdnsd.conf</literal>.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
extraConfig = mkOption {
|
||||||
|
type = types.lines;
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Extra configuration directives that should be added to
|
||||||
|
<literal>pdnsd.conf</literal>.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
users.extraUsers = singleton {
|
||||||
|
name = pdnsdUser;
|
||||||
|
uid = config.ids.uids.pdnsd;
|
||||||
|
group = pdnsdGroup;
|
||||||
|
description = "pdnsd user";
|
||||||
|
};
|
||||||
|
|
||||||
|
users.extraGroups = singleton {
|
||||||
|
name = 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}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -12,6 +12,8 @@ stdenv.mkDerivation rec {
|
||||||
sed -i 's/.*(cachedir).*/:/' Makefile.in
|
sed -i 's/.*(cachedir).*/:/' Makefile.in
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
configureFlags = [ "--enable-ipv6" ];
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
description = "Permanent DNS caching";
|
description = "Permanent DNS caching";
|
||||||
homepage = http://www.phys.uu.nl/~rombouts/pdnsd.html;
|
homepage = http://www.phys.uu.nl/~rombouts/pdnsd.html;
|
||||||
|
|
Loading…
Reference in a new issue