Class: Chef::Recipe

Overview

Chef::Recipe

A Recipe object is the context in which Chef recipes are evaluated.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Mixin::Deprecation

#deprecated_ivar

Methods included from Mixin::FromFile

#class_from_file, #from_file

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::Recipe

#method_missing

Methods included from Mixin::ConvertToClassName

#convert_to_class_name, #convert_to_snake_case, #filename_to_qualified_string, #snake_case_basename

Methods included from DSL::IncludeRecipe

#include_recipe, #load_recipe, #require_recipe

Methods included from DSL::PlatformIntrospection

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

Methods included from DSL::DataQuery

#data_bag, #data_bag_item, #search

Constructor Details

#initialize(cookbook_name, recipe_name, run_context) ⇒ Recipe

Returns a new instance of Recipe.



64
65
66
67
68
69
70
71
# File 'lib/chef/recipe.rb', line 64

def initialize(cookbook_name, recipe_name, run_context)
  @cookbook_name = cookbook_name
  @recipe_name = recipe_name
  @run_context = run_context
  # TODO: 5/19/2010 cw/tim: determine whether this can be removed
  @params = Hash.new
  @node = deprecated_ivar(run_context.node, :node, :warn)
end

Dynamic Method Handling

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

Instance Attribute Details

#cookbook_nameObject

Returns the value of attribute cookbook_name.



45
46
47
# File 'lib/chef/recipe.rb', line 45

def cookbook_name
  @cookbook_name
end

#paramsObject

Returns the value of attribute params.



45
46
47
# File 'lib/chef/recipe.rb', line 45

def params
  @params
end

#recipeObject

Returns the value of attribute recipe.



45
46
47
# File 'lib/chef/recipe.rb', line 45

def recipe
  @recipe
end

#recipe_nameObject

Returns the value of attribute recipe_name.



45
46
47
# File 'lib/chef/recipe.rb', line 45

def recipe_name
  @recipe_name
end

#run_contextObject

Returns the value of attribute run_context.



45
46
47
# File 'lib/chef/recipe.rb', line 45

def run_context
  @run_context
end

Class Method Details

.parse_recipe_name(recipe_name) ⇒ Object

Parses a potentially fully-qualified recipe name into its cookbook name and recipe short name.

For example:

"aws::elastic_ip" returns [:aws, "elastic_ip"]
"aws" returns [:aws, "default"]

– TODO: Duplicates functionality of RunListItem



55
56
57
58
59
60
61
62
# File 'lib/chef/recipe.rb', line 55

def self.parse_recipe_name(recipe_name)
  rmatch = recipe_name.match(/(.+?)::(.+)/)
  if rmatch
    [ rmatch[1].to_sym, rmatch[2] ]
  else
    [ recipe_name.to_sym, "default" ]
  end
end

Instance Method Details

#nodeObject

Used in DSL mixins



74
75
76
# File 'lib/chef/recipe.rb', line 74

def node
  run_context.node
end

#resources(*args) ⇒ Object

Used by the DSL to look up resources when executing in the context of a recipe.



80
81
82
# File 'lib/chef/recipe.rb', line 80

def resources(*args)
  run_context.resource_collection.find(*args)
end

#tag(*tags) ⇒ Object

Sets a tag, or list of tags, for this node. Syntactic sugar for run_context.node.

With no arguments, returns the list of tags.

Parameters

tags<Array>

A list of tags to add - can be a single string

Returns

tags<Array>

The contents of run_context.node



94
95
96
97
98
99
100
101
102
103
104
# File 'lib/chef/recipe.rb', line 94

def tag(*tags)
  if tags.length > 0
    tags.each do |tag|
      tag = tag.to_s
      run_context.node.normal[:tags] << tag unless run_context.node[:tags].include?(tag)
    end
    run_context.node[:tags]
  else
    run_context.node[:tags]
  end
end

#tagged?(*tags) ⇒ Boolean

Returns true if the node is tagged with all of the supplied tags.

Parameters

tags<Array>

A list of tags

Returns

true<TrueClass>

If all the parameters are present

false<FalseClass>

If any of the parameters are missing

Returns:

  • (Boolean)


114
115
116
117
118
119
# File 'lib/chef/recipe.rb', line 114

def tagged?(*tags)
  tags.each do |tag|
    return false unless run_context.node[:tags].include?(tag)
  end
  true
end

#untag(*tags) ⇒ Object

Removes the list of tags from the node.

Parameters

tags<Array>

A list of tags

Returns

tags<Array>

The current list of run_context.node



128
129
130
131
132
# File 'lib/chef/recipe.rb', line 128

def untag(*tags)
  tags.each do |tag|
    run_context.node.normal[:tags].delete(tag)
  end
end