Sha256: 0da7b04fba5fa98b83ebe6c6c8811cca7c383d5e648d76ab3d8caafc9d12ec51
Contents?: true
Size: 1.37 KB
Versions: 1
Compression:
Stored size: 1.37 KB
Contents
# encoding: binary module RbNaCl module HMAC # Computes an authenticator as HMAC-SHA-512 # # The authenticator can be used at a later time to verify the provenance of # the message by recomputing the HMAC over the message and then comparing it to # the provided authenticator. The class provides methods for generating # signatures and also has a constant-time implementation for checking them. # # This is a secret key authenticator, i.e. anyone who can verify signatures # can also create them. # # @see http://nacl.cr.yp.to/auth.html class SHA512 < Auth extend Sodium sodium_type :auth sodium_primitive :hmacsha512 sodium_constant :BYTES sodium_constant :KEYBYTES sodium_function :auth_hmacsha512, :crypto_auth_hmacsha512, [:pointer, :pointer, :ulong_long, :pointer] sodium_function :auth_hmacsha512_verify, :crypto_auth_hmacsha512_verify, [:pointer, :pointer, :ulong_long, :pointer] private def compute_authenticator(authenticator, message) self.class.auth_hmacsha512(authenticator, message, message.bytesize, key) end def verify_message(authenticator, message) self.class.auth_hmacsha512_verify(authenticator, message, message.bytesize, key) end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rbnacl-3.4.0 | lib/rbnacl/hmac/sha512.rb |