From ec5e855c48531227f5f9fa0b7ca3d26e2617cbcd Mon Sep 17 00:00:00 2001 From: Kenyon Ralph Date: Mon, 8 Apr 2024 22:56:16 -0700 Subject: [PATCH 1/9] init: trim trailing whitespace --- manifests/init.pp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/manifests/init.pp b/manifests/init.pp index 78882733df..70a336821b 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -40,7 +40,7 @@ # Specifies how often to run `apt-get update`. If the exec resource `apt_update` is notified, # `apt-get update` runs regardless of this value. # Valid options: -# 'always' (at every Puppet run); +# 'always' (at every Puppet run); # 'hourly' (if the value of `apt_update_last_success` is less than current epoch time minus 3600); # 'daily' (if the value of `apt_update_last_success` is less than current epoch time minus 86400); # 'weekly' (if the value of `apt_update_last_success` is less than current epoch time minus 604800); From aa9e518ac433e8663dcda23e8e7c48070b00d8b1 Mon Sep 17 00:00:00 2001 From: Kenyon Ralph Date: Mon, 8 Apr 2024 22:57:58 -0700 Subject: [PATCH 2/9] init, source: improve hash formatting The $auth_conf_tmp line should be multiple lines for readability and easier to read diffs when changes occur. Double-indented blocks look wrong. Placing the opening bracket on its own line fixes this. --- manifests/init.pp | 6 +++++- manifests/source.pp | 8 +++++--- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/manifests/init.pp b/manifests/init.pp index 70a336821b..8de99d5fcb 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -374,7 +374,11 @@ default => 'present', } - $auth_conf_tmp = stdlib::deferrable_epp('apt/auth_conf.epp', { 'auth_conf_entries' => $auth_conf_entries }) + $auth_conf_tmp = stdlib::deferrable_epp('apt/auth_conf.epp', + { + 'auth_conf_entries' => $auth_conf_entries, + }, + ) file { '/etc/apt/auth.conf': ensure => $auth_conf_ensure, diff --git a/manifests/source.pp b/manifests/source.pp index 5c64dd1ed2..70f78e17d0 100644 --- a/manifests/source.pp +++ b/manifests/source.pp @@ -209,10 +209,12 @@ $_architecture = undef } - $sourcelist = epp('apt/source.list.epp', { + $sourcelist = epp('apt/source.list.epp', + { 'comment' => $comment, 'includes' => $includes, - 'options' => delete_undef_values({ + 'options' => delete_undef_values( + { 'arch' => $_architecture, 'trusted' => $allow_unsigned ? { true => 'yes', false => undef }, 'allow-insecure' => $allow_insecure ? { true => 'yes', false => undef }, @@ -222,7 +224,7 @@ ), 'location' => $_location, 'components' => $_components, - } + }, ) apt::setting { "list-${name}": From 2faa817dcb05821bd9c27bbe8bf1955e6b2442f2 Mon Sep 17 00:00:00 2001 From: Kenyon Ralph Date: Mon, 8 Apr 2024 23:02:21 -0700 Subject: [PATCH 3/9] eliminate params.pp and create_resources() params.pp and create_resources() are obsolete. This module was converted to non-params.pp style #667, but was reverted in #680. Using Hiera in modules and no params.pp are the preferred styles these days. --- data/os/Debian.yaml | 3 + data/os/Ubuntu.yaml | 7 ++ manifests/init.pp | 168 ++++++++++++++++++++++++++++---------------- manifests/params.pp | 107 ---------------------------- manifests/source.pp | 13 ++-- 5 files changed, 124 insertions(+), 174 deletions(-) create mode 100644 data/os/Debian.yaml create mode 100644 data/os/Ubuntu.yaml delete mode 100644 manifests/params.pp diff --git a/data/os/Debian.yaml b/data/os/Debian.yaml new file mode 100644 index 0000000000..e7cc38af75 --- /dev/null +++ b/data/os/Debian.yaml @@ -0,0 +1,3 @@ +apt::backports: + location: http://deb.debian.org/debian + repos: main contrib non-free diff --git a/data/os/Ubuntu.yaml b/data/os/Ubuntu.yaml new file mode 100644 index 0000000000..20bf4318ba --- /dev/null +++ b/data/os/Ubuntu.yaml @@ -0,0 +1,7 @@ +apt::backports: + location: http://archive.ubuntu.com/ubuntu + repos: main universe multiverse restricted + +apt::ppa_options: + - -y +apt::ppa_package: software-properties-common diff --git a/manifests/init.pp b/manifests/init.pp index 8de99d5fcb..5ad48433f5 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -31,7 +31,7 @@ # See apt::backports for documentation. # # @param confs -# Creates new `apt::conf` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::conf` resources. # # @param update # Configures various update settings. Valid options: a hash made up from the following keys: @@ -85,22 +85,22 @@ # The default proxy settings that are combined and merged with the passed `proxy` value # # @param sources -# Creates new `apt::source` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::source` resources. # # @param keys -# Creates new `apt::key` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::key` resources. # # @param keyrings # Hash of `apt::keyring` resources. # # @param ppas -# Creates new `apt::ppa` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::ppa` resources. # # @param pins -# Creates new `apt::pin` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::pin` resources. # # @param settings -# Creates new `apt::setting` resources. Valid options: a hash to be passed to the create_resources function linked above. +# Hash of `apt::setting` resources. # # @param manage_auth_conf # Specifies whether to manage the /etc/apt/auth.conf file. When true, the file will be overwritten with the entries specified in @@ -113,7 +113,7 @@ # password and no others. Specifying manage_auth_conf and not specifying this parameter will set /etc/apt/auth.conf to absent. # # @param auth_conf_owner -# The owner of the file /etc/apt/auth.conf. Default: '_apt' or 'root' on old releases. +# The owner of the file /etc/apt/auth.conf. # # @param root # Specifies root directory of Apt executable. @@ -137,9 +137,10 @@ # A hash made up of the various configuration files used by Apt. # # @param sources_list_force -# Specifies whether to perform force purge or delete. Default false. +# Specifies whether to perform force purge or delete. # # @param include_defaults +# The package types to include by default. # # @param apt_conf_d # The path to the file `apt.conf.d` @@ -148,47 +149,79 @@ # The fault `source_key` settings # class apt ( - Hash $update_defaults = $apt::params::update_defaults, - Hash $purge_defaults = $apt::params::purge_defaults, - Hash $proxy_defaults = $apt::params::proxy_defaults, - Hash $include_defaults = $apt::params::include_defaults, - String $provider = $apt::params::provider, - String $keyserver = $apt::params::keyserver, - Optional[String] $key_options = $apt::params::key_options, - Optional[Array[String]] $ppa_options = $apt::params::ppa_options, - Optional[String] $ppa_package = $apt::params::ppa_package, - Optional[Hash] $backports = $apt::params::backports, - Hash $confs = $apt::params::confs, - Hash $update = $apt::params::update, - Hash $purge = $apt::params::purge, - Apt::Proxy $proxy = $apt::params::proxy, - Hash $sources = $apt::params::sources, - Hash $keys = $apt::params::keys, - Hash $keyrings = {}, - Hash $ppas = $apt::params::ppas, - Hash $pins = $apt::params::pins, - Hash $settings = $apt::params::settings, - Boolean $manage_auth_conf = $apt::params::manage_auth_conf, - Array[Apt::Auth_conf_entry] $auth_conf_entries = $apt::params::auth_conf_entries, - String $auth_conf_owner = $apt::params::auth_conf_owner, - String $root = $apt::params::root, - String $sources_list = $apt::params::sources_list, - String $sources_list_d = $apt::params::sources_list_d, - String $conf_d = $apt::params::conf_d, - String $preferences = $apt::params::preferences, - String $preferences_d = $apt::params::preferences_d, - String $apt_conf_d = $apt::params::apt_conf_d, - Hash $config_files = $apt::params::config_files, - Boolean $sources_list_force = $apt::params::sources_list_force, - + Hash $update_defaults = { + 'frequency' => 'reluctantly', + 'loglevel' => undef, + 'timeout' => undef, + 'tries' => undef, + }, + Hash $purge_defaults = { + 'sources.list' => false, + 'sources.list.d' => false, + 'preferences' => false, + 'preferences.d' => false, + 'apt.conf.d' => false, + }, + Hash $proxy_defaults = { + 'ensure' => undef, + 'host' => undef, + 'port' => 8080, + 'https' => false, + 'https_acng' => false, + 'direct' => false, + }, + Hash $include_defaults = { + 'deb' => true, + 'src' => false, + }, + String $provider = '/usr/bin/apt-get', + String $keyserver = 'keyserver.ubuntu.com', + Optional[String] $key_options = undef, + Optional[Array[String]] $ppa_options = undef, + Optional[String] $ppa_package = undef, + Optional[Hash] $backports = undef, + Hash $confs = {}, + Hash $update = {}, + Hash $purge = {}, + Apt::Proxy $proxy = {}, + Hash $sources = {}, + Hash $keys = {}, + Hash $keyrings = {}, + Hash $ppas = {}, + Hash $pins = {}, + Hash $settings = {}, + Boolean $manage_auth_conf = true, + Array[Apt::Auth_conf_entry] $auth_conf_entries = [], + String $auth_conf_owner = '_apt', + String $root = '/etc/apt', + String $sources_list = "${root}/sources.list", + String $sources_list_d = "${root}/sources.list.d", + String $conf_d = "${root}/apt.conf.d", + String $preferences = "${root}/preferences", + String $preferences_d = "${root}/preferences.d", + String $apt_conf_d = "${root}/apt.conf.d", + Hash $config_files = { + 'conf' => { + 'path' => $conf_d, + 'ext' => '', + }, + 'pref' => { + 'path' => $preferences_d, + 'ext' => '.pref', + }, + 'list' => { + 'path' => $sources_list_d, + 'ext' => '.list', + }, + }, + Boolean $sources_list_force = false, Hash $source_key_defaults = { 'server' => $keyserver, 'options' => undef, 'content' => undef, 'source' => undef, - } - -) inherits apt::params { + }, +) { if $facts['os']['family'] != 'Debian' { fail('This module only works on Debian or derivatives like Ubuntu') } @@ -342,30 +375,40 @@ notify => Class['apt::update'], } - if $confs { - create_resources('apt::conf', $confs) + $confs.each |$key, $value| { + apt::conf { $key: + * => $value, + } } - # manage sources if present - if $sources { - create_resources('apt::source', $sources) + + $sources.each |$key, $value| { + apt::source { $key: + * => $value, + } } - # manage keys if present - if $keys { - create_resources('apt::key', $keys) + + $keys.each |$key, $value| { + apt::key { $key: + * => $value, + } } - # manage keyrings if present + $keyrings.each |$key, $data| { apt::keyring { $key: * => $data, } } - # manage ppas if present - if $ppas { - create_resources('apt::ppa', $ppas) + + $ppas.each |$key, $value| { + apt::ppa { $key: + * => $value, + } } - # manage settings if present - if $settings { - create_resources('apt::setting', $settings) + + $settings.each |$key, $value| { + apt::setting { $key: + * => $value, + } } if $manage_auth_conf { @@ -390,9 +433,10 @@ } } - # manage pins if present - if $pins { - create_resources('apt::pin', $pins) + $pins.each |$key, $value| { + apt::pin { $key: + * => $value, + } } case $facts['os']['name'] { diff --git a/manifests/params.pp b/manifests/params.pp deleted file mode 100644 index c2fe0b48b1..0000000000 --- a/manifests/params.pp +++ /dev/null @@ -1,107 +0,0 @@ -# @summary Provides defaults for the Apt module parameters. -# -# @api private -# -class apt::params { - if $facts['os']['family'] != 'Debian' { - fail('This module only works on Debian or derivatives like Ubuntu') - } - - $root = '/etc/apt' - $provider = '/usr/bin/apt-get' - $sources_list = "${root}/sources.list" - $sources_list_force = false - $sources_list_d = "${root}/sources.list.d" - $trusted_gpg_d = "${root}/trusted.gpg.d" - $conf_d = "${root}/apt.conf.d" - $preferences = "${root}/preferences" - $preferences_d = "${root}/preferences.d" - $apt_conf_d = "${root}/apt.conf.d" - $keyserver = 'keyserver.ubuntu.com' - $key_options = undef - $confs = {} - $update = {} - $purge = {} - $proxy = {} - $sources = {} - $keys = {} - $ppas = {} - $pins = {} - $settings = {} - $manage_auth_conf = true - $auth_conf_entries = [] - - $config_files = { - 'conf' => { - 'path' => $conf_d, - 'ext' => '', - }, - 'pref' => { - 'path' => $preferences_d, - 'ext' => '.pref', - }, - 'list' => { - 'path' => $sources_list_d, - 'ext' => '.list', - }, - } - - $update_defaults = { - 'frequency' => 'reluctantly', - 'loglevel' => undef, - 'timeout' => undef, - 'tries' => undef, - } - - $proxy_defaults = { - 'ensure' => undef, - 'host' => undef, - 'port' => 8080, - 'https' => false, - 'https_acng' => false, - 'direct' => false, - } - - $purge_defaults = { - 'sources.list' => false, - 'sources.list.d' => false, - 'preferences' => false, - 'preferences.d' => false, - 'apt.conf.d' => false, - } - - $include_defaults = { - 'deb' => true, - 'src' => false, - } - - case $facts['os']['name'] { - 'Debian': { - $backports = { - 'location' => 'http://deb.debian.org/debian', - 'repos' => 'main contrib non-free', - } - $ppa_options = undef - $ppa_package = undef - $auth_conf_owner = '_apt' - } - 'Ubuntu': { - $backports = { - 'location' => 'http://archive.ubuntu.com/ubuntu', - 'repos' => 'main universe multiverse restricted', - } - $ppa_options = ['-y'] - $ppa_package = 'software-properties-common' - $auth_conf_owner = '_apt' - } - undef: { - fail('Unable to determine value for fact os[\"name\"]') - } - default: { - $ppa_options = undef - $ppa_package = undef - $backports = undef - $auth_conf_owner = 'root' - } - } -} diff --git a/manifests/source.pp b/manifests/source.pp index 70f78e17d0..776c5f7a43 100644 --- a/manifests/source.pp +++ b/manifests/source.pp @@ -28,7 +28,7 @@ # Supplies a comment for adding to the Apt source file. # # @param ensure -# Specifies whether the Apt source file should exist. Valid options: 'present' and 'absent'. +# Specifies whether the Apt source file should exist. # # @param release # Specifies a distribution of the Apt repository. @@ -40,10 +40,10 @@ # Configures include options. Valid options: a hash of available keys. # # @option include [Boolean] :deb -# Specifies whether to request the distribution's compiled binaries. Default true. +# Specifies whether to request the distribution's compiled binaries. # # @option include [Boolean] :src -# Specifies whether to request the distribution's uncompiled source code. Default false. +# Specifies whether to request the distribution's uncompiled source code. # # @param key # Creates an `apt::keyring` in `/etc/apt/keyrings` (or anywhere on disk given `filename`) Valid options: @@ -77,7 +77,7 @@ # Specifies whether to trigger an `apt-get update` run. # # @param check_valid_until -# Specifies whether to check if the package release date is valid. Defaults to `True`. +# Specifies whether to check if the package release date is valid. # define apt::source ( Optional[String] $location = undef, @@ -248,6 +248,9 @@ } else { fail('Received invalid value for pin parameter') } - create_resources('apt::pin', { "${name}" => $_pin }) + + apt::pin { $name: + * => $_pin, + } } } From 5a709c9d790df44f7facf8bb227c90ff0b73d2e5 Mon Sep 17 00:00:00 2001 From: Kenyon Ralph Date: Mon, 8 Apr 2024 23:09:11 -0700 Subject: [PATCH 4/9] regenerate REFERENCE.md --- REFERENCE.md | 141 +++++++++++++++++++++++++++++++++++---------------- 1 file changed, 97 insertions(+), 44 deletions(-) diff --git a/REFERENCE.md b/REFERENCE.md index 4c97d0d543..b3597d71a5 100644 --- a/REFERENCE.md +++ b/REFERENCE.md @@ -13,7 +13,6 @@ #### Private Classes -* `apt::params`: Provides defaults for the Apt module parameters. * `apt::update`: Updates the list of available packages using apt-get update. ### Defined types @@ -99,7 +98,7 @@ Data type: `String` Specifies the provider that should be used by apt::update. -Default value: `$apt::params::provider` +Default value: `'/usr/bin/apt-get'` ##### `keyserver` @@ -108,7 +107,7 @@ Data type: `String` Specifies a keyserver to provide the GPG key. Valid options: a string containing a domain name or a full URL (http://, https://, or hkp://). -Default value: `$apt::params::keyserver` +Default value: `'keyserver.ubuntu.com'` ##### `key_options` @@ -116,7 +115,7 @@ Data type: `Optional[String]` Specifies the default options for apt::key resources. -Default value: `$apt::params::key_options` +Default value: `undef` ##### `ppa_options` @@ -124,7 +123,7 @@ Data type: `Optional[Array[String]]` Supplies options to be passed to the `add-apt-repository` command. -Default value: `$apt::params::ppa_options` +Default value: `undef` ##### `ppa_package` @@ -132,7 +131,7 @@ Data type: `Optional[String]` Names the package that provides the `apt-add-repository` command. -Default value: `$apt::params::ppa_package` +Default value: `undef` ##### `backports` @@ -146,15 +145,15 @@ Options: * **:repos** `String`: See apt::backports for documentation. * **:key** `String`: See apt::backports for documentation. -Default value: `$apt::params::backports` +Default value: `undef` ##### `confs` Data type: `Hash` -Creates new `apt::conf` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::conf` resources. -Default value: `$apt::params::confs` +Default value: `{}` ##### `update` @@ -178,7 +177,7 @@ Default: 'reluctantly'. * **:timeout** `Integer`: Specifies how long to wait for the update to complete before canceling it. Valid options: an integer, in seconds. Default: undef. * **:tries** `Integer`: Specifies how many times to retry the update after receiving a DNS or HTTP error. Default: undef. -Default value: `$apt::params::update` +Default value: `{}` ##### `update_defaults` @@ -186,7 +185,16 @@ Data type: `Hash` The default update settings that are combined and merged with the passed `update` value -Default value: `$apt::params::update_defaults` +Default value: + +```puppet +{ + 'frequency' => 'reluctantly', + 'loglevel' => undef, + 'timeout' => undef, + 'tries' => undef, + } +``` ##### `purge` @@ -201,7 +209,7 @@ Options: * **:preferences** `Boolean`: Specifies whether to purge any unmanaged entries from preferences. Default false. * **:preferences.d.** `Boolean`: Specifies whether to purge any unmanaged entries from preferences.d. Default false. -Default value: `$apt::params::purge` +Default value: `{}` ##### `purge_defaults` @@ -209,7 +217,17 @@ Data type: `Hash` The default purge settings that are combined and merged with the passed `purge` value -Default value: `$apt::params::purge_defaults` +Default value: + +```puppet +{ + 'sources.list' => false, + 'sources.list.d' => false, + 'preferences' => false, + 'preferences.d' => false, + 'apt.conf.d' => false, + } +``` ##### `proxy` @@ -217,7 +235,7 @@ Data type: `Apt::Proxy` Configures Apt to connect to a proxy server. Valid options: a hash matching the locally defined type apt::proxy. -Default value: `$apt::params::proxy` +Default value: `{}` ##### `proxy_defaults` @@ -225,23 +243,34 @@ Data type: `Hash` The default proxy settings that are combined and merged with the passed `proxy` value -Default value: `$apt::params::proxy_defaults` +Default value: + +```puppet +{ + 'ensure' => undef, + 'host' => undef, + 'port' => 8080, + 'https' => false, + 'https_acng' => false, + 'direct' => false, + } +``` ##### `sources` Data type: `Hash` -Creates new `apt::source` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::source` resources. -Default value: `$apt::params::sources` +Default value: `{}` ##### `keys` Data type: `Hash` -Creates new `apt::key` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::key` resources. -Default value: `$apt::params::keys` +Default value: `{}` ##### `keyrings` @@ -255,25 +284,25 @@ Default value: `{}` Data type: `Hash` -Creates new `apt::ppa` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::ppa` resources. -Default value: `$apt::params::ppas` +Default value: `{}` ##### `pins` Data type: `Hash` -Creates new `apt::pin` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::pin` resources. -Default value: `$apt::params::pins` +Default value: `{}` ##### `settings` Data type: `Hash` -Creates new `apt::setting` resources. Valid options: a hash to be passed to the create_resources function linked above. +Hash of `apt::setting` resources. -Default value: `$apt::params::settings` +Default value: `{}` ##### `manage_auth_conf` @@ -282,7 +311,7 @@ Data type: `Boolean` Specifies whether to manage the /etc/apt/auth.conf file. When true, the file will be overwritten with the entries specified in the auth_conf_entries parameter. When false, the file will be ignored (note that this does not set the file to absent. -Default value: `$apt::params::manage_auth_conf` +Default value: `true` ##### `auth_conf_entries` @@ -293,15 +322,15 @@ format (similar to what curl uses) and contains the login configuration for APT https://manpages.debian.org/testing/apt/apt_auth.conf.5.en.html for details. If specified each hash must contain the keys machine, login and password and no others. Specifying manage_auth_conf and not specifying this parameter will set /etc/apt/auth.conf to absent. -Default value: `$apt::params::auth_conf_entries` +Default value: `[]` ##### `auth_conf_owner` Data type: `String` -The owner of the file /etc/apt/auth.conf. Default: '_apt' or 'root' on old releases. +The owner of the file /etc/apt/auth.conf. -Default value: `$apt::params::auth_conf_owner` +Default value: `'_apt'` ##### `root` @@ -309,7 +338,7 @@ Data type: `String` Specifies root directory of Apt executable. -Default value: `$apt::params::root` +Default value: `'/etc/apt'` ##### `sources_list` @@ -317,7 +346,7 @@ Data type: `String` Specifies the path of the sources_list file to use. -Default value: `$apt::params::sources_list` +Default value: `"${root}/sources.list"` ##### `sources_list_d` @@ -325,7 +354,7 @@ Data type: `String` Specifies the path of the sources_list.d file to use. -Default value: `$apt::params::sources_list_d` +Default value: `"${root}/sources.list.d"` ##### `conf_d` @@ -333,7 +362,7 @@ Data type: `String` Specifies the path of the conf.d file to use. -Default value: `$apt::params::conf_d` +Default value: `"${root}/apt.conf.d"` ##### `preferences` @@ -341,7 +370,7 @@ Data type: `String` Specifies the path of the preferences file to use. -Default value: `$apt::params::preferences` +Default value: `"${root}/preferences"` ##### `preferences_d` @@ -349,7 +378,7 @@ Data type: `String` Specifies the path of the preferences.d file to use. -Default value: `$apt::params::preferences_d` +Default value: `"${root}/preferences.d"` ##### `config_files` @@ -357,23 +386,47 @@ Data type: `Hash` A hash made up of the various configuration files used by Apt. -Default value: `$apt::params::config_files` +Default value: + +```puppet +{ + 'conf' => { + 'path' => $conf_d, + 'ext' => '', + }, + 'pref' => { + 'path' => $preferences_d, + 'ext' => '.pref', + }, + 'list' => { + 'path' => $sources_list_d, + 'ext' => '.list', + }, + } +``` ##### `sources_list_force` Data type: `Boolean` -Specifies whether to perform force purge or delete. Default false. +Specifies whether to perform force purge or delete. -Default value: `$apt::params::sources_list_force` +Default value: `false` ##### `include_defaults` Data type: `Hash` +The package types to include by default. +Default value: -Default value: `$apt::params::include_defaults` +```puppet +{ + 'deb' => true, + 'src' => false, + } +``` ##### `apt_conf_d` @@ -381,7 +434,7 @@ Data type: `String` The path to the file `apt.conf.d` -Default value: `$apt::params::apt_conf_d` +Default value: `"${root}/apt.conf.d"` ##### `source_key_defaults` @@ -1074,7 +1127,7 @@ Default value: `$name` Data type: `String` -Specifies whether the Apt source file should exist. Valid options: 'present' and 'absent'. +Specifies whether the Apt source file should exist. Default value: `present` @@ -1102,8 +1155,8 @@ Configures include options. Valid options: a hash of available keys. Options: -* **:deb** `Boolean`: Specifies whether to request the distribution's compiled binaries. Default true. -* **:src** `Boolean`: Specifies whether to request the distribution's uncompiled source code. Default false. +* **:deb** `Boolean`: Specifies whether to request the distribution's compiled binaries. +* **:src** `Boolean`: Specifies whether to request the distribution's uncompiled source code. Default value: `{}` @@ -1177,7 +1230,7 @@ Default value: `true` Data type: `Boolean` -Specifies whether to check if the package release date is valid. Defaults to `True`. +Specifies whether to check if the package release date is valid. Default value: `true` From 5415131facb107b4579e0fad56b3c96ff4f40d07 Mon Sep 17 00:00:00 2001 From: Kenyon Ralph Date: Mon, 8 Apr 2024 23:10:40 -0700 Subject: [PATCH 5/9] pdk update to 3.2.0 --- .github/workflows/release.yml | 2 +- .rubocop.yml | 8 +++++++- .vscode/extensions.json | 2 +- Gemfile | 25 ++++++++++++------------- metadata.json | 4 ++-- spec/spec_helper.rb | 5 +++-- 6 files changed, 26 insertions(+), 20 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 0b7b8a05dd..4b3b80fc80 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -2,7 +2,7 @@ name: "Publish module" on: workflow_dispatch: - + jobs: release: uses: "puppetlabs/cat-github-actions/.github/workflows/module_release.yml@main" diff --git a/.rubocop.yml b/.rubocop.yml index 7a66e08331..439ea84ee8 100644 --- a/.rubocop.yml +++ b/.rubocop.yml @@ -5,7 +5,7 @@ require: AllCops: NewCops: enable DisplayCopNames: true - TargetRubyVersion: '2.7' + TargetRubyVersion: '2.6' Include: - "**/*.rb" Exclude: @@ -529,6 +529,8 @@ Lint/DuplicateBranch: Enabled: false Lint/DuplicateMagicComment: Enabled: false +Lint/DuplicateMatchPattern: + Enabled: false Lint/DuplicateRegexpCharacterClassElement: Enabled: false Lint/EmptyBlock: @@ -645,6 +647,8 @@ Style/ComparableClamp: Enabled: false Style/ConcatArrayLiterals: Enabled: false +Style/DataInheritance: + Enabled: false Style/DirEmpty: Enabled: false Style/DocumentDynamicEvalDefinition: @@ -713,6 +717,8 @@ Style/RedundantHeredocDelimiterQuotes: Enabled: false Style/RedundantInitialize: Enabled: false +Style/RedundantLineContinuation: + Enabled: false Style/RedundantSelfAssignmentBranch: Enabled: false Style/RedundantStringEscape: diff --git a/.vscode/extensions.json b/.vscode/extensions.json index 2f1e4f73a5..6da8d472f8 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -1,6 +1,6 @@ { "recommendations": [ "puppet.puppet-vscode", - "rebornix.Ruby" + "Shopify.ruby-lsp" ] } diff --git a/Gemfile b/Gemfile index 49f29d3ebe..ca783ebb83 100644 --- a/Gemfile +++ b/Gemfile @@ -20,31 +20,30 @@ group :development do gem "json", '= 2.6.1', require: false if Gem::Requirement.create(['>= 3.1.0', '< 3.1.3']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) gem "json", '= 2.6.3', require: false if Gem::Requirement.create(['>= 3.2.0', '< 4.0.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) gem "racc", '~> 1.4.0', require: false if Gem::Requirement.create(['>= 2.7.0', '< 3.0.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) + gem "deep_merge", '~> 1.0', require: false gem "voxpupuli-puppet-lint-plugins", '~> 5.0', require: false - gem "facterdb", '~> 1.18', require: false - gem "metadata-json-lint", '~> 3.0', require: false - gem "puppetlabs_spec_helper", '~> 7.0', require: false - gem "rspec-puppet-facts", '~> 2.0', require: false - gem "codecov", '~> 0.2', require: false + gem "facterdb", '~> 1.26', require: false + gem "metadata-json-lint", '~> 4.0', require: false + gem "rspec-puppet-facts", '~> 3.0', require: false gem "dependency_checker", '~> 1.0.0', require: false gem "parallel_tests", '= 3.12.1', require: false gem "pry", '~> 0.10', require: false - gem "simplecov-console", '~> 0.5', require: false + gem "simplecov-console", '~> 0.9', require: false gem "puppet-debugger", '~> 1.0', require: false - gem "rubocop", '= 1.48.1', require: false + gem "rubocop", '~> 1.50.0', require: false gem "rubocop-performance", '= 1.16.0', require: false gem "rubocop-rspec", '= 2.19.0', require: false - gem "puppet-strings", '~> 4.0', require: false gem "rb-readline", '= 0.5.5', require: false, platforms: [:mswin, :mingw, :x64_mingw] end -group :system_tests do - gem "puppet_litmus", '~> 1.0', require: false, platforms: [:ruby, :x64_mingw] - gem "serverspec", '~> 2.41', require: false -end -group :release_prep do +group :development, :release_prep do gem "puppet-strings", '~> 4.0', require: false gem "puppetlabs_spec_helper", '~> 7.0', require: false end +group :system_tests do + gem "puppet_litmus", '~> 1.0', require: false, platforms: [:ruby, :x64_mingw] + gem "CFPropertyList", '< 3.0.7', require: false, platforms: [:mswin, :mingw, :x64_mingw] + gem "serverspec", '~> 2.41', require: false +end puppet_version = ENV['PUPPET_GEM_VERSION'] facter_version = ENV['FACTER_GEM_VERSION'] diff --git a/metadata.json b/metadata.json index 0f509b1126..9aaa77a241 100644 --- a/metadata.json +++ b/metadata.json @@ -37,6 +37,6 @@ } ], "template-url": "https://github.com/puppetlabs/pdk-templates.git#main", - "template-ref": "heads/main-0-g79a2f93", - "pdk-version": "3.0.0" + "template-ref": "heads/main-0-gdd25cb0", + "pdk-version": "3.2.0" } diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 6820cebee7..ae7c1f6818 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -25,7 +25,8 @@ next unless File.exist?(f) && File.readable?(f) && File.size?(f) begin - default_facts.merge!(YAML.safe_load(File.read(f), permitted_classes: [], permitted_symbols: [], aliases: true)) + require 'deep_merge' + default_facts.deep_merge!(YAML.safe_load(File.read(f), permitted_classes: [], permitted_symbols: [], aliases: true)) rescue StandardError => e RSpec.configuration.reporter.message "WARNING: Unable to load #{f}: #{e}" end @@ -33,7 +34,7 @@ # read default_facts and merge them over what is provided by facterdb default_facts.each do |fact, value| - add_custom_fact fact, value + add_custom_fact fact, value, merge_facts: true end RSpec.configure do |c| From 847de6be48c5e48d694f4ef065cd6b3cbb88ea7f Mon Sep 17 00:00:00 2001 From: Malik Parvez <84777619+malikparvez@users.noreply.github.com> Date: Tue, 21 May 2024 21:12:45 +0530 Subject: [PATCH 6/9] ITHELP-87329 : replace pull_request_target with pull_request --- .github/workflows/mend.yml | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/.github/workflows/mend.yml b/.github/workflows/mend.yml index 8b5b401847..b4100a5af0 100644 --- a/.github/workflows/mend.yml +++ b/.github/workflows/mend.yml @@ -1,10 +1,9 @@ name: "mend" on: - pull_request_target: - types: - - opened - - synchronize + pull_request: + branches: + - "main" schedule: - cron: "0 0 * * *" workflow_dispatch: From c58263af73215d297f7cfd87fa04859c814b590a Mon Sep 17 00:00:00 2001 From: Ramesh Sencha Date: Tue, 4 Jun 2024 13:46:36 +0530 Subject: [PATCH 7/9] (ITHELP-87329) Removing references of pull_request_target --- .github/workflows/labeller.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/labeller.yml b/.github/workflows/labeller.yml index ee149bf525..0d4870d70b 100644 --- a/.github/workflows/labeller.yml +++ b/.github/workflows/labeller.yml @@ -6,7 +6,7 @@ on: - opened - labeled - unlabeled - pull_request_target: + pull_request: types: - opened - labeled From a9cb238596b8d9e1c026a9cc3edd30086fc8f3e7 Mon Sep 17 00:00:00 2001 From: Malik Parvez <84777619+malikparvez@users.noreply.github.com> Date: Tue, 4 Jun 2024 13:52:24 +0530 Subject: [PATCH 8/9] ITHELP-87329 : replace pull_request_target with pull_request --- .github/workflows/labeller.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/labeller.yml b/.github/workflows/labeller.yml index ee149bf525..0d4870d70b 100644 --- a/.github/workflows/labeller.yml +++ b/.github/workflows/labeller.yml @@ -6,7 +6,7 @@ on: - opened - labeled - unlabeled - pull_request_target: + pull_request: types: - opened - labeled From edf5ecef17adea0ee04cd0b60cffa7acf539f5e8 Mon Sep 17 00:00:00 2001 From: Malik Parvez <84777619+malikparvez@users.noreply.github.com> Date: Tue, 4 Jun 2024 19:36:23 +0530 Subject: [PATCH 9/9] Update labeller.yml --- .github/workflows/labeller.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/labeller.yml b/.github/workflows/labeller.yml index ee149bf525..0d4870d70b 100644 --- a/.github/workflows/labeller.yml +++ b/.github/workflows/labeller.yml @@ -6,7 +6,7 @@ on: - opened - labeled - unlabeled - pull_request_target: + pull_request: types: - opened - labeled