blob: 95213cc6adaba5fc835bbf7976e05397723063ff (
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
52
53
54
55
56
57
58
59
60
61
62
63
64
|
#
# fact.rb
#
module Puppet::Parser::Functions
newfunction(:fact, :type => :rvalue, :doc => <<-EOS
This function will retrieve fact from Facter based on the fact
name and expose it for further use within Puppet manifest file ...
For example:
Given the following sample manifest:
define partitions {
$result = split(fact("partitions_${name}"), ',')
notice $result
partition { $result: }
}
define partition {
notice $name
}
$available_disks = split($disks, ',')
partitions { $available_disks: }
This will produce the following:
notice: Scope(Partitions[hda]): hda1 hda2
notice: Scope(Partition[hda1]): hda1
notice: Scope(Partition[hda2]): hda2
Which allows you to avoid resorting to the following:
$fact = "partitions_${name}"
$result = split(inline_template("<%= scope.lookupvar(fact) %>"), ',')
Phasing out the need for use and abuse of the infamous inline_template in the
partitions define given above.
EOS
) do |arguments|
raise(Puppet::ParseError, "Wrong number of arguments " +
"given (#{arguments.size} for 1)") if arguments.size < 1
fact = arguments[0]
raise(Puppet::ParseError, 'You must provide fact name') if fact.empty?
result = lookupvar(fact) # Get the value of interest from Facter ...
if not result or result.empty?
raise(Puppet::ParseError, "Unable to retrieve fact `#{fact}'")
end
return result
end
end
# vim: set ts=2 sw=2 et :
|