Class: SPARQL::Algebra::Operator::SHA256
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/sha256.rb
Overview
The SPARQL logical sha256 operator.
Returns the SHA256 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.
[121] BuiltInCall ::= ... | 'SHA256' '(' Expression ')'
Constant Summary collapse
- NAME =
:sha256
Instance Method Summary collapse
-
#apply(operand, **options) ⇒ RDF::Literal
Returns the SHA256 checksum, as a hex digit string, calculated on the UTF-8 representation of the simple literal or lexical form of the xsd:string.
-
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Evaluatable
#evaluate, #memoize, #replace_aggregate!, #replace_vars!
Instance Method Details
#apply(operand, **options) ⇒ RDF::Literal
Returns the SHA256 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.
37 38 39 40 41 |
# File 'lib/sparql/algebra/operator/sha256.rb', line 37 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::SHA256.new.hexdigest(operand.to_s)) end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
48 49 50 |
# File 'lib/sparql/algebra/operator/sha256.rb', line 48 def to_sparql(**) "SHA256(" + operands.to_sparql(**) + ")" end |