12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class Certificate::X509 < OpenSSL::X509::Certificate
- attr_reader :fingerprint
- def initialize(cert)
- super(cert.gsub(%r{(?:TRUSTED\s)?(CERTIFICATE---)}, '\1'))
- @fingerprint = OpenSSL::Digest.new('SHA1', to_der).to_s
- end
- def extensions_as_hash
- extensions.each_with_object({}) do |ext, hash|
- hash[ext.oid] = ext.value.split(',').map(&:strip)
- end
- end
- def ca?
- extensions_as_hash.fetch('basicConstraints', '').include?('CA:TRUE')
- end
- def effective?
- Time.zone.now >= not_before
- end
- def expired?
- Time.zone.now > not_after
- end
- def usable?
- effective? && !expired?
- end
- def signature?
- extensions_as_hash.fetch('keyUsage', ['Digital Signature']).include?('Digital Signature')
- end
- def encryption?
- extensions_as_hash.fetch('keyUsage', ['Key Encipherment']).include?('Key Encipherment')
- end
- def key_match?(pem, secret)
- key = OpenSSL::PKey.read(pem, secret)
- key.compare?(public_key)
- end
- end
|