aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorshugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-02-22 16:55:31 +0000
committershugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-02-22 16:55:31 +0000
commitec2e637cb4539bfa735303d6f39728aa7158df02 (patch)
tree61abd55492305117cc10135cd6cf03718913e5c6 /lib
parent6b68105ab26cce76c2f2e3dd876e2551715f4570 (diff)
downloadruby-ec2e637cb4539bfa735303d6f39728aa7158df02.tar.gz
* lib/net/imap.rb (initialize): handle certs correctly. Thanks,
NABEYA Kenichi. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8016 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/net/imap.rb11
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/net/imap.rb b/lib/net/imap.rb
index e12b4bac3a..82d5b29738 100644
--- a/lib/net/imap.rb
+++ b/lib/net/imap.rb
@@ -885,15 +885,16 @@ module Net
raise "SSL extension not installed"
end
@usessl = true
- @sock = SSLSocket.new(@sock)
# verify the server.
- @sock.ca_file = certs if certs && FileTest::file?(certs)
- @sock.ca_path = certs if certs && FileTest::directory?(certs)
- @sock.verify_mode = VERIFY_PEER if verify
+ context = SSLContext::new()
+ context.ca_file = certs if certs && FileTest::file?(certs)
+ context.ca_path = certs if certs && FileTest::directory?(certs)
+ context.verify_mode = VERIFY_PEER if verify
if defined?(VerifyCallbackProc)
- @sock.verify_callback = VerifyCallbackProc
+ context.verify_callback = VerifyCallbackProc
end
+ @sock = SSLSocket.new(@sock, context)
@sock.connect # start ssl session.
else
@usessl = false