X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=lib%2Ffacter%2Fapt_updates.rb;h=66c6a892867be4b15161f41cc84aad3ea9ca0510;hb=refs%2Fheads%2Frelease-prep;hp=e101dd79a477aae25ebf99995f080f15a76d95a3;hpb=0fd497d58b47e48f830a8fcea49e37d8df65930b;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/lib/facter/apt_updates.rb b/lib/facter/apt_updates.rb index e101dd7..66c6a89 100644 --- a/lib/facter/apt_updates.rb +++ b/lib/facter/apt_updates.rb @@ -1,68 +1,103 @@ +# frozen_string_literal: true + 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_dist_updates = nil + +# Executes the upgrading of packages +# @param +# upgrade_option Type of upgrade passed into apt-get command arguments i.e. 'upgrade' or 'dist-upgrade' +def get_updates(upgrade_option) + apt_updates = nil + if File.executable?('/usr/bin/apt-get') + apt_get_result = Facter::Core::Execution.execute("/usr/bin/apt-get -s -o Debug::NoLocking=true #{upgrade_option} 2>&1") + unless apt_get_result.nil? + apt_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 + next unless %r{^Inst\s}.match?(line) + + package = line.gsub(%r{^Inst\s([^\s]+)\s.*}, '\1').strip + apt_updates[0].push(package) + security_matches = [ + %r{ Debian-Security:}, + %r{ Ubuntu[^\s]+-security[, ]}, + %r{ gNewSense[^\s]+-security[, ]}, + ] + re = Regexp.union(security_matches) + apt_updates[1].push(package) if line.match(re) end end end + apt_updates +end +Facter.add('apt_has_updates') do + confine osfamily: 'Debian' setcode do - if not apt_package_updates.nil? and apt_package_updates.length == 2 - apt_package_updates != [[], []] - end + apt_package_updates = get_updates('upgrade') + apt_package_updates != [[], []] if !apt_package_updates.nil? && apt_package_updates.length == 2 end end -Facter.add("apt_package_updates") do - confine :apt_has_updates => true +Facter.add('apt_has_dist_updates') do + confine osfamily: 'Debian' setcode do - if Facter.version < '2.0.0' - apt_package_updates[0].join(',') - else - apt_package_updates[0] - end + apt_dist_updates = get_updates('dist-upgrade') + apt_dist_updates != [[], []] if !apt_dist_updates.nil? && apt_dist_updates.length == 2 end end -Facter.add("apt_package_security_updates") do - confine :apt_has_updates => true +Facter.add('apt_package_updates') do + confine apt_has_updates: true setcode do - if Facter.version < '2.0.0' - apt_package_updates[1].join(',') - else - apt_package_updates[1] - end + apt_package_updates[0] end end -Facter.add("apt_updates") do - confine :apt_has_updates => true +Facter.add('apt_package_dist_updates') do + confine apt_has_dist_updates: true + setcode do + apt_dist_updates[0] + end +end + +Facter.add('apt_package_security_updates') do + confine apt_has_updates: true + setcode do + apt_package_updates[1] + end +end + +Facter.add('apt_package_security_dist_updates') do + confine apt_has_dist_updates: true + setcode do + apt_dist_updates[1] + 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 +Facter.add('apt_dist_updates') do + confine apt_has_dist_updates: true + setcode do + Integer(apt_dist_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 + +Facter.add('apt_security_dist_updates') do + confine apt_has_dist_updates: true + setcode do + Integer(apt_dist_updates[1].length) + end +end