Sha256: 870f53b70b38dff83f80980e4d54f9fdbdacda61076d547a2df8c3fed4f81226

Contents?: true

Size: 1.55 KB

Versions: 35

Compression:

Stored size: 1.55 KB

Contents

'use strict'
var inherits = require('inherits')
var Legacy = require('./legacy')
var Base = require('cipher-base')
var Buffer = require('safe-buffer').Buffer
var md5 = require('create-hash/md5')
var RIPEMD160 = require('ripemd160')

var sha = require('sha.js')

var ZEROS = Buffer.alloc(128)

function Hmac (alg, key) {
  Base.call(this, 'digest')
  if (typeof key === 'string') {
    key = Buffer.from(key)
  }

  var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64

  this._alg = alg
  this._key = key
  if (key.length > blocksize) {
    var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)
    key = hash.update(key).digest()
  } 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 = alg === 'rmd160' ? new RIPEMD160() : sha(alg)
  this._hash.update(ipad)
}

inherits(Hmac, Base)

Hmac.prototype._update = function (data) {
  this._hash.update(data)
}

Hmac.prototype._final = function () {
  var h = this._hash.digest()
  var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg)
  return hash.update(this._opad).update(h).digest()
}

module.exports = function createHmac (alg, key) {
  alg = alg.toLowerCase()
  if (alg === 'rmd160' || alg === 'ripemd160') {
    return new Hmac('rmd160', key)
  }
  if (alg === 'md5') {
    return new Legacy(md5, key)
  }
  return new Hmac(alg, key)
}

Version data entries

35 entries across 34 versions & 12 rubygems

Version Path
optimacms-0.1.61 spec/dummy/node_modules/create-hmac/browser.js
disco_app-0.18.0 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.18.2 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.16.1 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.15.2 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.18.4 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.18.1 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.12.7.pre.puma.pre.3 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.14.0 test/dummy/node_modules/create-hmac/browser.js
disco_app-0.13.6.pre.puma.pre.3 test/dummy/node_modules/create-hmac/browser.js
tang-0.2.1 spec/tang_app/node_modules/create-hmac/browser.js
groonga-client-model-6.0.0 test/apps/rails6.1.3/node_modules/create-hmac/browser.js
groonga-client-model-6.0.0 test/apps/rails6.0.3.5/node_modules/create-hmac/browser.js
ruby2js-4.0.4 lib/tasks/testrails/node_modules/create-hmac/browser.js
ruby2js-4.0.3 lib/tasks/testrails/node_modules/create-hmac/browser.js
tang-0.2.0 spec/tang_app/node_modules/create-hmac/browser.js
tang-0.1.0 spec/tang_app/node_modules/create-hmac/browser.js
tang-0.0.9 spec/tang_app/node_modules/create-hmac/browser.js
enju_library-0.3.8 spec/dummy/node_modules/create-hmac/browser.js
ilog-0.4.1 node_modules/create-hmac/browser.js