forked from mirrors/nixpkgs
Adding a dnsmasq simple module.
svn path=/nixos/trunk/; revision=26820
This commit is contained in:
parent
e9b2ebcb99
commit
6824866d6d
|
@ -92,6 +92,7 @@
|
|||
./services/networking/ddclient.nix
|
||||
./services/networking/dhclient.nix
|
||||
./services/networking/dhcpd.nix
|
||||
./services/networking/dnsmasq.nix
|
||||
./services/networking/ejabberd.nix
|
||||
./services/networking/firewall.nix
|
||||
./services/networking/git-daemon.nix
|
||||
|
|
57
modules/services/networking/dnsmasq.nix
Normal file
57
modules/services/networking/dnsmasq.nix
Normal file
|
@ -0,0 +1,57 @@
|
|||
{ config, pkgs, ... }:
|
||||
|
||||
with pkgs.lib;
|
||||
|
||||
let
|
||||
cfg = config.services.dnsmasq;
|
||||
dnsmasq = pkgs.dnsmasq;
|
||||
|
||||
serversParam = concatMapStrings (s: "-S ${s} ") cfg.servers;
|
||||
|
||||
in
|
||||
|
||||
{
|
||||
|
||||
###### interface
|
||||
|
||||
options = {
|
||||
|
||||
services.dnsmasq = {
|
||||
|
||||
enable = mkOption {
|
||||
default = true;
|
||||
description = ''
|
||||
Whether to run dnsmasq.
|
||||
'';
|
||||
};
|
||||
|
||||
servers = mkOption {
|
||||
default = [];
|
||||
example = [ "8.8.8.8" "8.8.4.4" ];
|
||||
description = ''
|
||||
The parameter to dnsmasq -S.
|
||||
'';
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
|
||||
###### implementation
|
||||
|
||||
config = mkIf config.services.dnsmasq.enable {
|
||||
|
||||
jobs.dnsmasq =
|
||||
{ description = "dnsmasq daemon";
|
||||
|
||||
startOn = "ip-up";
|
||||
|
||||
daemonType = "daemon";
|
||||
|
||||
exec = "${dnsmasq}/bin/dnsmasq -R ${serversParam}";
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
}
|
Loading…
Reference in a new issue