# Configures various update settings. Valid options: a hash made up from the following keys:
#
# @option update [String] :frequency
-# 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); '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); and 'reluctantly' (only if the exec resource
-# `apt_update` is notified). Default: 'reluctantly'.
+# 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);
+# 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);
+# 'reluctantly' (only if the exec resource `apt_update` is notified).
+# Default: 'reluctantly'.
#
# @option update [Integer] :loglevel
# Specifies the log level of logs outputted to the console. Default: undef.
# Specifies whether to perform force purge or delete. Default false.
#
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[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 $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 = $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 $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 $source_key_defaults = {
'server' => $keyserver,
# Specifies whether Puppet should manage the package that provides `apt-add-repository`.
#
define apt::ppa (
- String $ensure = 'present',
- Optional[String] $options = $::apt::ppa_options,
- Optional[String] $release = fact('os.distro.codename'),
- Optional[String] $dist = $facts['os']['name'],
- Optional[String] $package_name = $::apt::ppa_package,
- Boolean $package_manage = false,
+ String $ensure = 'present',
+ Optional[Array[String]] $options = $::apt::ppa_options,
+ Optional[String] $release = fact('os.distro.codename'),
+ Optional[String] $dist = $facts['os']['name'],
+ Optional[String] $package_name = $::apt::ppa_package,
+ Boolean $package_manage = false,
) {
unless $release {
fail('os.distro.codename fact not available: release parameter required')
fail('apt::ppa is not currently supported on Debian.')
}
+ # Validate the resource name
+ if $name !~ /^ppa:([a-zA-Z0-9\-_]+)\/([a-zA-z0-9\-_]+)$/ {
+ fail("Invalid PPA name: ${name}")
+ }
+
if versioncmp($facts['os']['release']['full'], '14.10') >= 0 {
$distid = downcase($dist)
$dash_filename = regsubst($name, '^ppa:([^/]+)/(.+)$', "\\1-${distid}-\\2")
$trusted_gpg_d_filename = "${dash_filename_no_specialchars}.gpg"
}
+ # This is the location of our main exec script
+ $script_path = "/opt/puppetlabs/puppet/cache/add-apt-repository-${dash_filename_no_specialchars}-${release}.sh"
+
if $ensure == 'present' {
if $package_manage {
ensure_packages($package_name)
$_proxy_env = []
}
- exec { "add-apt-repository-${name}":
- environment => $_proxy_env,
- command => "/usr/bin/add-apt-repository ${options} ${name} || (rm ${::apt::sources_list_d}/${sources_list_d_filename} && false)",
- unless => "/usr/bin/test -f ${::apt::sources_list_d}/${sources_list_d_filename} && /usr/bin/test -f ${::apt::trusted_gpg_d}/${trusted_gpg_d_filename}",
- user => 'root',
- logoutput => 'on_failure',
- notify => Class['apt::update'],
- require => $_require,
- }
+ unless $sources_list_d_filename in $facts['apt_sources'] {
+ $script_content = epp('apt/add-apt-repository.sh.epp', {
+ command => ['/usr/bin/add-apt-repository', shell_join($options), $name],
+ sources_list_d_path => $::apt::sources_list_d,
+ sources_list_d_filename => $sources_list_d_filename,
+ })
- file { "${::apt::sources_list_d}/${sources_list_d_filename}":
- ensure => file,
- require => Exec["add-apt-repository-${name}"],
+ file { "add-apt-repository-script-${name}":
+ ensure => 'file',
+ path => $script_path,
+ content => $script_content,
+ mode => '0755',
+ }
+
+ exec { "add-apt-repository-${name}":
+ environment => $_proxy_env,
+ command => $script_path,
+ logoutput => 'on_failure',
+ notify => Class['apt::update'],
+ require => $_require,
+ }
}
}
else {
- file { "${::apt::sources_list_d}/${sources_list_d_filename}":
- ensure => 'absent',
+ tidy { "remove-apt-repository-script-${name}":
+ path => $script_path,
+ }
+
+ tidy { "remove-apt-repository-${name}":
+ path => "${::apt::sources_list_d}/${sources_list_d_filename}",
notify => Class['apt::update'],
}
}