mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
2e0b6e28ad
add new method to inherit @sync from @io.sync. * ext/openssl/lib/net/protocols.rb (SSLIO#ssl_connect): no need to set sync flag explicitly. * ext/openssl/ossl_ssl.c (ossl_sslctx_initialize): call super. * ext/openssl/ossl_ssl.c (ossl_sslctx_setup): set extra chain certificates in @extra_chain_cert. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4859 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
56 lines
1.4 KiB
Ruby
56 lines
1.4 KiB
Ruby
=begin
|
|
= $RCSfile$ -- SSL/TLS enhancement for Net.
|
|
|
|
= Info
|
|
'OpenSSL for Ruby 2' project
|
|
Copyright (C) 2001 GOTOU YUUZOU <gotoyuzo@notwork.org>
|
|
All rights reserved.
|
|
|
|
= Licence
|
|
This program is licenced under the same licence as Ruby.
|
|
(See the file 'LICENCE'.)
|
|
|
|
= Requirements
|
|
This program requires Net 1.2.0 or higher version.
|
|
You can get it from RAA or Ruby's CVS repository.
|
|
|
|
= Version
|
|
$Id$
|
|
|
|
2001/11/06: Contiributed to Ruby/OpenSSL project.
|
|
=end
|
|
|
|
require 'net/protocol'
|
|
require 'forwardable'
|
|
require 'openssl'
|
|
|
|
module Net
|
|
class SSLIO < InternetMessageIO
|
|
extend Forwardable
|
|
|
|
def_delegators(:@ssl_context,
|
|
:key=, :cert=, :key_file=, :cert_file=,
|
|
:ca_file=, :ca_path=,
|
|
:verify_mode=, :verify_callback=, :verify_depth=,
|
|
:timeout=, :cert_store=)
|
|
|
|
def initialize(addr, port, otime = nil, rtime = nil, dout = nil)
|
|
super
|
|
@ssl_context = OpenSSL::SSL::SSLContext.new()
|
|
end
|
|
|
|
def ssl_connect()
|
|
unless @ssl_context.verify_mode
|
|
warn "warning: peer certificate won't be verified in this SSL session."
|
|
@ssl_context.verify_mode = OpenSSL::SSL::VERIFY_NONE
|
|
end
|
|
@socket = OpenSSL::SSL::SSLSocket.new(@socket, @ssl_context)
|
|
@socket.sync_close = true
|
|
@socket.connect
|
|
end
|
|
|
|
def peer_cert
|
|
@socket.peer_cert
|
|
end
|
|
end
|
|
end
|