Module: Noise::Functions::Hash

Defined in:
lib/noise/functions/hash.rb,
lib/noise/functions/hash/sha256.rb,
lib/noise/functions/hash/sha512.rb,
lib/noise/functions/hash/blake2b.rb,
lib/noise/functions/hash/blake2s.rb

Defined Under Namespace

Classes: Blake2b, Blake2bHMAC, Blake2s, Blake2sDigester, Blake2sHMAC, Sha256, Sha512

Class Method Summary collapse

Class Method Details

.create_hkdf_fn(digest) ⇒ Object



21
22
23
24
25
# File 'lib/noise/functions/hash.rb', line 21

def self.create_hkdf_fn(digest)
  lambda do |chaining_key, input_key_material, num_output|
    hkdf(chaining_key, input_key_material, num_output, digest)
  end
end

.hkdf(chaining_key, input_key_material, num_outputs, digest) ⇒ Object



27
28
29
30
31
32
33
34
# File 'lib/noise/functions/hash.rb', line 27

def self.hkdf(chaining_key, input_key_material, num_outputs, digest)
  temp_key = hmac_hash(chaining_key, input_key_material, digest)
  output1 = hmac_hash(temp_key, "\x01", digest)
  output2 = hmac_hash(temp_key, output1 + "\x02", digest)
  return [output1, output2] if num_outputs == 2
  output3 = hmac_hash(temp_key, output2 + "\x03", digest)
  [output1, output2, output3]
end

.hmac_hash(key, data, digest) ⇒ Object



11
12
13
14
15
16
17
18
19
# File 'lib/noise/functions/hash.rb', line 11

def self.hmac_hash(key, data, digest)
  if digest.include?('SHA')
    OpenSSL::HMAC.digest(OpenSSL::Digest.new(digest), key, data)
  elsif digest.include?('BLAKE2b')
    Noise::Functions::Hash::Blake2bHMAC.new(key).update(data).digest
  elsif digest.include?('BLAKE2s')
    Noise::Functions::Hash::Blake2sHMAC.new(key).update(data).digest
  end
end