Class: Chef::Provider::Execute
- Inherits:
-
Chef::Provider
- Object
- Chef::Provider
- Chef::Provider::Execute
- Defined in:
- lib/chef/provider/execute.rb
Direct Known Subclasses
Constant Summary
Constants included from Mixin::ShellOut
Mixin::ShellOut::DEPRECATED_OPTIONS
Instance Attribute Summary
Attributes inherited from Chef::Provider
#action, #cookbook_name, #current_resource, #new_resource, #recipe_name, #run_context
Instance Method Summary collapse
Methods inherited from Chef::Provider
#action_nothing, #cleanup_after_converge, #converge_by, #define_resource_requirements, #events, #initialize, #node, node_map, #process_resource_requirements, provides, provides?, #requirements, #resource_collection, #resource_updated?, #run_action, #set_updated_status, supports?, #whyrun_mode?
Methods included from Mixin::DescendantsTracker
#descendants, descendants, direct_descendants, #direct_descendants, find_descendants_by_name, #find_descendants_by_name, #inherited, store_inherited
Methods included from Mixin::ShellOut
#run_command_compatible_options, #shell_out, #shell_out!, #shell_out_with_systems_locale, #shell_out_with_systems_locale!
Constructor Details
This class inherits a constructor from Chef::Provider
Instance Method Details
#action_run ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/chef/provider/execute.rb', line 36 def action_run opts = {} if sentinel_file = sentinel_file_if_exists Chef::Log.debug("#{@new_resource} sentinel file #{sentinel_file} exists - nothing to do") return false end # original implementation did not specify a timeout, but ShellOut # *always* times out. So, set a very long default timeout opts[:timeout] = @new_resource.timeout || 3600 opts[:returns] = @new_resource.returns if @new_resource.returns opts[:environment] = @new_resource.environment if @new_resource.environment opts[:user] = @new_resource.user if @new_resource.user opts[:group] = @new_resource.group if @new_resource.group opts[:cwd] = @new_resource.cwd if @new_resource.cwd opts[:umask] = @new_resource.umask if @new_resource.umask opts[:log_level] = :info opts[:log_tag] = @new_resource.to_s if STDOUT.tty? && !Chef::Config[:daemon] && Chef::Log.info? && !@new_resource.sensitive opts[:live_stream] = STDOUT end description = @new_resource.sensitive ? "sensitive resource" : @new_resource.command converge_by("execute #{description}") do result = shell_out!(@new_resource.command, opts) Chef::Log.info("#{@new_resource} ran successfully") end end |
#load_current_resource ⇒ Object
28 29 30 |
# File 'lib/chef/provider/execute.rb', line 28 def load_current_resource true end |
#whyrun_supported? ⇒ Boolean
32 33 34 |
# File 'lib/chef/provider/execute.rb', line 32 def whyrun_supported? true end |