# frozen_string_literal: true
#
# ronin-recon - A micro-framework and tool for performing reconnaissance.
#
# Copyright (c) 2023-2024 Hal Brodigan (postmodern.mod3@gmail.com)
#
# ronin-recon is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# ronin-recon is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with ronin-recon. If not, see .
#
require 'ronin/recon/value'
require 'ronin/support/crypto'
module Ronin
module Recon
module Values
#
# Represents a SSL/TLS certificate.
#
class Cert < Value
# The certificate object.
#
# @return [Ronin::Support::Crypto::Cert]
#
# @api private
attr_reader :cert
#
# Initializes the certificate value.
#
# @param [OpenSSL::X509::Certificate] cert
# The decoded X509 certificate.
#
def initialize(cert)
@cert = Support::Crypto::Cert(cert)
end
#
# The serial number of the SSL/TLS certificate.
#
# @return [OpenSSL::BN]
#
def serial
@cert.serial
end
#
# When the certificate begins being valid.
#
# @return [Time]
#
def not_before
@cert.not_before
end
#
# When the certificate expires.
#
# @return [Time]
#
def not_after
@cert.not_after
end
#
# The certificate issuer's information.
#
# @return [OpenSSL::X509::Name]
#
def issuer
@cert.issuer
end
#
# The certificate subject's information.
#
# @return [OpenSSL::X509::Name]
#
def subject
@cert.subject
end
#
# Additional certificate extensions.
#
# @return [Array]
#
def extensions
@cert.extensions
end
#
# Compares the certificate to another value.
#
# @param [Object] other
#
# @return [Boolean]
#
def eql?(other)
self.class == other.class && serial == other.serial
end
#
# The "hash" value of the certificate.
#
# @return [Integer]
#
def hash
[self.class, @cert.serial].hash
end
#
# Converts the certificate to a string.
#
# @return [String]
#
def to_s
@cert.to_s
end
#
# Converts the certificate to a hash of attributes
#
# @return [Hash{Symbol => Object}]
#
def as_json
{
serial: @cert.serial,
not_before: @cert.not_before,
not_after: @cert.not_after,
subject: @cert.subject.to_h,
issuer: @cert.issuer.to_h,
extensions: @cert.extensions_hash,
subject_alt_names: @cert.subject_alt_names,
pem: @cert.to_pem
}
end
#
# Returns the type or kind of recon value.
#
# @return [:cert]
#
# @note
# This is used internally to map a recon value class to a printable
# type.
#
# @api private
#
def self.value_type
:cert
end
end
end
end
end