X-Git-Url: https://git.donarmstrong.com/?p=dsa-puppet.git;a=blobdiff_plain;f=modules%2Fpuppetmaster%2Flib%2Fpuppet%2Fparser%2Ffunctions%2Fgen_tlsa_entry.rb;h=baaa73b4dfcd59c08d54597a9ba0d73fe0bc180f;hp=7c07b7c9fcf5d5b978821ef7eb4ad7e373a6a27f;hb=d32b5ca2040af0e861851c5519aa5ff5b7887768;hpb=b41bbe0bcc0ca74548ff8e99c3014452a7dc64f2 diff --git a/modules/puppetmaster/lib/puppet/parser/functions/gen_tlsa_entry.rb b/modules/puppetmaster/lib/puppet/parser/functions/gen_tlsa_entry.rb index 7c07b7c9..baaa73b4 100644 --- a/modules/puppetmaster/lib/puppet/parser/functions/gen_tlsa_entry.rb +++ b/modules/puppetmaster/lib/puppet/parser/functions/gen_tlsa_entry.rb @@ -4,13 +4,33 @@ module Puppet::Parser::Functions hostname = args.shift() port = args.shift() - if File.exist?(certfile) - cmd = ['swede', 'create', '--usage=3', '--selector=1', '--mtype=1', '--certificate', certfile, '--port', port.to_s, hostname] - IO.popen(cmd, "r") {|i| - return i.read - } + if port.kind_of?(Array) + ports = port else - return "; certfile #{certfile} did not exist to create TLSA record for #{hostname}:#{port}." + ports = [port] end + + res = [] + res << "; cert #{certfile} for #{hostname}:#{ports}." + ports.each do |port| + cf = certfile + if File.exist?(cf) + cmd = ['swede', 'create', '--usage=3', '--selector=1', '--mtype=1', '--certificate', cf, '--port', port.to_s, hostname] + IO.popen(cmd, "r") {|i| res << i.read } + else + res << "; certfile #{cf} did not exist to create TLSA record for #{hostname}:#{port}." + end + + if cf.gsub!(/\.crt$/, '-new.crt') and File.exist?(cf) + cmd = ['swede', 'create', '--usage=3', '--selector=1', '--mtype=1', '--certificate', cf, '--port', port.to_s, hostname] + new_entry = '' + IO.popen(cmd, "r") {|i| new_entry = i.read } + if not res.include?(new_entry) + res << new_entry + end + end + end + + return res.join("\n") end end