Sha256: 1d01fdda94bddd7e1a595a4304d316e1d033cbf637f7002a08c9e4d928df9f72

Contents?: true

Size: 1.7 KB

Versions: 8

Compression:

Stored size: 1.7 KB

Contents

require 'socket'
require 'openssl'
require 'net/ssh/proxy/errors'
require 'net/ssh/proxy/http'

module Net
  module SSH
    module Proxy
      # A specialization of the HTTP proxy which encrypts the whole connection
      # using OpenSSL. This has the advantage that proxy authentication
      # information is not sent in plaintext.
      class HTTPS < HTTP
        # Create a new socket factory that tunnels via the given host and
        # port. The +options+ parameter is a hash of additional settings that
        # can be used to tweak this proxy connection. In addition to the options
        # taken by Net::SSH::Proxy::HTTP it supports:
        #
        # * :ssl_context => the SSL configuration to use for the connection
        def initialize(proxy_host, proxy_port=80, options={})
          @ssl_context = options.delete(:ssl_context) ||
                           OpenSSL::SSL::SSLContext.new
          super(proxy_host, proxy_port, options)
        end

        protected

        # Shim to make OpenSSL::SSL::SSLSocket behave like a regular TCPSocket
        # for all intents and purposes of Net::SSH::BufferedIo
        module SSLSocketCompatibility
          def self.extended(object) #:nodoc:
            object.define_singleton_method(:recv, object.method(:sysread))
            object.sync_close = true
          end

          def send(data, _opts)
            syswrite(data)
          end
        end

        def establish_connection(connect_timeout)
          plain_socket = super(connect_timeout)
          OpenSSL::SSL::SSLSocket.new(plain_socket, @ssl_context).tap do |socket|
            socket.extend(SSLSocketCompatibility)
            socket.connect
          end
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 2 rubygems

Version Path
net-ssh-backports-6.3.6.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.5.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.4.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.3.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.2.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.1.backports lib/net/ssh/proxy/https.rb
net-ssh-backports-6.3.0.backports lib/net/ssh/proxy/https.rb
net-ssh-6.3.0.beta1 lib/net/ssh/proxy/https.rb