Class: HMAC::Base

Inherits:
Object
  • Object
show all
Defined in:
lib/hmac.rb

Direct Known Subclasses

MD5, RMD160, SHA1, SHA256, SHA384, SHA512

Instance Method Summary collapse

Constructor Details

#initialize(algorithm, block_size, output_length, key) ⇒ Base

Returns a new instance of Base.



23
24
25
26
27
28
29
30
31
# File 'lib/hmac.rb', line 23

def initialize(algorithm, block_size, output_length, key)
  @algorithm = algorithm
  @block_size = block_size
  @output_length = output_length
  @initialized = false
  @key_xor_ipad = ''
  @key_xor_opad = ''
  set_key(key) unless key.nil?
end

Instance Method Details

#digestObject



81
82
83
84
# File 'lib/hmac.rb', line 81

def digest
  check_status
  @md.digest
end

#hexdigestObject



86
87
88
89
# File 'lib/hmac.rb', line 86

def hexdigest
  check_status
  @md.hexdigest
end

#reset_keyObject



58
59
60
61
62
63
64
# File 'lib/hmac.rb', line 58

def reset_key
  @key_xor_ipad.gsub!(/./, '?')
  @key_xor_opad.gsub!(/./, '?')
  @key_xor_ipad[0..-1] = ''
  @key_xor_opad[0..-1] = ''
  @initialized = false
end

#set_key(key) ⇒ Object



42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/hmac.rb', line 42

def set_key(key)
  # If key is longer than the block size, apply hash function
  # to key and use the result as a real key.
  key = @algorithm.digest(key) if key.size > @block_size
  key_xor_ipad = "\x36" * @block_size
  key_xor_opad = "\x5C" * @block_size
  for i in 0 .. key.size - 1
    key_xor_ipad[i] ^= key[i]
    key_xor_opad[i] ^= key[i]
  end
  @key_xor_ipad = key_xor_ipad
  @key_xor_opad = key_xor_opad
  @md = @algorithm.new
  @initialized = true
end

#to_sObject



90
91
92
93
# File 'lib/hmac.rb', line 90

def hexdigest
  check_status
  @md.hexdigest
end

#update(text) ⇒ Object Also known as: <<



66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'lib/hmac.rb', line 66

def update(text)
  check_status
  # perform inner H
  md = @algorithm.new
  md.update(@key_xor_ipad)
  md.update(text)
  str = md.digest
  # perform outer H
  md = @algorithm.new
  md.update(@key_xor_opad)
  md.update(str)
  @md = md
end