X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fpin.pp;h=dff2c297c0c08b3d6f353e69a1d88732dbc904a2;hb=a71dfd168296f12207749131d4f734ae671622a4;hp=a6e3cf8e29cceebd65a772cf42525a2d2f8d0375;hpb=501a1b5627687b13c0809b82db03f9df168fbd7a;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/pin.pp b/manifests/pin.pp index a6e3cf8..dff2c29 100644 --- a/manifests/pin.pp +++ b/manifests/pin.pp @@ -3,8 +3,8 @@ define apt::pin( $ensure = present, - $explanation = "${caller_module_name}: ${name}", - $order = '', + $explanation = undef, + $order = 50, $packages = '*', $priority = 0, $release = '', # a= @@ -16,12 +16,20 @@ define apt::pin( $originator = '', # o= $label = '' # l= ) { - $preferences_d = $apt::params::preferences_d - - if $order != '' and !is_integer($order) { + if $order and !is_integer($order) { fail('Only integers are allowed in the apt::pin order param') } + if $explanation { + $_explanation = $explanation + } else { + if defined('$caller_module_name') { # strict vars check + $_explanation = "${caller_module_name}: ${name}" + } else { + $_explanation = ": ${name}" + } + } + $pin_release_array = [ $release, $codename, @@ -54,7 +62,6 @@ define apt::pin( } } - # According to man 5 apt_preferences: # The files have either no or "pref" as filename extension # and only contain alphanumeric, hyphen (-), underscore (_) and period @@ -64,16 +71,10 @@ define apt::pin( # be silently ignored. $file_name = regsubst($title, '[^0-9a-z\-_\.]', '_', 'IG') - $path = $order ? { - '' => "${preferences_d}/${file_name}.pref", - default => "${preferences_d}/${order}-${file_name}.pref", - } - file { "${file_name}.pref": - ensure => $ensure, - path => $path, - owner => root, - group => root, - mode => '0644', - content => template('apt/_header.erb', 'apt/pin.pref.erb'), + apt::setting { "pref-${file_name}": + ensure => $ensure, + priority => $order, + content => template('apt/_header.erb', 'apt/pin.pref.erb'), + notify_update => false, } }