2013-07-19 13:04:45 +02:00
|
|
|
require 'digest/md5'
|
|
|
|
|
|
|
|
module Puppet::Parser::Functions
|
|
|
|
newfunction(:postgresql_escape, :type => :rvalue, :doc => <<-EOS
|
|
|
|
Safely escapes a string using $$ using a random tag which should be consistent
|
|
|
|
EOS
|
|
|
|
) do |args|
|
|
|
|
|
|
|
|
raise(Puppet::ParseError, "postgresql_escape(): Wrong number of arguments " +
|
|
|
|
"given (#{args.size} for 1)") if args.size != 1
|
|
|
|
|
|
|
|
password = args[0]
|
|
|
|
|
2016-02-01 19:27:22 +01:00
|
|
|
if password !~ /\$\$/ and password[-1] != '$'
|
2013-07-19 13:04:45 +02:00
|
|
|
retval = "$$#{password}$$"
|
|
|
|
else
|
|
|
|
escape = Digest::MD5.hexdigest(password)[0..5].gsub(/\d/,'')
|
|
|
|
until password !~ /#{escape}/
|
|
|
|
escape = Digest::MD5.hexdigest(escape)[0..5].gsub(/\d/,'')
|
|
|
|
end
|
|
|
|
retval = "$#{escape}$#{password}$#{escape}$"
|
|
|
|
end
|
2016-02-01 19:27:22 +01:00
|
|
|
retval
|
2013-07-19 13:04:45 +02:00
|
|
|
end
|
|
|
|
end
|