Sha256: 384b3dc03af62808971a992e0a7286c772aedcace949984df31fd9c4584521af

Contents?: true

Size: 1.13 KB

Versions: 8

Compression:

Stored size: 1.13 KB

Contents

var hmac = exports;

var hash = require('../hash');
var utils = hash.utils;
var assert = utils.assert;

function Hmac(hash, key, enc) {
  if (!(this instanceof Hmac))
    return new Hmac(hash, key, enc);
  this.Hash = hash;
  this.blockSize = hash.blockSize / 8;
  this.outSize = hash.outSize / 8;
  this.inner = null;
  this.outer = null;

  this._init(utils.toArray(key, enc));
}
module.exports = Hmac;

Hmac.prototype._init = function init(key) {
  // Shorten key, if needed
  if (key.length > this.blockSize)
    key = new this.Hash().update(key).digest();
  assert(key.length <= this.blockSize);

  // Add padding to key
  for (var i = key.length; i < this.blockSize; i++)
    key.push(0);

  for (var i = 0; i < key.length; i++)
    key[i] ^= 0x36;
  this.inner = new this.Hash().update(key);

  // 0x36 ^ 0x5c = 0x6a
  for (var i = 0; i < key.length; i++)
    key[i] ^= 0x6a;
  this.outer = new this.Hash().update(key);
};

Hmac.prototype.update = function update(msg, enc) {
  this.inner.update(msg, enc);
  return this;
};

Hmac.prototype.digest = function digest(enc) {
  this.outer.update(this.inner.digest());
  return this.outer.digest(enc);
};

Version data entries

8 entries across 8 versions & 3 rubygems

Version Path
lanes-0.8.0 node_modules/hash.js/lib/hash/hmac.js
minimum_viable_product-0.0.11 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.6 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.5 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.4 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.3 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.2 test/dummy/node_modules/hash.js/lib/hash/hmac.js
brwy_rails-0.0.1 test/dummy/node_modules/hash.js/lib/hash/hmac.js