X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=manifests%2Fupdate.pp;h=ef37f52db04f1bfa19da690bb054b51c6cbda897;hb=c01f2ca5353853db87279ae4410a58b560f0adef;hp=ce0b78fbddbded8805ff4e56aa1a2ad9d24a9f18;hpb=d1e87d477466455220daff8fe36ea1516591fd67;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/manifests/update.pp b/manifests/update.pp index ce0b78f..ef37f52 100644 --- a/manifests/update.pp +++ b/manifests/update.pp @@ -1,10 +1,68 @@ +# @summary Updates the list of available packages using apt-get update. +# +# @api private +# class apt::update { - include apt::params + assert_private() + #TODO: to catch if $apt_update_last_success has the value of -1 here. If we + #opt to do this, a info/warn would likely be all you'd need likely to happen + #on the first run, but if it's not run in awhile something is likely borked + #with apt and we'd want to know about it. + + case $apt::_update['frequency'] { + 'always': { + $_kick_apt = true + } + 'daily': { + #compare current date with the apt_update_last_success fact to determine + #if we should kick apt_update. + $daily_threshold = (Integer(Timestamp().strftime('%s')) - 86400) + if $apt::apt_update_last_success { + if $apt::apt_update_last_success + 0 < $daily_threshold { + $_kick_apt = true + } else { + $_kick_apt = false + } + } else { + #if apt-get update has not successfully run, we should kick apt_update + $_kick_apt = true + } + } + 'weekly':{ + #compare current date with the apt_update_last_success fact to determine + #if we should kick apt_update. + $weekly_threshold = (Integer(Timestamp().strftime('%s')) - 604800) + if $apt::apt_update_last_success { + if ( $apt::apt_update_last_success + 0 < $weekly_threshold ) { + $_kick_apt = true + } else { + $_kick_apt = false + } + } else { + #if apt-get update has not successfully run, we should kick apt_update + $_kick_apt = true + } + } + default: { + #catches 'reluctantly', and any other value (which should not occur). + #do nothing. + $_kick_apt = false + } + } + + if $_kick_apt { + $_refresh = false + } else { + $_refresh = true + } exec { 'apt_update': - command => "${apt::params::provider} update", + command => "${apt::provider} update", + loglevel => $apt::_update['loglevel'], logoutput => 'on_failure', - refreshonly => true, - timeout => $apt::update_timeout, + refreshonly => $_refresh, + timeout => $apt::_update['timeout'], + tries => $apt::_update['tries'], + try_sleep => 1, } }