Module: OpenSSL::X509::Name::RFC2253DN
- Defined in:
- lib/1.8/openssl/x509-internal.rb,
lib/1.9/openssl/x509-internal.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}/
Class Method Summary collapse
- .expand_hexstring(str) ⇒ Object
- .expand_pair(str) ⇒ Object
- .expand_value(str1, str2, str3) ⇒ Object
- .scan(dn) ⇒ Object
Class Method Details
.expand_hexstring(str) ⇒ Object
93 94 95 96 97 98 |
# File 'lib/1.8/openssl/x509-internal.rb', line 93 def (str) return nil unless str der = str.gsub(HexPair){$&.to_i(16).chr } a1 = OpenSSL::ASN1.decode(der) return a1.value, a1.tag end |
.expand_pair(str) ⇒ Object
81 82 83 84 85 86 87 88 89 90 91 |
# File 'lib/1.8/openssl/x509-internal.rb', line 81 def (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
100 101 102 103 104 105 |
# File 'lib/1.8/openssl/x509-internal.rb', line 100 def (str1, str2, str3) value = (str1) value, tag = (str2) unless value value = (str3) unless value return value, tag end |
.scan(dn) ⇒ Object
107 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 |
# File 'lib/1.8/openssl/x509-internal.rb', line 107 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 = (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 |