X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fsetting.pp;h=a3fc3630bd5b6e3f4a1f0c9c40ae1c621217d60b;hb=refs%2Fheads%2Fpdksync_CONT-844-update_.sync.yml;hp=7740fd6e24c7b5deb3220bfae1242f0f4718485e;hpb=e0f058cc209e89451e36ed631161c1bc82d62383;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/setting.pp b/manifests/setting.pp index 7740fd6..a3fc363 100644 --- a/manifests/setting.pp +++ b/manifests/setting.pp @@ -1,14 +1,31 @@ +# @summary Manages Apt configuration files. +# +# @see https://docs.puppetlabs.com/references/latest/type.html#file-attributes for more information on source and content parameters +# +# @param priority +# Determines the order in which Apt processes the configuration file. Files with higher priority numbers are loaded first. +# +# @param ensure +# Specifies whether the file should exist. Valid options: 'present', 'absent', and 'file'. +# +# @param source +# Required, unless `content` is set. Specifies a source file to supply the content of the configuration file. Cannot be used in combination +# with `content`. Valid options: see link above for Puppet's native file type source attribute. +# +# @param content +# Required, unless `source` is set. Directly supplies content for the configuration file. Cannot be used in combination with `source`. Valid +# options: see link above for Puppet's native file type content attribute. +# +# @param notify_update +# Specifies whether to trigger an `apt-get update` run. +# define apt::setting ( - $setting_type, - $priority = 50, - $ensure = file, - $source = undef, - $content = undef, - $file_perms = {}, + Variant[String, Integer, Array] $priority = 50, + Enum['file', 'present', 'absent'] $ensure = file, + Optional[String] $source = undef, + Optional[String] $content = undef, + Boolean $notify_update = true, ) { - - $_file = merge($::apt::file_defaults, $file_perms) - if $content and $source { fail('apt::setting cannot have both content and source') } @@ -17,37 +34,42 @@ 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']) - - 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.') - } + $title_array = split($title, '-') + $setting_type = $title_array[0] + $base_name = join(delete_at($title_array, 0), '-') - if $source { - validate_string($source) + assert_type(Pattern[/\Aconf\z/, /\Apref\z/, /\Alist\z/], $setting_type) |$a, $b| { + fail("apt::setting resource name/title must start with either 'conf-', 'pref-' or 'list-'") } - if $content { - validate_string($content) + if $priority !~ Integer { + # need this to allow zero-padded priority. + assert_type(Pattern[/^\d+$/], $priority) |$a, $b| { + fail('apt::setting priority must be an integer or a zero-padded integer') + } } - if $setting_type == 'list' { + if ($setting_type == 'list') or ($setting_type == 'pref') { $_priority = '' } else { $_priority = $priority } - $_path = $::apt::config_files[$setting_type]['path'] - $_ext = $::apt::config_files[$setting_type]['ext'] + $_path = $apt::config_files[$setting_type]['path'] + $_ext = $apt::config_files[$setting_type]['ext'] + + if $notify_update { + $_notify = Class['apt::update'] + } else { + $_notify = undef + } - file { "${_path}/${_priority}${title}${_ext}": + file { "${_path}/${_priority}${base_name}${_ext}": ensure => $ensure, - owner => $_file['owner'], - group => $_file['group'], - mode => $_file['mode'], + owner => 'root', + group => 'root', content => $content, source => $source, + notify => $_notify, } }