X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=modules%2Fresolv%2Ftemplates%2Fresolv.conf.erb;h=9bc11ba9664e90a63b189e5d328aad840e14ce15;hb=a46da6bd7b246ce960c5bd1d484597b79c05521a;hp=d612f753bdd9f5559f45e8798052e212503653e3;hpb=e733600e917f78330b957715d1a2cf6d06c18963;p=dsa-puppet.git diff --git a/modules/resolv/templates/resolv.conf.erb b/modules/resolv/templates/resolv.conf.erb index d612f753..9bc11ba9 100644 --- a/modules/resolv/templates/resolv.conf.erb +++ b/modules/resolv/templates/resolv.conf.erb @@ -6,43 +6,35 @@ <%= nameservers = [] searchpaths = [] -resolvconf = '' +options = [] -case hoster - when "darmstadt" then - case hostname - when "draghi", "liszt" then - nameservers << "127.0.0.1" - end - nameservers += ["82.195.75.81", "82.195.66.249", "217.198.242.225"] - searchpaths << "debprivate-darmstadt.debian.org" - when "ftcollins" then - case hostname - when "spohr", "samosa" then - nameservers << "127.0.0.1" - end - nameservers += ["192.25.206.33", "192.25.206.57"] - searchpaths << "debprivate-ftcollins.debian.org" - when "grnet" then - nameservers += ["194.177.210.10", "194.177.210.210"] - searchpaths << "debprivate-grnet.debian.org" - when "osousl" then - nameserver += ["140.211.166.130","140.211.166.131"] - searchpaths << "debprivate-osuosl.debian.org" - when "ubcece" then - nameservers += ["206.12.19.5", "137.82.1.1", "142.103.1.1" ] - searchpaths << "debprivate-ubc.debian.org" +if %w{draghi liszt widor spohr}.include?(hostname) + nameservers << "127.0.0.1" end +nameservers += nodeinfo['hoster']['nameservers'] if nodeinfo['hoster']['nameservers'] +searchpaths += nodeinfo['hoster']['searchpaths'] if nodeinfo['hoster']['searchpaths'] +options += nodeinfo['hoster']['resolvoptions'] if nodeinfo['hoster']['resolvoptions'] + searchpaths << "debian.org" -if nameservers.empty? - raise Puppet::ParseError, "Something has gone wrong writing resolv.conf: probably included for wrong hoster" +resolvconf = '' +resolvconf += "search " + searchpaths.join(" ") + "\n" + +if runs_local_resolver + 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!" + end + + nameservers.each do |ns| + resolvconf += "nameserver " + ns + "\n" + end end -resolvconf += "search " + searchpaths.join(" ") + "\n" -nameservers.each do |ns| - resolvconf += "nameserver " + ns + "\n" +options.each do |opt| + resolvconf += "options " + opt + "\n" end resolvconf