Module: Puppet::Network::HttpPool
- Defined in:
- lib/puppet/network/http_pool.rb
Class Method Summary collapse
-
.cert_setup(http) ⇒ Object
Use cert information from a Puppet client to set up the http object.
-
.http_instance(host, port, reset = false) ⇒ Object
Retrieve a cached http instance if caching is enabled, else return a new one.
-
.ssl_host ⇒ Object
Use the global localhost instance.
Class Method Details
.cert_setup(http) ⇒ Object
Use cert information from a Puppet client to set up the http object.
13 14 15 16 17 18 19 20 21 22 |
# File 'lib/puppet/network/http_pool.rb', line 13 def self.cert_setup(http) # Just no-op if we don't have certs. return false unless FileTest.exist?(Puppet[:hostcert]) and FileTest.exist?(Puppet[:localcacert]) http.cert_store = ssl_host.ssl_store http.ca_file = Puppet[:localcacert] http.cert = ssl_host.certificate.content http.verify_mode = OpenSSL::SSL::VERIFY_PEER http.key = ssl_host.key.content end |
.http_instance(host, port, reset = false) ⇒ Object
Retrieve a cached http instance if caching is enabled, else return a new one.
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/puppet/network/http_pool.rb', line 26 def self.http_instance(host, port, reset = false) args = [host, port] if Puppet[:http_proxy_host] == "none" args << nil << nil else args << Puppet[:http_proxy_host] << Puppet[:http_proxy_port] end http = Net::HTTP.new(*args) # Pop open the http client a little; older versions of Net::HTTP(s) didn't # give us a reader for ca_file... Grr... class << http; attr_accessor :ca_file; end http.use_ssl = true # Use configured timeout (#1176) http.read_timeout = Puppet[:configtimeout] http.open_timeout = Puppet[:configtimeout] cert_setup(http) http end |