summaryrefslogtreecommitdiffstats
path: root/lib/openssl/ssl.rb
diff options
context:
space:
mode:
authorgotoyuzo <gotoyuzo@ruby-lang.org>2005-12-26 23:26:21 +0000
committergotoyuzo <gotoyuzo@ruby-lang.org>2005-12-26 23:26:21 +0000
commitfaca807ca9f90a5cbc25cf9005e210b55010b9aa (patch)
treed0239e798954efbe788dd1bd2e5c1f7bad7ea284 /lib/openssl/ssl.rb
parentfefdfe76c5255acb98c6357667bf5938c108ca76 (diff)
downloadruby-openssl-history-faca807ca9f90a5cbc25cf9005e210b55010b9aa.tar.gz
* ext/openssl/lib/openssl/ssl.rb (OpenSSL::SSL::SSLSocket#post_connection_chech):
treat wildcard character in commonName. [ruby-dev:28121] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9741 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/openssl/ssl.rb')
-rw-r--r--lib/openssl/ssl.rb5
1 files changed, 3 insertions, 2 deletions
diff --git a/lib/openssl/ssl.rb b/lib/openssl/ssl.rb
index 9b287fc..a535fc1 100644
--- a/lib/openssl/ssl.rb
+++ b/lib/openssl/ssl.rb
@@ -82,8 +82,9 @@ module OpenSSL
}
if check_common_name
cert.subject.to_a.each{|oid, value|
- if oid == "CN" && value.casecmp(hostname) == 0
- return true
+ if oid == "CN"
+ reg = Regexp.escape(value).gsub(/\\\*/, "[^.]+")
+ return true if /\A#{reg}\z/i =~ hostname
end
}
end