From: Peter Palfrader Date: Fri, 23 Sep 2016 20:35:09 +0000 (+0000) Subject: A gen_hpkp_pin function X-Git-Url: https://git.adam-barratt.org.uk/?a=commitdiff_plain;h=ce8481b3cd1c29351bfe211d48495b4494dd2252;p=mirror%2Fdsa-puppet.git A gen_hpkp_pin function --- diff --git a/modules/puppetmaster/lib/puppet/parser/functions/gen_hpkp_pin.rb b/modules/puppetmaster/lib/puppet/parser/functions/gen_hpkp_pin.rb new file mode 100644 index 000000000..f14a6fcba --- /dev/null +++ b/modules/puppetmaster/lib/puppet/parser/functions/gen_hpkp_pin.rb @@ -0,0 +1,30 @@ +module Puppet::Parser::Functions + newfunction(:gen_hpkp_pin, :type => :rvalue) do |args| + site = args.shift() + + pin_info = [] + pinfiles = [ "/srv/puppet.debian.org/from-letsencrypt/#{site}.pin", + "/srv/puppet.debian.org/backup-keys/#{site}.pin" ] + pinfiles.each do |fn| + if File.exist?(fn) + pin_info << File.read(fn).chomp() + end + end + + res = [] + res << "" + if pin_info.size >= 2 then + pin_info = pin_info.map{ |x| x.gsub('"', '\"') } + pin_info << "max-age=300" + pin_str = pin_info.join("; ") + res << " Header set Public-Key-Pins \"#{pin_str}\"" + else + res << " # mod macro does not like empty macros, so here's some content:" + res << " " + res << " " + end + res << "" + res << "" + return res.join("\n") + end +end