diff options
author | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-06-25 22:55:26 +0300 |
---|---|---|
committer | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-06-25 23:35:46 +0300 |
commit | a5551af9b3033b8a83531d65f54b5e5e4cfc5502 (patch) | |
tree | c1e3b85674c4a209e49005e39d7ca1ad435a7dc1 /aconf/modules | |
parent | a0e697b34e270e97ea35aa567ba1c58ecbd63f1c (diff) | |
download | aconf-a5551af9b3033b8a83531d65f54b5e5e4cfc5502.tar.bz2 aconf-a5551af9b3033b8a83531d65f54b5e5e4cfc5502.tar.xz |
dnsmasq module
Diffstat (limited to 'aconf/modules')
-rw-r--r-- | aconf/modules/dnsmasq.lua | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/aconf/modules/dnsmasq.lua b/aconf/modules/dnsmasq.lua new file mode 100644 index 0000000..c61a1f5 --- /dev/null +++ b/aconf/modules/dnsmasq.lua @@ -0,0 +1,49 @@ +--[[ +Copyright (c) 2012-2014 Kaarle Ritvanen +See LICENSE file for license details +--]] + +local M = require('aconf.model') + +local filter_conf = '/etc/dnsmasq-filter.conf' + +local Address = M.new() +Address.address = M.net.IPAddress{addr='&'} +Address.domain = M.String + +local Filter = M.new() +Filter.enabled = M.Boolean{ + compute=function(obj) + return M.node.contains(obj:fetch('../conf-file'), filter_conf) + end, + store=function(obj, value) + local files = obj:fetch('../conf-file') + if value then M.node.insert(files, filter_conf) + else files[filter_conf] = nil end + end +} +Filter.redirect_address = M.net.IPAddress{ + compute=function(obj) + local addr = obj.address + return addr and addr.address + end, + store=function(obj, value) + obj.address = value and {address=value, domain='#'} or nil + end +} +Filter.address = M.Model{model=Address, visible=false} +Filter.whitelist = M.Set{ + type=M.net.DomainName, + addr='server/@/#/domain/#', + ui_name='Domain whitelist', + widget='inline' +} + +local Dnsmasq = M.new() +Dnsmasq.filter = M.Model{model=Filter, addr='/augeas'..filter_conf} +Dnsmasq.conf_file = M.Set{ + type=M.String, addr='/augeas/etc/dnsmasq.conf/conf-file/#', visible=false +} + +M.register('dnsmasq', Dnsmasq) +M.permission.defaults('/dnsmasq') |