def load_current_resource
if flush_cache[:before]
@yum.reload
end
if @new_resource.options
repo_control = []
@new_resource.options.split.each do |opt|
if opt =~ %r{--(enable|disable)repo=.+}
repo_control << opt
end
end
if repo_control.size > 0
@yum.enable_extra_repo_control(repo_control.join(" "))
else
@yum.disable_extra_repo_control
end
else
@yum.disable_extra_repo_control
end
unless @yum.package_available?(@new_resource.package_name)
parse_dependency
end
unless arch
parse_arch
end
@current_resource = Chef::Resource::Package.new(@new_resource.name)
@current_resource.package_name(@new_resource.package_name)
if @new_resource.source
unless ::File.exists?(@new_resource.source)
raise Chef::Exceptions::Package, "Package #{@new_resource.name} not found: #{@new_resource.source}"
end
Chef::Log.debug("#{@new_resource} checking rpm status")
status = popen4("rpm -qp --queryformat '%{NAME} %{VERSION}-%{RELEASE}\n' #{@new_resource.source}") do |pid, stdin, stdout, stderr|
stdout.each do |line|
case line
when /([\w\d_.-]+)\s([\w\d_.-]+)/
@current_resource.package_name($1)
@new_resource.version($2)
end
end
end
end
if @new_resource.version
new_resource = "#{@new_resource.package_name}-#{@new_resource.version}#{yum_arch}"
else
new_resource = "#{@new_resource.package_name}#{yum_arch}"
end
Chef::Log.debug("#{@new_resource} checking yum info for #{new_resource}")
installed_version = @yum.installed_version(@new_resource.package_name, arch)
@current_resource.version(installed_version)
@candidate_version = @yum.candidate_version(@new_resource.package_name, arch)
Chef::Log.debug("#{@new_resource} installed version: #{installed_version || "(none)"} candidate version: " +
"#{@candidate_version || "(none)"}")
@current_resource
end