Class: Chef::Provider::Env
- Inherits:
-
Chef::Provider
- Object
- Chef::Provider
- Chef::Provider::Env
- Includes:
- Mixin::Command
- Defined in:
- lib/chef/provider/env.rb,
lib/chef/provider/env/windows.rb
Direct Known Subclasses
Defined Under Namespace
Classes: Windows
Constant Summary
Constants included from Mixin::ShellOut
Mixin::ShellOut::DEPRECATED_OPTIONS
Instance Attribute Summary collapse
-
#key_exists ⇒ Object
Returns the value of attribute key_exists.
Attributes inherited from Chef::Provider
#action, #cookbook_name, #current_resource, #new_resource, #recipe_name, #run_context
Instance Method Summary collapse
- #action_create ⇒ Object
- #action_delete ⇒ Object
- #action_modify ⇒ Object
- #create_env ⇒ Object
-
#current_values ⇒ Object
Returns the current values to split by delimiter.
-
#delete_element ⇒ Object
e.g.
- #delete_env ⇒ Object
- #env_key_exists(key_name) ⇒ Object
- #env_value(key_name) ⇒ Object
-
#initialize(new_resource, run_context) ⇒ Env
constructor
A new instance of Env.
- #load_current_resource ⇒ Object
- #modify_env ⇒ Object
-
#new_values ⇒ Object
Returns the new values to split by delimiter.
-
#requires_modify_or_create? ⇒ Boolean
(also: #compare_value)
Check to see if value needs any changes.
Methods included from Mixin::Command
#chdir_or_tmpdir, #handle_command_failures, #output_of_command, #run_command, #run_command_and_return_stdout_stderr, #run_command_with_systems_locale
Methods included from Mixin::Command::Windows
Methods included from Mixin::Command::Unix
Methods inherited from Chef::Provider
#action_nothing, #cleanup_after_converge, #converge_by, #define_resource_requirements, #events, #node, node_map, #process_resource_requirements, provides, provides?, #requirements, #resource_collection, #resource_updated?, #run_action, #set_updated_status, supports?, #whyrun_mode?, #whyrun_supported?
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
#initialize(new_resource, run_context) ⇒ Env
Returns a new instance of Env.
29 30 31 32 |
# File 'lib/chef/provider/env.rb', line 29 def initialize(new_resource, run_context) super @key_exists = true end |
Instance Attribute Details
#key_exists ⇒ Object
Returns the value of attribute key_exists.
27 28 29 |
# File 'lib/chef/provider/env.rb', line 27 def key_exists @key_exists end |
Instance Method Details
#action_create ⇒ Object
74 75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'lib/chef/provider/env.rb', line 74 def action_create if @key_exists if requires_modify_or_create? modify_env Chef::Log.info("#{@new_resource} altered") @new_resource.updated_by_last_action(true) end else create_env Chef::Log.info("#{@new_resource} created") @new_resource.updated_by_last_action(true) end end |
#action_delete ⇒ Object
118 119 120 121 122 123 124 |
# File 'lib/chef/provider/env.rb', line 118 def action_delete if @key_exists && !delete_element delete_env Chef::Log.info("#{@new_resource} deleted") @new_resource.updated_by_last_action(true) end end |
#action_modify ⇒ Object
126 127 128 129 130 131 132 133 134 135 136 |
# File 'lib/chef/provider/env.rb', line 126 def action_modify if @key_exists if requires_modify_or_create? modify_env Chef::Log.info("#{@new_resource} modified") @new_resource.updated_by_last_action(true) end else raise Chef::Exceptions::Env, "Cannot modify #{@new_resource} - key does not exist!" end end |
#create_env ⇒ Object
138 139 140 |
# File 'lib/chef/provider/env.rb', line 138 def create_env raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :#{@new_resource.action}" end |
#current_values ⇒ Object
Returns the current values to split by delimiter
157 158 159 |
# File 'lib/chef/provider/env.rb', line 157 def current_values @current_values ||= @current_resource.value.split(@new_resource.delim) end |
#delete_element ⇒ Object
e.g. delete a PATH element
Returns
- <true>
-
If we handled the element case and caller should not delete the key
- <false>
-
Caller should delete the key, either no :delim was specific or value was empty after we removed the element.
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 |
# File 'lib/chef/provider/env.rb', line 94 def delete_element return false unless @new_resource.delim #no delim: delete the key needs_delete = new_values.any? { |v| current_values.include?(v) } if !needs_delete Chef::Log.debug("#{@new_resource} element '#{@new_resource.value}' does not exist") return true #do not delete the key else new_value = current_values.select { |item| not new_values.include?(item) }.join(@new_resource.delim) if new_value.empty? return false #nothing left here, delete the key else old_value = @new_resource.value(new_value) create_env Chef::Log.debug("#{@new_resource} deleted #{old_value} element") @new_resource.updated_by_last_action(true) return true #we removed the element and updated; do not delete the key end end end |
#delete_env ⇒ Object
142 143 144 |
# File 'lib/chef/provider/env.rb', line 142 def delete_env raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :delete" end |
#env_key_exists(key_name) ⇒ Object
52 53 54 |
# File 'lib/chef/provider/env.rb', line 52 def env_key_exists(key_name) env_value(key_name) ? true : false end |
#env_value(key_name) ⇒ Object
48 49 50 |
# File 'lib/chef/provider/env.rb', line 48 def env_value(key_name) raise Chef::Exceptions::Env, "#{self.to_s} provider does not implement env_value!" end |
#load_current_resource ⇒ Object
34 35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/chef/provider/env.rb', line 34 def load_current_resource @current_resource = Chef::Resource::Env.new(@new_resource.name) @current_resource.key_name(@new_resource.key_name) if env_key_exists(@new_resource.key_name) @current_resource.value(env_value(@new_resource.key_name)) else @key_exists = false Chef::Log.debug("#{@new_resource} key does not exist") end @current_resource end |
#modify_env ⇒ Object
146 147 148 149 150 151 152 153 154 |
# File 'lib/chef/provider/env.rb', line 146 def modify_env if @new_resource.delim values = new_values.reject do |v| current_values.include?(v) end @new_resource.value((values + [@current_resource.value]).join(@new_resource.delim)) end create_env end |
#new_values ⇒ Object
Returns the new values to split by delimiter
162 163 164 |
# File 'lib/chef/provider/env.rb', line 162 def new_values @new_values ||= @new_resource.value.split(@new_resource.delim) end |
#requires_modify_or_create? ⇒ Boolean Also known as: compare_value
Check to see if value needs any changes
Returns
- <true>
-
If a change is required
- <false>
-
If a change is not required
61 62 63 64 65 66 67 68 69 70 |
# File 'lib/chef/provider/env.rb', line 61 def requires_modify_or_create? if @new_resource.delim #e.g. check for existing value within PATH not new_values.all? do |val| current_values.include? val end else @new_resource.value != @current_resource.value end end |