diff --git a/manifests/zone.pp b/manifests/zone.pp index dfbae160..cd552691 100644 --- a/manifests/zone.pp +++ b/manifests/zone.pp @@ -127,9 +127,9 @@ # # [*zone_type*] # The type of DNS zone being described. Can be one of `master`, `slave` -# (requires *slave_masters* to be set), or `forward` (requires both -# *allow_forwarder* and *forward_policy* to be set). Defaults to -# `master`. +# (requires *slave_masters* to be set), `delegation-only`, or `forward` +# (requires both *allow_forwarder* and *forward_policy* to be set). +# Defaults to `master`. # define dns::zone ( $soa = $::fqdn, @@ -170,6 +170,13 @@ default => $name } + validate_string($zone_type) + $valid_zone_type_array = ['master', 'slave', 'forward', 'delegation-only'] + if !member($valid_zone_type_array, $zone_type) { + $valid_zone_type_array_str = join($valid_zone_type_array, ',') + fail("The zone_type must be one of [${valid_zone_type_array}]") + } + $zone_file = "${dns::server::params::data_dir}/db.${name}" $zone_file_stage = "${zone_file}.stage" diff --git a/spec/defines/dns__zone_spec.rb b/spec/defines/dns__zone_spec.rb index 5df5f4d9..3dd84297 100644 --- a/spec/defines/dns__zone_spec.rb +++ b/spec/defines/dns__zone_spec.rb @@ -76,6 +76,18 @@ end end + context 'with a delegation-only zone' do + let :params do + { :zone_type => 'delegation-only' + } + end + it 'should only have a type delegation-only entry' do + should contain_concat__fragment('named.conf.local.test.com.include'). + with_content(/zone \"test.com\" \{\s*type delegation-only;\s*\}/) + end + end + + context 'with a forward zone' do let :params do { :allow_transfer => ['123.123.123.123'], diff --git a/templates/zone.erb b/templates/zone.erb index 321d0d6a..722fb5d5 100644 --- a/templates/zone.erb +++ b/templates/zone.erb @@ -10,7 +10,7 @@ type <%= @zone_type %>; <%- end -%> }; <% end -%> -<% if @zone_type != 'forward' -%> +<% if (@zone_type != 'forward') && (@zone_type != 'delegation-only')-%> file "<%= @zone_file %>"; <% end -%> <% if @zone_type == 'slave' -%>