summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorLamont Granquist <lamont@scriptkiddie.org>2014-07-01 11:18:07 -0700
committerLamont Granquist <lamont@scriptkiddie.org>2014-07-01 19:12:34 -0700
commit75f27ae79b10a89b9518ea5b19da70a2636746a3 (patch)
tree08ca06ef83bc34249dcc00205da5a80cabe38167 /lib
parenta06bc951fc9ac04200988f596c04cdf5c686e04e (diff)
downloadchef-75f27ae79b10a89b9518ea5b19da70a2636746a3.tar.gz
remove inheritance from apt_package
the dpkg_package provider is not strictly an apt_package provider so code-sharing via inheritance was broken. this copypastas some code from apt_package back into dpkg_provider and does some rearrangement. future code sharing between these two should be done via mixin or via composition (e.g. mixin for #run_noninteractive)
Diffstat (limited to 'lib')
-rw-r--r--lib/chef/provider/package/dpkg.rb51
1 files changed, 35 insertions, 16 deletions
diff --git a/lib/chef/provider/package/dpkg.rb b/lib/chef/provider/package/dpkg.rb
index fb366fb6eb..463482c640 100644
--- a/lib/chef/provider/package/dpkg.rb
+++ b/lib/chef/provider/package/dpkg.rb
@@ -24,13 +24,14 @@ require 'chef/mixin/get_source_from_package'
class Chef
class Provider
class Package
- class Dpkg < Chef::Provider::Package::Apt
+ class Dpkg < Chef::Provider::Package
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-f-Version
DPKG_INFO = /([a-z\d\-\+\.]+)\t([\w\d.~:-]+)/
DPKG_INSTALLED = /^Status: install ok installed/
DPKG_VERSION = /^Version: (.+)$/
include Chef::Mixin::GetSourceFromPackage
+
def define_resource_requirements
super
requirements.assert(:install) do |a|
@@ -98,31 +99,49 @@ class Chef
end
def install_package(name, version)
- run_command_with_systems_locale(
- :command => "dpkg -i#{expand_options(@new_resource.options)} #{@new_resource.source}",
- :environment => {
- "DEBIAN_FRONTEND" => "noninteractive"
- }
+ Chef::Log.info("#{@new_resource} installing #{@new_resource.source}")
+ run_noninteractive(
+ "dpkg -i#{expand_options(@new_resource.options)} #{@new_resource.source}",
)
end
def remove_package(name, version)
- run_command_with_systems_locale(
- :command => "dpkg -r#{expand_options(@new_resource.options)} #{@new_resource.package_name}",
- :environment => {
- "DEBIAN_FRONTEND" => "noninteractive"
- }
+ Chef::Log.info("#{@new_resource} removing #{@new_resource.package_name}")
+ run_noninteractive(
+ "dpkg -r#{expand_options(@new_resource.options)} #{@new_resource.package_name}",
)
end
def purge_package(name, version)
- run_command_with_systems_locale(
- :command => "dpkg -P#{expand_options(@new_resource.options)} #{@new_resource.package_name}",
- :environment => {
- "DEBIAN_FRONTEND" => "noninteractive"
- }
+ Chef::Log.info("#{@new_resource} purging #{@new_resource.package_name}")
+ run_noninteractive(
+ "dpkg -P#{expand_options(@new_resource.options)} #{@new_resource.package_name}"
)
end
+
+ def upgrade_package(name, version)
+ install_package(name, version)
+ end
+
+ def preseed_package(preseed_file)
+ Chef::Log.info("#{@new_resource} pre-seeding package installation instructions")
+ run_noninteractive("debconf-set-selections #{preseed_file}")
+ end
+
+ def reconfig_package(name, version)
+ Chef::Log.info("#{@new_resource} reconfiguring")
+ run_noninteractive("dpkg-reconfigure #{name}")
+ end
+
+ # Runs command via shell_out with magic environment to disable
+ # interactive prompts. Command is run with default localization rather
+ # than forcing locale to "C", so command output may not be stable.
+ #
+ # FIXME: This should be "LC_ALL" => "en_US.UTF-8" in order to stabilize the output and get UTF-8
+ def run_noninteractive(command)
+ shell_out!(command, :env => { "DEBIAN_FRONTEND" => "noninteractive", "LC_ALL" => nil })
+ end
+
end
end
end