diff options
| author | Paul Berry <paul@puppetlabs.com> | 2010-11-01 13:26:41 -0700 |
|---|---|---|
| committer | Paul Berry <paul@puppetlabs.com> | 2010-11-01 13:26:41 -0700 |
| commit | 6c116015ce4a9e6e7de392047f38b7a9e911bc0c (patch) | |
| tree | a042b9d7ecd2f22ef9b2056986170b14aad774a9 /lib/puppet/indirector/inventory | |
| parent | ee4eda825c33469e09c88a1f8c4234202cce5ce9 (diff) | |
| download | puppet-6c116015ce4a9e6e7de392047f38b7a9e911bc0c.tar.gz puppet-6c116015ce4a9e6e7de392047f38b7a9e911bc0c.tar.xz puppet-6c116015ce4a9e6e7de392047f38b7a9e911bc0c.zip | |
Refactor Puppet::Node::Inventory::Yaml in preparation for adding freshness
Diffstat (limited to 'lib/puppet/indirector/inventory')
| -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 |
