X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fsetting.pp;h=ab844602326bc166d1cc6bf934db19905cbea098;hb=044fb5faf545f1336c949bd5667da3d5dda2fa1f;hp=7740fd6e24c7b5deb3220bfae1242f0f4718485e;hpb=e0f058cc209e89451e36ed631161c1bc82d62383;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/setting.pp b/manifests/setting.pp index 7740fd6..ab84460 100644 --- a/manifests/setting.pp +++ b/manifests/setting.pp @@ -1,14 +1,11 @@ define apt::setting ( - $setting_type, - $priority = 50, - $ensure = file, - $source = undef, - $content = undef, - $file_perms = {}, + $priority = 50, + $ensure = file, + $source = undef, + $content = undef, + $notify_update = true, ) { - $_file = merge($::apt::file_defaults, $file_perms) - if $content and $source { fail('apt::setting cannot have both content and source') } @@ -17,12 +14,18 @@ define apt::setting ( fail('apt::setting needs either of content or source') } - validate_re($setting_type, ['conf', 'pref', 'list']) validate_re($ensure, ['file', 'present', 'absent']) + validate_bool($notify_update) + + $title_array = split($title, '-') + $setting_type = $title_array[0] + $base_name = join(delete_at($title_array, 0), '-') + + validate_re($setting_type, ['\Aconf\z', '\Apref\z', '\Alist\z'], "apt::setting resource name/title must start with either 'conf-', 'pref-' or 'list-'") unless is_integer($priority) { # need this to allow zero-padded priority. - validate_re($priority, '^\d+$', 'apt::setting priority must be an integer or a zero-padded integer.') + validate_re($priority, '^\d+$', 'apt::setting priority must be an integer or a zero-padded integer') } if $source { @@ -42,12 +45,19 @@ define apt::setting ( $_path = $::apt::config_files[$setting_type]['path'] $_ext = $::apt::config_files[$setting_type]['ext'] - file { "${_path}/${_priority}${title}${_ext}": + if $notify_update { + $_notify = Exec['apt_update'] + } else { + $_notify = undef + } + + file { "${_path}/${_priority}${base_name}${_ext}": ensure => $ensure, - owner => $_file['owner'], - group => $_file['group'], - mode => $_file['mode'], + owner => 'root', + group => 'root', + mode => '0644', content => $content, source => $source, + notify => $_notify, } }