Class: Chef::Recipe
- Includes:
- DSL::DataQuery, DSL::IncludeRecipe, DSL::PlatformIntrospection, DSL::RebootPending, DSL::Recipe, DSL::RegistryHelper, Mixin::Deprecation, Mixin::FromFile
- Defined in:
- lib/chef/recipe.rb
Overview
Chef::Recipe
A Recipe object is the context in which Chef recipes are evaluated.
Constant Summary
Constants included from Mixin::ShellOut
Mixin::ShellOut::DEPRECATED_OPTIONS
Instance Attribute Summary collapse
-
#cookbook_name ⇒ Object
Returns the value of attribute cookbook_name.
-
#params ⇒ Object
Returns the value of attribute params.
-
#recipe ⇒ Object
Returns the value of attribute recipe.
-
#recipe_name ⇒ Object
Returns the value of attribute recipe_name.
-
#run_context ⇒ Object
Returns the value of attribute run_context.
Class Method Summary collapse
-
.parse_recipe_name(recipe_name) ⇒ Object
Parses a potentially fully-qualified recipe name into its cookbook name and recipe short name.
Instance Method Summary collapse
-
#initialize(cookbook_name, recipe_name, run_context) ⇒ Recipe
constructor
A new instance of Recipe.
-
#node ⇒ Object
Used in DSL mixins.
-
#resources(*args) ⇒ Object
Used by the DSL to look up resources when executing in the context of a recipe.
-
#tag(*tags) ⇒ Object
This was moved to Chef::Node#tag, redirecting here for compatability.
-
#tagged?(*tags) ⇒ Boolean
Returns true if the node is tagged with all of the supplied
tags
. -
#untag(*tags) ⇒ Object
Removes the list of tags from the node.
Methods included from Mixin::Deprecation
Methods included from Mixin::FromFile
Methods included from DSL::RebootPending
Methods included from DSL::PlatformIntrospection
#platform?, #platform_family?, #value_for_platform, #value_for_platform_family
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
#build_resource, #declare_resource, #describe_self_for_error, #evaluate_resource_definition, #exec, #has_resource_definition?, #have_resource_class_for?, #method_missing, #resource_class_for
Methods included from Mixin::ConvertToClassName
#constantize, #convert_to_class_name, #convert_to_snake_case, #filename_to_qualified_string, #snake_case_basename
Methods included from Mixin::ShellOut
#run_command_compatible_options, #shell_out, #shell_out!, #shell_out_with_systems_locale, #shell_out_with_systems_locale!
Methods included from DSL::IncludeRecipe
#include_recipe, #load_recipe, #require_recipe
Methods included from DSL::DataQuery
#data_bag, #data_bag_item, #search
Methods included from EncryptedDataBagItem::CheckEncrypted
Constructor Details
#initialize(cookbook_name, recipe_name, run_context) ⇒ Recipe
Returns a new instance of Recipe.
66 67 68 69 70 71 72 |
# File 'lib/chef/recipe.rb', line 66 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 end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Chef::DSL::Recipe
Instance Attribute Details
#cookbook_name ⇒ Object
Returns the value of attribute cookbook_name.
47 48 49 |
# File 'lib/chef/recipe.rb', line 47 def cookbook_name @cookbook_name end |
#params ⇒ Object
Returns the value of attribute params.
47 48 49 |
# File 'lib/chef/recipe.rb', line 47 def params @params end |
#recipe ⇒ Object
Returns the value of attribute recipe.
47 48 49 |
# File 'lib/chef/recipe.rb', line 47 def recipe @recipe end |
#recipe_name ⇒ Object
Returns the value of attribute recipe_name.
47 48 49 |
# File 'lib/chef/recipe.rb', line 47 def recipe_name @recipe_name end |
#run_context ⇒ Object
Returns the value of attribute run_context.
47 48 49 |
# File 'lib/chef/recipe.rb', line 47 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
57 58 59 60 61 62 63 64 |
# File 'lib/chef/recipe.rb', line 57 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
#node ⇒ Object
Used in DSL mixins
75 76 77 |
# File 'lib/chef/recipe.rb', line 75 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.
81 82 83 |
# File 'lib/chef/recipe.rb', line 81 def resources(*args) run_context.resource_collection.find(*args) end |
#tag(*tags) ⇒ Object
This was moved to Chef::Node#tag, redirecting here for compatability
86 87 88 |
# File 'lib/chef/recipe.rb', line 86 def tag(*) run_context.node.tag(*) 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
98 99 100 101 102 103 104 105 |
# File 'lib/chef/recipe.rb', line 98 def tagged?(*) return false if run_context.node[:tags].nil? .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
114 115 116 117 118 |
# File 'lib/chef/recipe.rb', line 114 def untag(*) .each do |tag| run_context.node.normal[:tags].delete(tag) end end |