Module: OpenSSL::X509::Name::RFC2253DN

Defined in:
lib/openssl/x509.rb

Constant Summary collapse

Special =
',=+<>#;'
HexChar =
/[0-9a-fA-F]/
HexPair =
/#{HexChar}#{HexChar}/
HexString =
/#{HexPair}+/
Pair =
/\\(?:[#{Special}]|\\|"|#{HexPair})/
StringChar =
/[^#{Special}\\"]/
QuoteChar =
/[^\\"]/
AttributeType =
/[a-zA-Z][0-9a-zA-Z]*|[0-9]+(?:\.[0-9]+)*/
AttributeValue =
/
  (?!["#])((?:#{StringChar}|#{Pair})*)|
  \#(#{HexString})|
  "((?:#{QuoteChar}|#{Pair})*)"
/x
TypeAndValue =
/\A(#{AttributeType})=#{AttributeValue}/

Instance Method Summary collapse

Instance Method Details

#expand_hexstring(str) ⇒ Object



94
95
96
97
98
99
# File 'lib/openssl/x509.rb', line 94

def expand_hexstring(str)
  return nil unless str
  der = str.gsub(HexPair){|hex| Integer("0x#{hex}").chr }
  a1 = OpenSSL::ASN1.decode(der)
  return a1.value, a1.tag
end

#expand_pair(str) ⇒ Object



83
84
85
86
87
88
89
90
91
92
# File 'lib/openssl/x509.rb', line 83

def expand_pair(str)
  return nil unless str
  return str.gsub(Pair){|pair|
    case pair.size
    when 2 then pair[1,1]
    when 3 then Integer("0x#{pair[1,2]}").chr
    else raise OpenSSL::X509::NameError, "invalid pair: #{str}"
    end
  }
end

#expand_value(str1, str2, str3) ⇒ Object



101
102
103
104
105
106
# File 'lib/openssl/x509.rb', line 101

def expand_value(str1, str2, str3)
  value = expand_pair(str1)
  value, tag = expand_hexstring(str2) unless value
  value = expand_pair(str3) unless value
  return value, tag
end

#scan(dn) ⇒ Object



108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/openssl/x509.rb', line 108

def scan(dn)
  str = dn
  ary = []
  while true
    if md = TypeAndValue.match(str)
      matched = md.to_s
      remain = md.post_match
      type = md[1]
      value, tag = expand_value(md[2], md[3], md[4]) rescue nil
      if value
        type_and_value = [type, value]
        type_and_value.push(tag) if tag
        ary.unshift(type_and_value)
        if remain.length > 2 && remain[0] == ?,
          str = remain[1..-1]
          next
        elsif remain.length > 2 && remain[0] == ?+
          raise OpenSSL::X509::NameError,
            "multi-valued RDN is not supported: #{dn}"
        elsif remain.empty?
          break
        end
      end
    end
    msg_dn = dn[0, dn.length - str.length] + " =>" + str
    raise OpenSSL::X509::NameError, "malformed RDN: #{msg_dn}"
  end
  return ary
end