SSL is a private module with class methods that help work with x.509 subjects.
@api private
::cn_from_subject extracts the CN from the given OpenSSL certtificate subject.
@api private
@param [OpenSSL::X509::Name] subject the subject to extract the CN field from
@return [String, nil] the CN, or nil if not found
# File lib/puppet/util/ssl.rb, line 44 def self.cn_from_subject(subject) if subject.respond_to? :to_a (subject.to_a.assoc('CN') || [])[1] end end
# File lib/puppet/util/ssl.rb, line 50 def self.is_possibly_valid_dn?(dn) dn =~ /=/ end
Given a DN string, parse it into an OpenSSL certificate subject. This method will flexibly handle both OpenSSl and RFC2253 formats, as given by nginx and Apache, respectively.
@param [String] dn the x.509 Distinguished Name (DN) string.
@return [OpenSSL::X509::Name] the certificate subject
# File lib/puppet/util/ssl.rb, line 22 def self.subject_from_dn(dn) if is_possibly_valid_dn?(dn) DN_PARSERS.each do |parser| begin return parser.call(dn) rescue OpenSSL::X509::NameError end end else NO_NAME end end