2011-04-30 04:16:12 +02:00
|
|
|
#
|
2011-08-05 09:25:03 +02:00
|
|
|
# is_domain_name.rb
|
2011-04-30 04:16:12 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
module Puppet::Parser::Functions
|
2011-08-05 09:25:03 +02:00
|
|
|
newfunction(:is_domain_name, :type => :rvalue, :doc => <<-EOS
|
2011-11-09 09:02:09 +01:00
|
|
|
Returns true if the string passed to this function is a syntactically correct domain name.
|
2011-04-30 04:16:12 +02:00
|
|
|
EOS
|
|
|
|
) do |arguments|
|
2011-06-29 22:21:55 +02:00
|
|
|
|
|
|
|
if (arguments.size != 1) then
|
2011-08-05 09:25:03 +02:00
|
|
|
raise(Puppet::ParseError, "is_domain_name(): Wrong number of arguments "+
|
2011-06-29 22:21:55 +02:00
|
|
|
"given #{arguments.size} for 1")
|
|
|
|
end
|
|
|
|
|
2015-02-19 21:01:26 +01:00
|
|
|
# Only allow string types
|
|
|
|
return false unless arguments[0].is_a?(String)
|
|
|
|
|
2015-02-14 16:46:34 +01:00
|
|
|
domain = arguments[0].dup
|
2011-07-29 21:08:31 +02:00
|
|
|
|
2011-11-09 09:02:09 +01:00
|
|
|
# Limits (rfc1035, 3.1)
|
|
|
|
domain_max_length=255
|
|
|
|
label_min_length=1
|
|
|
|
label_max_length=63
|
|
|
|
|
|
|
|
# Allow ".", it is the top level domain
|
|
|
|
return true if domain == '.'
|
|
|
|
|
|
|
|
# Remove the final dot, if present.
|
|
|
|
domain.chomp!('.')
|
|
|
|
|
|
|
|
# Check the whole domain
|
|
|
|
return false if domain.empty?
|
|
|
|
return false if domain.length > domain_max_length
|
|
|
|
|
|
|
|
# Check each label in the domain
|
|
|
|
labels = domain.split('.')
|
|
|
|
vlabels = labels.each do |label|
|
|
|
|
break if label.length < label_min_length
|
|
|
|
break if label.length > label_max_length
|
|
|
|
break if label[-1..-1] == '-'
|
|
|
|
break if label[0..0] == '-'
|
|
|
|
break unless /^[a-z\d-]+$/i.match(label)
|
2011-07-29 21:08:31 +02:00
|
|
|
end
|
2011-11-09 09:02:09 +01:00
|
|
|
return vlabels == labels
|
2011-07-29 21:08:31 +02:00
|
|
|
|
2011-04-30 04:16:12 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# vim: set ts=2 sw=2 et :
|