X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fparams.pp;h=42dd6b01290bae1783aadccaaae56eb84708f572;hb=1c707c7d323f80502e09008351c5007b385a1c97;hp=14401c6c930b19ed9eae71a08d81e22cf64d7f9f;hpb=0cb48b0c470c81b369a54336409789b28bb09f16;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/params.pp b/manifests/params.pp index 14401c6..42dd6b0 100644 --- a/manifests/params.pp +++ b/manifests/params.pp @@ -1,9 +1,41 @@ class apt::params { - if $caller_module_name and $caller_module_name != $module_name { + if defined('$caller_module_name') and $caller_module_name and $caller_module_name != $module_name { fail('apt::params is a private class and cannot be accessed directly') } + 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" @@ -13,10 +45,6 @@ class apt::params { $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, @@ -59,24 +87,18 @@ class apt::params { 'source' => undef, } - $file_defaults = { - 'owner' => 'root', - 'group' => 'root', - 'mode' => '0644', - } - - case $::lsbdistid { + 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', @@ -85,7 +107,7 @@ class apt::params { } } } - '': { + undef: { fail('Unable to determine lsbdistid, is lsb-release installed?') } default: { @@ -113,5 +135,9 @@ class apt::params { } } } + '', default: { + $ppa_options = undef + $ppa_package = undef + } } }