diff options
author | Nick Lewis <nick@puppetlabs.com> | 2011-03-09 13:43:57 -0800 |
---|---|---|
committer | Nick Lewis <nick@puppetlabs.com> | 2011-03-09 13:43:57 -0800 |
commit | 40e8b48eb19973ec413518be656249e134344ee0 (patch) | |
tree | 8f6a10924b74ff2b52efe992feb4be420b7ae2f7 /lib/puppet/rails/inventory_node.rb | |
parent | eae17c3cba159d895e5ec2e87e4abe8c125a9562 (diff) | |
parent | 531e25836e1313cd508ab8394e16cf438a62ac7b (diff) | |
download | puppet-40e8b48eb19973ec413518be656249e134344ee0.tar.gz puppet-40e8b48eb19973ec413518be656249e134344ee0.tar.xz puppet-40e8b48eb19973ec413518be656249e134344ee0.zip |
Merge branch 'maint/2.6.next/6338' into 2.6.next
Diffstat (limited to 'lib/puppet/rails/inventory_node.rb')
-rw-r--r-- | lib/puppet/rails/inventory_node.rb | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/lib/puppet/rails/inventory_node.rb b/lib/puppet/rails/inventory_node.rb new file mode 100644 index 000000000..b3e321f94 --- /dev/null +++ b/lib/puppet/rails/inventory_node.rb @@ -0,0 +1,37 @@ +require 'puppet/rails/inventory_fact' + +class Puppet::Rails::InventoryNode < ::ActiveRecord::Base + has_many :facts, :class_name => "Puppet::Rails::InventoryFact", :dependent => :delete_all + + named_scope :has_fact_with_value, lambda { |name,value| + { + :conditions => ["inventory_facts.name = ? AND inventory_facts.value = ?", name, value], + :joins => :facts + } + } + + named_scope :has_fact_without_value, lambda { |name,value| + { + :conditions => ["inventory_facts.name = ? AND inventory_facts.value != ?", name, value], + :joins => :facts + } + } + + named_scope :has_fact, lambda { |name| + { + :conditions => ["inventory_facts.name = ?", name], + :joins => :facts + } + } + + def value_for(fact_name) + fact = facts.find_by_name(fact_name) + fact ? fact.value : nil + end + + def facts_to_hash + facts.inject({}) do |fact_hash,fact| + fact_hash.merge(fact.name => fact.value) + end + end +end |