47 lines
		
	
	
		
			969 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			969 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict'
 | |
| var inherits = require('inherits')
 | |
| var Buffer = require('safe-buffer').Buffer
 | |
| 
 | |
| var Base = require('cipher-base')
 | |
| 
 | |
| var ZEROS = Buffer.alloc(128)
 | |
| var blocksize = 64
 | |
| 
 | |
| function Hmac (alg, key) {
 | |
|   Base.call(this, 'digest')
 | |
|   if (typeof key === 'string') {
 | |
|     key = Buffer.from(key)
 | |
|   }
 | |
| 
 | |
|   this._alg = alg
 | |
|   this._key = key
 | |
| 
 | |
|   if (key.length > blocksize) {
 | |
|     key = alg(key)
 | |
|   } else if (key.length < blocksize) {
 | |
|     key = Buffer.concat([key, ZEROS], blocksize)
 | |
|   }
 | |
| 
 | |
|   var ipad = this._ipad = Buffer.allocUnsafe(blocksize)
 | |
|   var opad = this._opad = Buffer.allocUnsafe(blocksize)
 | |
| 
 | |
|   for (var i = 0; i < blocksize; i++) {
 | |
|     ipad[i] = key[i] ^ 0x36
 | |
|     opad[i] = key[i] ^ 0x5C
 | |
|   }
 | |
| 
 | |
|   this._hash = [ipad]
 | |
| }
 | |
| 
 | |
| inherits(Hmac, Base)
 | |
| 
 | |
| Hmac.prototype._update = function (data) {
 | |
|   this._hash.push(data)
 | |
| }
 | |
| 
 | |
| Hmac.prototype._final = function () {
 | |
|   var h = this._alg(Buffer.concat(this._hash))
 | |
|   return this._alg(Buffer.concat([this._opad, h]))
 | |
| }
 | |
| module.exports = Hmac
 |