|
@ -3,7 +3,7 @@ var bignum = require('bignum'); |
|
|
var Binary = require('binary'); |
|
|
var Binary = require('binary'); |
|
|
var Put = require('bufferput'); |
|
|
var Put = require('bufferput'); |
|
|
var buffertools = require('buffertools'); |
|
|
var buffertools = require('buffertools'); |
|
|
var jssha = require('jssha'); |
|
|
var sjcl = require('sjcl'); |
|
|
var browser; |
|
|
var browser; |
|
|
var inBrowser = !process.versions; |
|
|
var inBrowser = !process.versions; |
|
|
if (inBrowser) { |
|
|
if (inBrowser) { |
|
@ -16,19 +16,25 @@ var sha256 = exports.sha256 = function(data) { |
|
|
|
|
|
|
|
|
var sha512 = exports.sha512 = function(data) { |
|
|
var sha512 = exports.sha512 = function(data) { |
|
|
if (inBrowser) { |
|
|
if (inBrowser) { |
|
|
var j = new jssha(data.toString('hex'), 'HEX'); |
|
|
var datahex = data.toString('hex'); |
|
|
var hashhex = j.getHash('SHA-512', 'HEX'); |
|
|
var databits = sjcl.codec.hex.toBits(datahex); |
|
|
return new Buffer(hashhex, 'hex'); |
|
|
var hashbits = sjcl.hash.sha512.hash(databits); |
|
|
|
|
|
var hashhex = sjcl.codec.hex.fromBits(hashbits); |
|
|
|
|
|
var hash = new Buffer(hashhex, 'hex'); |
|
|
|
|
|
return hash; |
|
|
}; |
|
|
}; |
|
|
return new Buffer(crypto.createHash('sha512').update(data).digest('binary'), 'binary'); |
|
|
return new Buffer(crypto.createHash('sha512').update(data).digest('binary'), 'binary'); |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
var sha512hmac = exports.sha512hmac = function (data, key) { |
|
|
var sha512hmac = exports.sha512hmac = function (data, key) { |
|
|
if (inBrowser) { |
|
|
if (inBrowser) { |
|
|
var j = new jssha(data.toString('hex'), 'HEX'); |
|
|
var skey = sjcl.codec.hex.toBits(key.toString('hex')); |
|
|
var hash = j.getHMAC(key.toString('hex'), "HEX", "SHA-512", "HEX"); |
|
|
var sdata = sjcl.codec.hex.toBits(data.toString('hex')); |
|
|
hash = new Buffer(hash, 'hex'); |
|
|
var hmac = new sjcl.misc.hmac(skey, sjcl.hash.sha512); |
|
|
return hash; |
|
|
var encrypted = hmac.encrypt(sdata); |
|
|
|
|
|
var enchex = sjcl.codec.hex.fromBits(encrypted); |
|
|
|
|
|
var encbuf = new Buffer(enchex, 'hex'); |
|
|
|
|
|
return encbuf; |
|
|
}; |
|
|
}; |
|
|
var hmac = crypto.createHmac('sha512', key); |
|
|
var hmac = crypto.createHmac('sha512', key); |
|
|
var hash = hmac.update(data).digest(); |
|
|
var hash = hmac.update(data).digest(); |
|
|