X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fparams.pp;h=f4489cdcb5556e45008b62985f493308168126ed;hb=4fa28203b9ca3f12395d0d81df5a690063fc2b47;hp=aa90a7dd32ef7b7f1512694a5f176c9a0d9fb75e;hpb=463a61c0ab85e93d7d8c0dca90784570a39d83f7;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/params.pp b/manifests/params.pp index aa90a7d..f4489cd 100644 --- a/manifests/params.pp +++ b/manifests/params.pp @@ -1,26 +1,105 @@ class apt::params { + + if $::osfamily != 'Debian' { + fail('This module only works on Debian or derivatives like Ubuntu') + } + + # Strict variables facts lookup compatibility + $xfacts = { + 'lsbdistcodename' => defined('$lsbdistcodename') ? { + true => $::lsbdistcodename, + default => undef, + }, + 'lsbdistrelease' => defined('$lsbdistrelease') ? { + true => $::lsbdistrelease, + default => undef, + }, + 'lsbmajdistrelease' => defined('$lsbmajdistrelease') ? { + true => $::lsbmajdistrelease, + default => undef, + }, + 'lsbdistdescription' => defined('$lsbdistdescription') ? { + true => $::lsbdistdescription, + default => undef, + }, + 'lsbminordistrelease' => defined('$lsbminordistrelease') ? { + true => $::lsbminordistrelease, + default => undef, + }, + 'lsbdistid' => defined('$lsbdistid') ? { + true => $::lsbdistid, + default => undef, + }, + } + $root = '/etc/apt' $provider = '/usr/bin/apt-get' + $sources_list = "${root}/sources.list" $sources_list_d = "${root}/sources.list.d" - $apt_conf_d = "${root}/apt.conf.d" + $conf_d = "${root}/apt.conf.d" + $preferences = "${root}/preferences" $preferences_d = "${root}/preferences.d" + $keyserver = 'keyserver.ubuntu.com' - if $::osfamily != 'Debian' { - fail('This module only works on Debian or derivatives like Ubuntu') + $config_files = { + 'conf' => { + 'path' => $conf_d, + 'ext' => '', + }, + 'pref' => { + 'path' => $preferences_d, + 'ext' => '', + }, + 'list' => { + 'path' => $sources_list_d, + 'ext' => '.list', + } + } + + $update_defaults = { + 'always' => false, + 'frequency' => 'reluctantly', + 'timeout' => undef, + 'tries' => undef, } - case $::lsbdistid { + $proxy_defaults = { + 'host' => undef, + 'port' => 8080, + 'https' => false, + } + + $purge_defaults = { + 'sources.list' => true, + 'sources.list.d' => true, + 'preferences' => true, + 'preferences.d' => true, + } + + $source_key_defaults = { + 'server' => $keyserver, + 'options' => undef, + 'content' => undef, + 'source' => undef, + } + + $include_defaults = { + 'deb' => true, + 'src' => false, + } + + case $xfacts['lsbdistid'] { 'ubuntu', 'debian': { - $distid = $::lsbdistid - $distcodename = $::lsbdistcodename + $distid = $xfacts['lsbdistid'] + $distcodename = $xfacts['lsbdistcodename'] } 'linuxmint': { - if $::lsbdistcodename == 'debian' { + if $xfacts['lsbdistcodename'] == 'debian' { $distid = 'debian' $distcodename = 'wheezy' } else { $distid = 'ubuntu' - $distcodename = $::lsbdistcodename ? { + $distcodename = $xfacts['lsbdistcodename'] ? { 'qiana' => 'trusty', 'petra' => 'saucy', 'olivia' => 'raring', @@ -29,7 +108,7 @@ class apt::params { } } } - '': { + undef: { fail('Unable to determine lsbdistid, is lsb-release installed?') } default: { @@ -41,14 +120,25 @@ class apt::params { case $distcodename { 'lucid': { $ppa_options = undef + $ppa_package = 'python-software-properties' } - 'precise', 'trusty', 'utopic', 'vivid': { + 'precise': { $ppa_options = '-y' + $ppa_package = 'python-software-properties' + } + 'trusty', 'utopic', 'vivid': { + $ppa_options = '-y' + $ppa_package = 'software-properties-common' } default: { $ppa_options = '-y' + $ppa_package = 'software-properties-common' } } } + '', default: { + $ppa_options = undef + $ppa_package = undef + } } }