diff options
author | Paul Berry <paul@puppetlabs.com> | 2010-11-01 13:26:41 -0700 |
---|---|---|
committer | Paul Berry <paul@puppetlabs.com> | 2011-02-17 15:01:57 -0800 |
commit | 67f24e48fb100a2bd971e87669d4fb91486156dc (patch) | |
tree | 307b6994f954ef01ad31324dc1d9cd74328b189f | |
parent | 23fc4db954c22bce2c6cc8996d5fafb175e2b747 (diff) | |
download | puppet-67f24e48fb100a2bd971e87669d4fb91486156dc.tar.gz puppet-67f24e48fb100a2bd971e87669d4fb91486156dc.tar.xz puppet-67f24e48fb100a2bd971e87669d4fb91486156dc.zip |
Refactor Puppet::Node::Inventory::Yaml in preparation for adding freshness
-rw-r--r-- | lib/puppet/indirector/inventory/yaml.rb | 46 |
1 files changed, 29 insertions, 17 deletions
diff --git a/lib/puppet/indirector/inventory/yaml.rb b/lib/puppet/indirector/inventory/yaml.rb index c6b1a14aa..5acbef60c 100644 --- a/lib/puppet/indirector/inventory/yaml.rb +++ b/lib/puppet/indirector/inventory/yaml.rb @@ -15,23 +15,7 @@ class Puppet::Node::Inventory::Yaml < Puppet::Indirector::Yaml type, name, operator = key.to_s.split(".") operator ||= 'eq' - next unless type == "facts" - return false unless facts.values[name] - - return false unless case operator - when "eq" - facts.values[name].to_s == value.to_s - when "le" - facts.values[name].to_f <= value.to_f - when "ge" - facts.values[name].to_f >= value.to_f - when "lt" - facts.values[name].to_f < value.to_f - when "gt" - facts.values[name].to_f > value.to_f - when "ne" - facts.values[name].to_s != value.to_s - end + return false unless node_matches_option?(type, name, operator, value, facts) end return true end @@ -44,4 +28,32 @@ class Puppet::Node::Inventory::Yaml < Puppet::Indirector::Yaml end node_names end + + private + + def node_matches_option?(type, name, operator, value, facts) + case type + when "facts" + compare_facts(operator, facts.values[name], value) + end + end + + def compare_facts(operator, value1, value2) + return false unless value1 + + case operator + when "eq" + value1.to_s == value2.to_s + when "le" + value1.to_f <= value2.to_f + when "ge" + value1.to_f >= value2.to_f + when "lt" + value1.to_f < value2.to_f + when "gt" + value1.to_f > value2.to_f + when "ne" + value1.to_s != value2.to_s + end + end end |