From 5f84c80fc580bdd64b0f2f67a92a840965148e40 Mon Sep 17 00:00:00 2001 From: nahi Date: Thu, 4 Sep 2003 10:31:29 +0000 Subject: * sample/openssl: added. Sample of standard distribution library should be locate in sample/{module_name}/*. * ext/openssl/sample/*: removed. move to sample/openssl/*. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4492 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- sample/openssl/wget.rb | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 sample/openssl/wget.rb (limited to 'sample/openssl/wget.rb') diff --git a/sample/openssl/wget.rb b/sample/openssl/wget.rb new file mode 100644 index 0000000000..0362ab980d --- /dev/null +++ b/sample/openssl/wget.rb @@ -0,0 +1,33 @@ +#!/usr/bin/env ruby + +require 'net/https' +require 'getopts' + +getopts nil, 'C:' + +ca_path = $OPT_C + +uri = URI.parse(ARGV[0]) +if proxy = ENV['HTTP_PROXY'] + prx_uri = URI.parse(proxy) + prx_host = prx_uri.host + prx_port = prx_uri.port +end + +h = Net::HTTP.new(uri.host, uri.port, prx_host, prx_port) +h.set_debug_output($stderr) if $DEBUG +if uri.scheme == "https" + h.use_ssl = true + if ca_path + h.verify_mode = OpenSSL::SSL::VERIFY_PEER + h.ca_path = ca_path + else + $stderr.puts "!!! WARNING: PEER CERTIFICATE WON'T BE VERIFIED !!!" + end +end + +path = uri.path.empty? ? "/" : uri.path +h.get2(path){|resp| + STDERR.puts h.peer_cert.inspect if h.peer_cert + print resp.body +} -- cgit v1.2.3