require 'puppet/network/http/connection'
require 'puppet/network/http/connection_adapter'
require 'puppet/util/platform'
module Puppet::Network; end
# This module contains the factory methods that should be used for getting a
# {Puppet::Network::HTTP::Connection} instance. The pool may return a new
# connection or a persistent cached connection, depending on the underlying
# pool implementation in use.
#
# @api public
#
module Puppet::Network::HttpPool
@http_client_class = Puppet::Network::HTTP::ConnectionAdapter
def self.http_client_class
@http_client_class
end
def self.http_client_class=(klass)
@http_client_class = klass
end
# Retrieve a connection for the given host and port.
#
# @param host [String] The hostname to connect to
# @param port [Integer] The port on the host to connect to
# @param use_ssl [Boolean] Whether to use an SSL connection
# @param verify_peer [Boolean] Whether to verify the peer credentials, if possible. Verification will not take place if the CA certificate is missing.
# @return [Puppet::Network::HTTP::Connection]
#
# @deprecated Use {#http_connection} instead.
# @api public
#
def self.http_instance(host, port, use_ssl = true, verify_peer = true)
verifier = if verify_peer
Puppet::SSL::Validator.default_validator()
else
Puppet::SSL::Validator.no_validator()
end
http_client_class.new(host, port,
:use_ssl => use_ssl,
:verify => verifier)
end
# Get an http connection that will be secured with SSL and have the
# connection verified with the given verifier
#
# @param host [String] the DNS name to connect to
# @param port [Integer] the port to connect to
# @param verifier [#setup_connection, #peer_certs, #verify_errors] An object that will setup the appropriate
# verification on a Net::HTTP instance and report any errors and the certificates used.
# @return [Puppet::Network::HTTP::Connection]
#
# @deprecated Use {#http_connection} instead.
# @api public
#
def self.http_ssl_instance(host, port, verifier = Puppet::SSL::Validator.default_validator())
http_client_class.new(host, port,
:use_ssl => true,
:verify => verifier)
end
# Retrieve a connection for the given host and port.
#
# @param host [String] The host to connect to
# @param port [Integer] The port to connect to
# @param use_ssl [Boolean] Whether to use SSL, defaults to `true`.
# @param ssl_context [Puppet::SSL:SSLContext, nil] The ssl context to use
# when making HTTPS connections. Required when `use_ssl` is `true`.
# @return [Puppet::Network::HTTP::Connection]
#
# @api public
#
def self.connection(host, port, use_ssl: true, ssl_context: nil)
if use_ssl
unless ssl_context
# TRANSLATORS 'ssl_context' is an argument and should not be translated
raise ArgumentError, _("An ssl_context is required when connecting to 'https://%{host}:%{port}'") % { host: host, port: port }
end
verifier = Puppet::SSL::Verifier.new(host, ssl_context)
http_client_class.new(host, port, use_ssl: true, verifier: verifier)
else
if ssl_context
# TRANSLATORS 'ssl_context' is an argument and should not be translated
Puppet.warning(_("An ssl_context is unnecessary when connecting to 'http://%{host}:%{port}' and will be ignored") % { host: host, port: port })
end
http_client_class.new(host, port, use_ssl: false)
end
end
end
Anons79 File Manager Version 1.0, Coded By Anons79
Email: [email protected]