X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=lib%2Ffacter%2Fapt_updates.rb;h=e101dd79a477aae25ebf99995f080f15a76d95a3;hb=0fd497d58b47e48f830a8fcea49e37d8df65930b;hp=ee177380c231939a12f0d22fd33dbacd4acd3f0c;hpb=943be409bdfe4bbf4d4331effc5e544d998b3290;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/lib/facter/apt_updates.rb b/lib/facter/apt_updates.rb index ee17738..e101dd7 100644 --- a/lib/facter/apt_updates.rb +++ b/lib/facter/apt_updates.rb @@ -1,9 +1,68 @@ -Facter.add("apt_updates") do +apt_package_updates = nil +Facter.add("apt_has_updates") do confine :osfamily => 'Debian' + if File.executable?("/usr/bin/apt-get") + apt_get_result = Facter::Util::Resolution.exec('/usr/bin/apt-get -s -o Debug::NoLocking=true upgrade 2>&1') + if not apt_get_result.nil? + apt_package_updates = [[], []] + apt_get_result.each_line do |line| + if line =~ /^Inst\s/ + package = line.gsub(/^Inst\s([^\s]+)\s.*/, '\1').strip + apt_package_updates[0].push(package) + security_matches = [ + / Debian[^\s]+-updates /, + / Debian-Security:/, + / Ubuntu[^\s]+-security /, + / gNewSense[^\s]+-security / + ] + re = Regexp.union(security_matches) + if line.match(re) + apt_package_updates[1].push(package) + end + end + end + end + end + + setcode do + if not apt_package_updates.nil? and apt_package_updates.length == 2 + apt_package_updates != [[], []] + end + end +end + +Facter.add("apt_package_updates") do + confine :apt_has_updates => true + setcode do + if Facter.version < '2.0.0' + apt_package_updates[0].join(',') + else + apt_package_updates[0] + end + end +end + +Facter.add("apt_package_security_updates") do + confine :apt_has_updates => true setcode do - if File.executable?("/usr/lib/update-notifier/apt-check") - updates = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check 2>&1') - Integer(updates.strip.split(';')[0]) + if Facter.version < '2.0.0' + apt_package_updates[1].join(',') + else + apt_package_updates[1] end end end + +Facter.add("apt_updates") do + confine :apt_has_updates => true + setcode do + Integer(apt_package_updates[0].length) + end +end + +Facter.add("apt_security_updates") do + confine :apt_has_updates => true + setcode do + Integer(apt_package_updates[1].length) + end +end