Class: Chef::Recipe
- Inherits:
-
Object
- Object
- Chef::Recipe
- Includes:
- DSL::Recipe, 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.
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.
Attributes included from Mixin::FromFile
Class Method Summary collapse
-
.parse_recipe_name(recipe_name, current_cookbook: nil) ⇒ 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.
- #inspect ⇒ Object
-
#node ⇒ Object
Used in DSL mixins.
-
#tag(*tags) ⇒ Object
This was moved to Chef::Node#tag, redirecting here for compatibility.
- #to_s ⇒ Object
-
#untag(*tags) ⇒ Object
Removes the list of tags from the node.
Methods included from Mixin::Deprecation
#deprecated_attr, #deprecated_attr_reader, #deprecated_attr_writer, #deprecated_ivar
Methods included from Mixin::FromFile
Methods included from DSL::Recipe
#exec, #have_resource_class_for?, #resource_class_for
Methods included from Mixin::LazyModuleInclude
#descendants, #include, #included
Methods included from DSL::Definitions
add_definition, #evaluate_resource_definition, #has_resource_definition?
Methods included from DSL::Resources
add_resource_dsl, remove_resource_dsl
Methods included from DSL::Cheffish
Methods included from DSL::RebootPending
Methods included from DSL::PlatformIntrospection
#older_than_win_2012_or_8?, #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::IncludeRecipe
Methods included from Mixin::NotifyingBlock
#notifying_block, #subcontext_block
Methods included from DSL::DeclareResource
#build_resource, #declare_resource, #delete_resource, #delete_resource!, #edit_resource, #edit_resource!, #find_resource, #find_resource!, #resources, #with_run_context
Methods included from Mixin::ShellOut
apply_default_env, maybe_add_timeout, #shell_out, #shell_out!
Methods included from Mixin::PowershellOut
#powershell_out, #powershell_out!
Methods included from Mixin::WindowsArchitectureHelper
#assert_valid_windows_architecture!, #disable_wow64_file_redirection, #forced_32bit_override_required?, #is_i386_process_on_x86_64_windows?, #node_supports_windows_architecture?, #node_windows_architecture, #restore_wow64_file_redirection, #valid_windows_architecture?, #with_os_architecture, #wow64_architecture_override_required?, #wow64_directory
Methods included from Mixin::PowershellExec
Methods included from DSL::Powershell
Methods included from DSL::DataQuery
#data_bag, #data_bag_item, #search, #tagged?
Methods included from EncryptedDataBagItem::CheckEncrypted
Constructor Details
#initialize(cookbook_name, recipe_name, run_context) ⇒ Recipe
Returns a new instance of Recipe.
57 58 59 60 61 62 63 |
# File 'lib/chef/recipe.rb', line 57 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 = {} end |
Instance Attribute Details
#cookbook_name ⇒ Object
Returns the value of attribute cookbook_name.
28 29 30 |
# File 'lib/chef/recipe.rb', line 28 def cookbook_name @cookbook_name end |
#params ⇒ Object
Returns the value of attribute params.
28 29 30 |
# File 'lib/chef/recipe.rb', line 28 def params @params end |
#recipe ⇒ Object
Returns the value of attribute recipe.
28 29 30 |
# File 'lib/chef/recipe.rb', line 28 def recipe @recipe end |
#recipe_name ⇒ Object
Returns the value of attribute recipe_name.
28 29 30 |
# File 'lib/chef/recipe.rb', line 28 def recipe_name @recipe_name end |
#run_context ⇒ Object
Returns the value of attribute run_context.
28 29 30 |
# File 'lib/chef/recipe.rb', line 28 def run_context @run_context end |
Class Method Details
.parse_recipe_name(recipe_name, current_cookbook: nil) ⇒ 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"]
"::elastic_ip" returns [ current_cookbook, "elastic_ip" ]
– TODO: Duplicates functionality of RunListItem
44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/chef/recipe.rb', line 44 def self.parse_recipe_name(recipe_name, current_cookbook: nil) case recipe_name when /(.+?)::(.+)/ [ $1.to_sym, $2 ] when /^::(.+)/ raise "current_cookbook is nil, cannot resolve #{recipe_name}" if current_cookbook.nil? [ current_cookbook.to_sym, $1 ] else [ recipe_name.to_sym, "default" ] end end |
Instance Method Details
#inspect ⇒ Object
92 93 94 |
# File 'lib/chef/recipe.rb', line 92 def inspect to_s end |
#node ⇒ Object
Used in DSL mixins
66 67 68 |
# File 'lib/chef/recipe.rb', line 66 def node run_context.node end |
#tag(*tags) ⇒ Object
This was moved to Chef::Node#tag, redirecting here for compatibility
71 72 73 |
# File 'lib/chef/recipe.rb', line 71 def tag(*) run_context.node.tag(*) end |
#to_s ⇒ Object
88 89 90 |
# File 'lib/chef/recipe.rb', line 88 def to_s "cookbook: #{cookbook_name ? cookbook_name : "(none)"}, recipe: #{recipe_name ? recipe_name : "(none)"} " 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.tags
82 83 84 85 86 |
# File 'lib/chef/recipe.rb', line 82 def untag(*) .each do |tag| run_context.node..delete(tag) end end |