Sha256: 6c16df92486ce0a9f3581b9eb09ff8496ccc0de01fdffdab1d549de31ee7f801

Contents?: true

Size: 874 Bytes

Versions: 5

Compression:

Stored size: 874 Bytes

Contents

module SSLCheck
  module Validators
    class CommonName < GenericValidator
      def validate
        return nil if common_name_matches?
        SSLCheck::Errors::Validation::CommonNameMismatch.new({:name => "Common Name Mismatch", :message => "This certificate is not valid for #{@common_name}."})
      end

    private
      def common_name_matches?
        matching_wildcard_domain || alternate_common_name_match || direct_common_name_match
      end

      def matching_wildcard_domain
        true if (@peer_cert.common_name.match(/\*\./) && @common_name.include?(@peer_cert.common_name.gsub(/\*\./,'')))
      end

      def direct_common_name_match
        @peer_cert.common_name.downcase == @common_name.downcase
      end

      def alternate_common_name_match
        @peer_cert.alternate_common_names.include?(@common_name.downcase)
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
sslcheck-0.9.4 lib/sslcheck/validators/common_name.rb
sslcheck-0.9.3 lib/sslcheck/validators/common_name.rb
sslcheck-0.9.2 lib/sslcheck/validators/common_name.rb
sslcheck-0.9.1 lib/sslcheck/validators/common_name.rb
sslcheck-0.9.0 lib/sslcheck/validators/common_name.rb