Sha256: c4e9c1eac97fdf45de9e62446d1a5e7d6c5d3c3021929e1430fe5b12b226aa75
Contents?: true
Size: 1001 Bytes
Versions: 3
Compression:
Stored size: 1001 Bytes
Contents
require 'openssl' module Berkshelf class SSLPolicy # @return [Store] # Holds trusted CA certificates used to verify peer certificates attr_reader :store def initialize @store = OpenSSL::X509::Store.new.tap do |store| store.set_default_paths end set_custom_certs if ::File.exist?(trusted_certs_dir) end def add_trusted_cert(cert) @store.add_cert(cert) rescue OpenSSL::X509::StoreError => e raise e unless e.message == 'cert already in hash table' end def trusted_certs_dir config_dir = Berkshelf.config.chef.trusted_certs_dir.to_s if config_dir.empty? || !::File.exist?(config_dir) File.join(ENV['HOME'], '.chef', 'trusted_certs') else config_dir end end def set_custom_certs ::Dir.glob("#{trusted_certs_dir}/" "{*.crt,*.pem}").each do |cert| cert = OpenSSL::X509::Certificate.new(IO.read(cert)) add_trusted_cert(cert) end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
berkshelf-5.5.0 | lib/berkshelf/ssl_policies.rb |
berkshelf-5.4.0 | lib/berkshelf/ssl_policies.rb |
berkshelf-5.3.0 | lib/berkshelf/ssl_policies.rb |