+# frozen_string_literal: true
+
apt_package_updates = nil
-Facter.add("apt_has_updates") do
- confine :osfamily => 'Debian'
- if File.executable?("/usr/lib/update-notifier/apt-check")
- apt_check_result = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check 2>&1')
- if not apt_check_result.nil? and apt_check_result =~ /^\d+;\d+$/
- apt_package_updates = apt_check_result.split(';')
+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::Util::Resolution.exec("/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|
+ 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)
+ if line.match(re)
+ apt_updates[1].push(package)
+ end
+ 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 != ['0', '0']
+ apt_package_updates = get_updates('upgrade')
+ if !apt_package_updates.nil? && apt_package_updates.length == 2
+ apt_package_updates != [[], []]
end
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
- packages = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check -p 2>&1').split("\n")
- if Facter.version < '2.0.0'
- packages.join(',')
- else
- packages
+ apt_dist_updates = get_updates('dist-upgrade')
+ if !apt_dist_updates.nil? && apt_dist_updates.length == 2
+ apt_dist_updates != [[], []]
end
end
end
-Facter.add("apt_updates") do
- confine :apt_has_updates => true
+Facter.add('apt_package_updates') do
+ confine apt_has_updates: true
+ setcode do
+ apt_package_updates[0]
+ end
+end
+
+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_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[0])
+ Integer(apt_package_updates[1].length)
end
end
-Facter.add("apt_security_updates") do
- confine :apt_has_updates => true
+Facter.add('apt_security_dist_updates') do
+ confine apt_has_dist_updates: true
setcode do
- Integer(apt_package_updates[1])
+ Integer(apt_dist_updates[1].length)
end
end