1 apt_package_updates = nil
2 Facter.add('apt_has_updates') do
3 confine osfamily: 'Debian'
4 if File.executable?('/usr/bin/apt-get')
5 apt_get_result = Facter::Util::Resolution.exec('/usr/bin/apt-get -s -o Debug::NoLocking=true upgrade 2>&1')
6 unless apt_get_result.nil?
7 apt_package_updates = [[], []]
8 apt_get_result.each_line do |line|
9 next unless line =~ %r{^Inst\s}
10 package = line.gsub(%r{^Inst\s([^\s]+)\s.*}, '\1').strip
11 apt_package_updates[0].push(package)
13 %r{ Debian-Security:},
14 %r{ Ubuntu[^\s]+-security[, ]},
15 %r{ gNewSense[^\s]+-security[, ]},
17 re = Regexp.union(security_matches)
19 apt_package_updates[1].push(package)
26 if !apt_package_updates.nil? && apt_package_updates.length == 2
27 apt_package_updates != [[], []]
32 Facter.add('apt_package_updates') do
33 confine apt_has_updates: true
35 if Facter.version < '2.0.0'
36 apt_package_updates[0].join(',')
38 apt_package_updates[0]
43 Facter.add('apt_package_security_updates') do
44 confine apt_has_updates: true
46 if Facter.version < '2.0.0'
47 apt_package_updates[1].join(',')
49 apt_package_updates[1]
54 Facter.add('apt_updates') do
55 confine apt_has_updates: true
57 Integer(apt_package_updates[0].length)
61 Facter.add('apt_security_updates') do
62 confine apt_has_updates: true
64 Integer(apt_package_updates[1].length)