blob: 0ef90d6d8c8c5c240b0c35f135cfcbb1d76d5143 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
require 'puppet/provider/confine'
# Require a specific value for a variable, either a Puppet setting
# or a Facter value. This class is a bit weird because the name
# is set explicitly by the ConfineCollection class -- from this class,
# it's not obvious how the name would ever get set.
class Puppet::Provider::Confine::Variable < Puppet::Provider::Confine
# Provide a hash summary of failing confines -- the key of the hash
# is the name of the confine, and the value is the missing yet required values.
# Only returns failed values, not all required values.
def self.summarize(confines)
result = Hash.new { |hash, key| hash[key] = [] }
confines.inject(result) { |total, confine| total[confine.name] += confine.values unless confine.valid?; total }
end
# This is set by ConfineCollection.
attr_accessor :name
# Retrieve the value from facter
def facter_value
unless defined?(@facter_value) and @facter_value
@facter_value = ::Facter.value(name).to_s.downcase
end
@facter_value
end
def message(value)
"facter value '%s' for '%s' not in required list '%s'" % [value, self.name, values.join(",")]
end
# Compare the passed-in value to the retrieved value.
def pass?(value)
test_value.downcase.to_s == value.to_s.downcase
end
def reset
# Reset the cache. We want to cache it during a given
# run, but across runs.
@facter_value = nil
end
private
def setting?
Puppet.settings.valid?(name)
end
def test_value
setting? ? Puppet.settings[name] : facter_value
end
end
|