# File lib/foreman_maintain/package_manager/yum.rb, line 7 def self.parse_envra(envra) # envra format: 0:foreman-1.20.1.10-1.el7sat.noarch parsed = envra.match(/\d*:?(?<name>.*)-[^-]+-[^-]+\.[^.]+/) parsed ? Hash[parsed.names.map(&:to_sym).zip(parsed.captures)].merge(:envra => envra) : nil end
# File lib/foreman_maintain/package_manager/yum.rb, line 60 def clean_cache yum_action('clean', 'all') end
# File lib/foreman_maintain/package_manager/yum.rb, line 64 def files_not_owned_by_package(directory) find_cmd = "find #{directory} -exec /bin/sh -c 'rpm -qf {} &> /dev/null || echo {}' \\;" sys.execute(find_cmd).split("\n") end
# File lib/foreman_maintain/package_manager/yum.rb, line 41 def find_installed_package(name) status, result = sys.execute_with_status(%Q(rpm -q '#{name}')) if status == 0 result end end
# File lib/foreman_maintain/package_manager/yum.rb, line 48 def install(packages, assumeyes: false) yum_action('install', packages, :assumeyes => assumeyes) end
# File lib/foreman_maintain/package_manager/yum.rb, line 30 def install_version_locking(*) install_extras('foreman_protector/foreman-protector.py', PROTECTOR_PLUGIN_FILE) install_extras('foreman_protector/foreman-protector.conf', PROTECTOR_CONFIG_FILE) install_extras('foreman_protector/foreman-protector.whitelist', PROTECTOR_WHITELIST_FILE) end
# File lib/foreman_maintain/package_manager/yum.rb, line 36 def installed?(packages) packages_list = [packages].flatten(1).map { |pkg| "'#{pkg}'" }.join(' ') sys.execute?(%Q(rpm -q #{packages_list})) end
# File lib/foreman_maintain/package_manager/yum.rb, line 13 def lock_versions enable_protector end
# File lib/foreman_maintain/package_manager/yum.rb, line 52 def remove(packages, assumeyes: false) yum_action('remove', packages, :assumeyes => assumeyes) end
# File lib/foreman_maintain/package_manager/yum.rb, line 17 def unlock_versions disable_protector end
# File lib/foreman_maintain/package_manager/yum.rb, line 56 def update(packages = [], assumeyes: false) yum_action('update', packages, :assumeyes => assumeyes) end
# File lib/foreman_maintain/package_manager/yum.rb, line 25 def version_locking_enabled? File.exist?(PROTECTOR_PLUGIN_FILE) && File.exist?(PROTECTOR_CONFIG_FILE) && File.exist?(PROTECTOR_WHITELIST_FILE) end
# File lib/foreman_maintain/package_manager/yum.rb, line 21 def versions_locked? !!(protector_config =~ /^\s*enabled\s*=\s*1/) end
# File lib/foreman_maintain/package_manager/yum.rb, line 83 def disable_protector setup_protector(false) end
# File lib/foreman_maintain/package_manager/yum.rb, line 79 def enable_protector setup_protector(true) end
# File lib/foreman_maintain/package_manager/yum.rb, line 109 def install_extras(src, dest, override: false) extras_src = File.expand_path('../../../../extras', __FILE__) if override || (File.directory?(dest) && !File.exist?(File.join(dest, src))) || !File.exist?(dest) FileUtils.cp(File.join(extras_src, src), dest) end end
# File lib/foreman_maintain/package_manager/yum.rb, line 71 def protector_config File.exist?(protector_config_file) ? File.read(protector_config_file) : '' end
# File lib/foreman_maintain/package_manager/yum.rb, line 75 def protector_config_file PROTECTOR_CONFIG_FILE end
# File lib/foreman_maintain/package_manager/yum.rb, line 87 def setup_protector(enabled) config = protector_config config += "\n" unless config[-1] == "\n" enabled_re = /^\s*enabled\s*=.*$/ if enabled_re.match(config) config = config.gsub(enabled_re, "enabled = #{enabled ? '1' : '0'}") else config += "enabled = #{enabled ? '1' : '0'}\n" end File.open(protector_config_file, 'w') { |file| file.puts config } end
# File lib/foreman_maintain/package_manager/yum.rb, line 99 def yum_action(action, packages, assumeyes: false) yum_options = [] packages = [packages].flatten(1) yum_options << '-y' if assumeyes yum_options_s = yum_options.empty? ? '' : ' ' + yum_options.join(' ') packages_s = packages.empty? ? '' : ' ' + packages.join(' ') sys.execute!("yum#{yum_options_s} #{action}#{packages_s}", :interactive => true) end