Sha256: 4758e0d91bd57525aff5ab37949b8e8f01031d0ee84c4580402e93b391027a89

Contents?: true

Size: 1.93 KB

Versions: 5

Compression:

Stored size: 1.93 KB

Contents

module Xmldsig
  class Reference
    attr_accessor :reference, :errors

    class ReferencedNodeNotFound < Exception;
    end

    def initialize(reference)
      @reference = reference
      @errors    = []
    end

    def document
      reference.document
    end

    def sign
      self.digest_value = calculate_digest_value
    end

    def referenced_node
      if reference_uri && reference_uri != ""
        id = reference_uri[1..-1]
        if ref = document.dup.at_xpath("//*[@ID='#{id}' or @wsu:Id='#{id}']", NAMESPACES)
          ref
        else
          raise(
              ReferencedNodeNotFound,
              "Could not find the referenced node #{id}'"
          )
        end
      else
        document.dup.root
      end
    end

    def reference_uri
      reference.get_attribute("URI")
    end

    def digest_value
      Base64.decode64 reference.at_xpath("descendant::ds:DigestValue", NAMESPACES).content
    end

    def calculate_digest_value
      transformed = transforms.apply(referenced_node)
      case transformed
        when String
          digest_method.digest transformed
        when Nokogiri::XML::Node
          digest_method.digest Canonicalizer.new(transformed).canonicalize
      end
    end

    def digest_method
      algorithm = reference.at_xpath("descendant::ds:DigestMethod", NAMESPACES).get_attribute("Algorithm")
      case algorithm
        when "http://www.w3.org/2001/04/xmlenc#sha256"
          Digest::SHA2
        when "http://www.w3.org/2000/09/xmldsig#sha1"
          Digest::SHA1
      end
    end

    def digest_value=(digest_value)
      reference.at_xpath("descendant::ds:DigestValue", NAMESPACES).content =
          Base64.encode64(digest_value).chomp
    end

    def transforms
      Transforms.new(reference.xpath("descendant::ds:Transform", NAMESPACES))
    end

    def validate_digest_value
      unless digest_value == calculate_digest_value
        @errors << :digest_value
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
xmldsig-0.2.6 lib/xmldsig/reference.rb
xmldsig-0.2.5 lib/xmldsig/reference.rb
xmldsig-0.2.4 lib/xmldsig/reference.rb
xmldsig-0.2.3 lib/xmldsig/reference.rb
xmldsig-0.2.2 lib/xmldsig/reference.rb