X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=modules%2Fssl%2Fmanifests%2Finit.pp;h=756661e06be479782aefc6ef80a16f1d50356a22;hb=0e375233af569acc80ddd55b3e0b4d522eabb04c;hp=9e900bec118e2f7cd8b866e225c0b5704c01fa3c;hpb=2a0513f8f6987fadbcb1dd0e5207a4e80933f91a;p=mirror%2Fdsa-puppet.git diff --git a/modules/ssl/manifests/init.pp b/modules/ssl/manifests/init.pp index 9e900bec1..756661e06 100644 --- a/modules/ssl/manifests/init.pp +++ b/modules/ssl/manifests/init.pp @@ -131,9 +131,18 @@ class ssl { require => Package['ssl-cert'], } - file { '/usr/local/sbin/update-ca-certificates-dsa': - mode => '0555', - source => 'puppet:///modules/ssl/update-ca-certificates-dsa', + $updatecacertsdsa = '/usr/local/sbin/update-ca-certificates-dsa' + if (versioncmp($::lsbmajdistrelease, '9') >= 0) { + file { $updatecacertsdsa: + ensure => absent, + } + $updatecacerts = '/usr/sbin/update-ca-certificates' + } else { + file { $updatecacertsdsa: + mode => '0555', + source => 'puppet:///modules/ssl/update-ca-certificates-dsa', + } + $updatecacerts = $updatecacertsdsa } exec { 'retire_debian_links': @@ -147,34 +156,40 @@ class ssl { refreshonly => true, require => Package['openssl'], } + if $::hostname == 'godard' { + $extra_ssl_certs_flags = ' --default' + } else { + $extra_ssl_certs_flags = '' + } + exec { 'refresh_normal_hashes': # NOTE 1: always use update-ca-certificates to manage hashes in # /etc/ssl/certs otherwise /etc/ssl/ca-certificates.crt will # get a hash overriding the hash that would have been generated # for another certificate ... which is problem, comrade # NOTE 2: always ask update-ca-certificates to freshen (-f) the links - command => '/usr/sbin/update-ca-certificates -f', + command => "/usr/sbin/update-ca-certificates --fresh${extra_ssl_certs_flags}", refreshonly => true, require => Package['ca-certificates'], } exec { 'refresh_ca_debian_hashes': - command => '/usr/local/sbin/update-ca-certificates-dsa --fresh --certsconf /etc/ca-certificates-debian.conf --localcertsdir /dev/null --etccertsdir /etc/ssl/ca-debian --hooksdir /dev/null', + command => "${updatecacerts} --fresh --certsconf /etc/ca-certificates-debian.conf --localcertsdir /dev/null --etccertsdir /etc/ssl/ca-debian --hooksdir /dev/null", refreshonly => true, require => [ Package['ca-certificates'], File['/etc/ssl/ca-debian'], File['/etc/ca-certificates-debian.conf'], - File['/usr/local/sbin/update-ca-certificates-dsa'], + File[$updatecacertsdsa], ] } exec { 'refresh_ca_global_hashes': - command => '/usr/local/sbin/update-ca-certificates-dsa --fresh --default --certsconf /etc/ca-certificates-global.conf --etccertsdir /etc/ssl/ca-global --hooksdir /dev/null', + command => "${updatecacerts} --fresh --default --certsconf /etc/ca-certificates-global.conf --etccertsdir /etc/ssl/ca-global --hooksdir /dev/null", refreshonly => true, require => [ Package['ca-certificates'], File['/etc/ssl/ca-global'], File['/etc/ca-certificates-global.conf'], - File['/usr/local/sbin/update-ca-certificates-dsa'], + File[$updatecacertsdsa], ] }