summaryrefslogtreecommitdiff
path: root/lib/chef/node.rb
diff options
context:
space:
mode:
authorClaire McQuin <claire@getchef.com>2014-05-12 11:49:01 -0700
committerClaire McQuin <claire@getchef.com>2014-05-15 14:04:19 -0700
commit68e33803973a51a461037426b8318320bcc57b34 (patch)
tree974d92b27159454465951a7ed766bd1f45b7023f /lib/chef/node.rb
parent831691edfb95a4f56d684819d698d81fdd517f2a (diff)
downloadchef-68e33803973a51a461037426b8318320bcc57b34.tar.gz
add whitelist config options for attributes saved by the node
Diffstat (limited to 'lib/chef/node.rb')
-rw-r--r--lib/chef/node.rb33
1 files changed, 30 insertions, 3 deletions
diff --git a/lib/chef/node.rb b/lib/chef/node.rb
index 6061dbe615..0a3a4f4297 100644
--- a/lib/chef/node.rb
+++ b/lib/chef/node.rb
@@ -520,18 +520,18 @@ class Chef
if Chef::Config[:why_run]
Chef::Log.warn("In whyrun mode, so NOT performing node save.")
else
- chef_server_rest.put_rest("nodes/#{name}", self)
+ chef_server_rest.put_rest("nodes/#{name}", data_for_save)
end
rescue Net::HTTPServerException => e
raise e unless e.response.code == "404"
- chef_server_rest.post_rest("nodes", self)
+ chef_server_rest.post_rest("nodes", data_for_save)
end
self
end
# Create the node via the REST API
def create
- chef_server_rest.post_rest("nodes", self)
+ chef_server_rest.post_rest("nodes", data_for_save)
self
end
@@ -543,5 +543,32 @@ class Chef
self.name <=> other_node.name
end
+ private
+
+ def data_for_save
+ Chef::Log.info("Whitelisting node attributes for save")
+ data = for_json
+ ["automatic", "default", "normal", "override"].each do |level|
+ whitelist_config_option = "#{level}_attribute_whitelist".to_sym
+ whitelist = Chef::Config[whitelist_config_option]
+ unless whitelist.nil? # nil is default, saves everything
+ data[level] = apply_whitelist_filter(data[level], whitelist)
+ end
+ end
+ data
+ end
+
+ def apply_whitelist_filter(data, whitelist)
+ return nil if data.nil?
+
+ new_data = data.reject { |k, v| !whitelist.keys.include? k }
+ whitelist.each do |k, v|
+ if v.kind_of? Hash
+ new_data[k] = apply_whitelist_filter(new_data[k], v)
+ end
+ end
+ new_data
+ end
+
end
end