Class: Chef::Provider::Execute

Inherits:
Chef::Provider show all
Defined in:
lib/chef/provider/execute.rb

Direct Known Subclasses

Script

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_runObject



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_resourceObject



28
29
30
# File 'lib/chef/provider/execute.rb', line 28

def load_current_resource
  true
end

#whyrun_supported?Boolean

Returns:

  • (Boolean)


32
33
34
# File 'lib/chef/provider/execute.rb', line 32

def whyrun_supported?
  true
end