X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=modules%2Fresolv%2Ftemplates%2Fresolv.conf.erb;h=2e1968b639785d625a38b1cd0e45ffbf58e5ad7d;hb=ab9d167e68d57e55ce0c52785b21d4122e1c0f9f;hp=e8873c88f382f6c095ddc64ddaff80d7fbfe4a50;hpb=be6f9a8aa7f4bc626fd97883de5ec06d0e5b7e65;p=mirror%2Fdsa-puppet.git diff --git a/modules/resolv/templates/resolv.conf.erb b/modules/resolv/templates/resolv.conf.erb index e8873c88f..2e1968b63 100644 --- a/modules/resolv/templates/resolv.conf.erb +++ b/modules/resolv/templates/resolv.conf.erb @@ -3,15 +3,42 @@ ### USE: git clone git+ssh://$USER@puppet.debian.org/srv/puppet.debian.org/git/dsa-puppet.git ### -<%= resolvconf = case hoster - when "ubcece" then "search debprivate-ubc.debian.org debian.org -nameserver 206.12.19.5 -nameserver 137.82.1.1 -nameserver 142.103.1.1 -" +<%= +nameservers = [] +searchpaths = [] +options = [] +resolvconf = '' + +if %w{draghi}.include?(hostname) + nameservers << "127.0.0.1" end -if resolvconf == "" - raise Puppet::ParseError, "resolv.conf is empty" + +nameservers += scope.lookupvar('ns') +searchpaths += scope.lookupvar('sp') +options += scope.lookupvar('opts') + +searchpaths << "debian.org" + +resolvconf += "search " + searchpaths.to_a.flatten.join(" ") + "\n" + +if has_variable?('unbound') and unbound and unbound == "true" + resolvconf += "nameserver 127.0.0.1\n" +else + if nameservers.empty? + #raise Puppet::ParseError, "Something has gone wrong writing resolv.conf. No nameservers to use!" + scope.function_warning(["Something has gone wrong writing resolv.conf. No nameservers to use - using google's!"]) + nameservers << '8.8.8.8' + nameservers << '8.8.4.4' + end + + nameservers.to_a.flatten.each do |ns| + resolvconf += "nameserver " + ns + "\n" + end +end + +options.to_a.flatten.each do |opt| + resolvconf += "options " + opt + "\n" end + resolvconf %>