Sha256: f41e8a1d7ca7317c98f83942ede26e5cedae7d7299c8a101fee3f546ac7a1631
Contents?: true
Size: 1.39 KB
Versions: 5
Compression:
Stored size: 1.39 KB
Contents
require 'digest' module SPARQL; module Algebra class Operator ## # The SPARQL logical `sha1` operator. # # Returns the SHA1 checksum, as a hex digit string, calculated on the UTF-8 representation of the simple literal or lexical form of the `xsd:string`. Hex digits `SHOULD` be in lower case. # # @example # (prefix ((: <http://example.org/>)) # (project (?hash) # (extend ((?hash (sha1 ?l))) # (bgp (triple :s1 :str ?l))))) # # @see https://www.w3.org/TR/sparql11-query/#func-sha1 class SHA1 < Operator::Unary include Evaluatable NAME = :sha1 ## # Returns the SHA1 checksum, as a hex digit string, calculated on the UTF-8 representation of the simple literal or lexical form of the xsd:string. Hex digits should be in lower case. # # @param [RDF::Literal] operand # the operand # @return [RDF::Literal] # @raise [TypeError] if the operand is not a simple literal def apply(operand) raise TypeError, "expected an RDF::Literal, but got #{operand.inspect}" unless operand.literal? raise TypeError, "expected simple literal or xsd:string, but got #{operand.inspect}" unless (operand.datatype || RDF::XSD.string) == RDF::XSD.string RDF::Literal(Digest::SHA1.new.hexdigest(operand.to_s)) end end # SHA1 end # Operator end; end # SPARQL::Algebra
Version data entries
5 entries across 5 versions & 1 rubygems