Sha256: c1bb24e8d13d095e159f5cced78168090305fa0e1dcb73d29ceb0de7661f61fd

Contents?: true

Size: 850 Bytes

Versions: 9

Compression:

Stored size: 850 Bytes

Contents

# frozen_string_literal: true

require "cbor"
require "cose/security_message"
require "openssl"

module COSE
  class Mac0 < SecurityMessage
    CONTEXT = "MAC0"

    attr_reader :payload, :tag

    def self.keyword_arguments_for_initialize(decoded)
      { payload: decoded[0], tag: decoded[1] }
    end

    def self.tag
      17
    end

    def initialize(payload:, tag:, **keyword_arguments)
      super(**keyword_arguments)

      @payload = payload
      @tag = tag
    end

    def verify(key, external_aad = nil)
      tag == algorithm.mac(key.k, data(external_aad)) || raise(COSE::Error, "Mac0 verification failed")
    end

    private

    def data(external_aad = nil)
      CBOR.encode([context, serialized_map(protected_headers), external_aad || zero_length_bin_string, payload])
    end

    def context
      CONTEXT
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
cose-1.3.1 lib/cose/mac0.rb
cose-1.3.0 lib/cose/mac0.rb
cose-1.2.1 lib/cose/mac0.rb
cose-1.2.0 lib/cose/mac0.rb
cose-1.1.0 lib/cose/mac0.rb
cose-1.0.0 lib/cose/mac0.rb
cose-0.11.0 lib/cose/mac0.rb
cose-0.10.0 lib/cose/mac0.rb
cose-0.9.0 lib/cose/mac0.rb