diff options
author | Jeff McCune <jeff@puppetlabs.com> | 2012-03-29 15:48:10 -0700 |
---|---|---|
committer | Jeff McCune <jeff@puppetlabs.com> | 2012-03-29 15:48:10 -0700 |
commit | a1a5f7487d2009c92f68475c60c2fcaadcfe21e4 (patch) | |
tree | bb468cc7b5b283201cec502c626cb9733a58aa75 /lib/puppet/parser | |
parent | d37815e5bfe1d480e5fe4691f82aa615b25a08a2 (diff) | |
parent | fef247b5db492bdfc971036b1a52cbe7ba58fcb3 (diff) |
Merge pull request #53 from traylenator/fqdn_rotate
(#13205) Rotate array/string randomley based on fqdn, fqdn_rotate()
Diffstat (limited to 'lib/puppet/parser')
-rw-r--r-- | lib/puppet/parser/functions/fqdn_rotate.rb | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/fqdn_rotate.rb b/lib/puppet/parser/functions/fqdn_rotate.rb new file mode 100644 index 0000000..6558206 --- /dev/null +++ b/lib/puppet/parser/functions/fqdn_rotate.rb @@ -0,0 +1,46 @@ +# +# fqdn_rotate.rb +# + +module Puppet::Parser::Functions + newfunction(:fqdn_rotate, :type => :rvalue, :doc => <<-EOS +Rotates an array a random number of times based on a nodes fqdn. + EOS + ) do |arguments| + + raise(Puppet::ParseError, "fqdn_rotate(): Wrong number of arguments " + + "given (#{arguments.size} for 1)") if arguments.size < 1 + + value = arguments[0] + klass = value.class + require 'digest/md5' + + unless [Array, String].include?(klass) + raise(Puppet::ParseError, 'fqdn_rotate(): Requires either ' + + 'array or string to work with') + end + + result = value.clone + + string = value.is_a?(String) ? true : false + + # Check whether it makes sense to rotate ... + return result if result.size <= 1 + + # We turn any string value into an array to be able to rotate ... + result = string ? result.split('') : result + + elements = result.size + + srand(Digest::MD5.hexdigest([lookupvar('::fqdn'),arguments].join(':')).hex) + rand(elements).times { + result.push result.shift + } + + result = string ? result.join : result + + return result + end +end + +# vim: set ts=2 sw=2 et : |