1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/ext/openssl/lib/net/protocols.rb
gotoyuzo fd71f860a1 * ext/openssl/lib/net/https.rb,protocols.rb,telnets.rb: delete
doc and code about SSLContext#{key_file,cert_file}.
  fixed: [ruby-dev:25243]


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7609 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2004-12-20 03:49:16 +00:00

55 lines
1.3 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=, :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