2011-04-13 14:09:02 +00:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
|
|
|
with pkgs.lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.dnsmasq;
|
|
|
|
dnsmasq = pkgs.dnsmasq;
|
|
|
|
|
|
|
|
serversParam = concatMapStrings (s: "-S ${s} ") cfg.servers;
|
|
|
|
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
###### interface
|
2011-09-14 18:20:50 +00:00
|
|
|
|
2011-04-13 14:09:02 +00:00
|
|
|
options = {
|
2011-09-14 18:20:50 +00:00
|
|
|
|
2011-04-13 14:09:02 +00:00
|
|
|
services.dnsmasq = {
|
|
|
|
|
|
|
|
enable = mkOption {
|
2011-04-19 13:37:31 +00:00
|
|
|
default = false;
|
2011-04-13 14:09:02 +00:00
|
|
|
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 {
|
2011-09-14 18:20:50 +00:00
|
|
|
|
2011-04-13 14:09:02 +00:00
|
|
|
jobs.dnsmasq =
|
|
|
|
{ description = "dnsmasq daemon";
|
|
|
|
|
|
|
|
startOn = "ip-up";
|
|
|
|
|
|
|
|
daemonType = "daemon";
|
|
|
|
|
|
|
|
exec = "${dnsmasq}/bin/dnsmasq -R ${serversParam}";
|
|
|
|
};
|
2011-09-14 18:20:50 +00:00
|
|
|
|
2011-04-13 14:09:02 +00:00
|
|
|
};
|
2011-09-14 18:20:50 +00:00
|
|
|
|
2011-04-13 14:09:02 +00:00
|
|
|
}
|