Class: Chef::Resource::ErlCall

Inherits:
Chef::Resource show all
Defined in:
lib/chef/resource/erl_call.rb

Constant Summary

Constants inherited from Chef::Resource

FORBIDDEN_IVARS, HIDDEN_IVARS

Instance Attribute Summary

Attributes inherited from Chef::Resource

#allowed_actions, #cookbook_name, #elapsed_time, #enclosing_provider, #not_if_args, #only_if_args, #params, #provider, #recipe_name, #resource_name, #retries, #retry_delay, #run_context, #source_line, #updated

Instance Method Summary collapse

Methods inherited from Chef::Resource

#action, #after_created, #as_json, #cookbook_version, #customize_exception, #defined_at, #delayed_notifications, dsl_name, #epic_fail, #events, #identity, identity_attr, #ignore_failure, #immediate_notifications, #inspect, #is, json_create, #load_prior_resource, #method_missing, #name, #node, #noop, #not_if, #notifies, #notifies_delayed, #notifies_immediately, #only_if, platform_map, provider_base, #provider_for_action, provides, #resolve_notification_references, resource_for_node, resource_for_platform, #resources, #run_action, #should_skip?, #state, state_attrs, #subscribes, #supports, #to_hash, #to_json, #to_s, #to_text, #updated?, #updated_by_last_action, #updated_by_last_action?, #validate_action

Methods included from Mixin::ConvertToClassName

#convert_to_class_name, #convert_to_snake_case, #filename_to_qualified_string, #snake_case_basename

Methods included from Mixin::Deprecation

#deprecated_ivar

Methods included from DSL::RegistryHelper

#registry_data_exists?, #registry_get_subkeys, #registry_get_values, #registry_has_subkeys?, #registry_key_exists?, #registry_value_exists?

Methods included from DSL::PlatformIntrospection

#platform?, #platform_family?, #value_for_platform, #value_for_platform_family

Methods included from Mixin::ParamsValidate

#set_or_return, #validate

Methods included from DSL::DataQuery

#data_bag, #data_bag_item, #search

Constructor Details

#initialize(name, run_context = nil) ⇒ ErlCall

Returns a new instance of ErlCall.



30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/chef/resource/erl_call.rb', line 30

def initialize(name, run_context=nil)
  super
  @resource_name = :erl_call

  @code = "q()." # your erlang code goes here
  @cookie = nil # cookie of the erlang node
  @distributed = false # if you want to have a distributed erlang node
  @name_type = "sname" # type of erlang hostname name or sname
  @node_name = "chef@localhost" # the erlang node hostname

  @action = "run"
  @allowed_actions.push(:run)
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Chef::Resource

Instance Method Details

#code(arg = nil) ⇒ Object



44
45
46
47
48
49
50
# File 'lib/chef/resource/erl_call.rb', line 44

def code(arg=nil)
  set_or_return(
    :code,
    arg,
    :kind_of => [ String ]
  )
end


52
53
54
55
56
57
58
# File 'lib/chef/resource/erl_call.rb', line 52

def cookie(arg=nil)
  set_or_return(
    :cookie,
    arg,
    :kind_of => [ String ]
  )
end

#distributed(arg = nil) ⇒ Object



60
61
62
63
64
65
66
# File 'lib/chef/resource/erl_call.rb', line 60

def distributed(arg=nil)
  set_or_return(
    :distributed,
    arg,
    :kind_of => [ TrueClass, FalseClass ]
  )
end

#name_type(arg = nil) ⇒ Object



68
69
70
71
72
73
74
# File 'lib/chef/resource/erl_call.rb', line 68

def name_type(arg=nil)
  set_or_return(
    :name_type,
    arg,
    :kind_of => [ String ]
  )
end

#node_name(arg = nil) ⇒ Object



76
77
78
79
80
81
82
# File 'lib/chef/resource/erl_call.rb', line 76

def node_name(arg=nil)
  set_or_return(
    :node_name,
    arg,
    :kind_of => [ String ]
  )
end