Sha256: 2654cb766ec3c532ef756e1171be2db5850951f53f3175f766f6dd7238ca85d6

Contents?: true

Size: 1.16 KB

Versions: 5

Compression:

Stored size: 1.16 KB

Contents

# frozen_string_literal: true

require "openssl"
require "openssl/signature_algorithm/error"

module OpenSSL
  module SignatureAlgorithm
    class SignatureVerificationError < Error; end
    class UnsupportedParameterError < Error; end
    class VerifyKeyError < Error; end

    class Base
      attr_reader :signing_key, :verify_key

      def verify_key=(key)
        if compatible_verify_key?(key)
          @verify_key = key
        else
          raise(OpenSSL::SignatureAlgorithm::VerifyKeyError, "Incompatible verify key for algorithm")
        end
      end

      def compatible_verify_key?(verify_key)
        verify_key.respond_to?(:verify)
      end

      def sign(data)
        signing_key.sign(hash_function, data)
      end

      def verify(signature, verification_data)
        formatted_signature =
          if respond_to?(:formatted_signature, true)
            formatted_signature(signature)
          else
            signature
          end

        verify_key.verify(hash_function, formatted_signature, verification_data) ||
          raise(OpenSSL::SignatureAlgorithm::SignatureVerificationError, "Signature verification failed")
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
openssl-signature_algorithm-1.3.0 lib/openssl/signature_algorithm/base.rb
openssl-signature_algorithm-1.2.1 lib/openssl/signature_algorithm/base.rb
openssl-signature_algorithm-1.1.1 lib/openssl/signature_algorithm/base.rb
openssl-signature_algorithm-1.1.0 lib/openssl/signature_algorithm/base.rb
openssl-signature_algorithm-1.0.0 lib/openssl/signature_algorithm/base.rb