Spaces:
Runtime error
Runtime error
/** | |
* Module dependencies. | |
*/ | |
var crypto = require('crypto'); | |
/** | |
* Sign the given `val` with `secret`. | |
* | |
* @param {String} val | |
* @param {String} secret | |
* @return {String} | |
* @api private | |
*/ | |
exports.sign = function(val, secret){ | |
if ('string' != typeof val) throw new TypeError("Cookie value must be provided as a string."); | |
if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); | |
return val + '.' + crypto | |
.createHmac('sha256', secret) | |
.update(val) | |
.digest('base64') | |
.replace(/\=+$/, ''); | |
}; | |
/** | |
* Unsign and decode the given `val` with `secret`, | |
* returning `false` if the signature is invalid. | |
* | |
* @param {String} val | |
* @param {String} secret | |
* @return {String|Boolean} | |
* @api private | |
*/ | |
exports.unsign = function(val, secret){ | |
if ('string' != typeof val) throw new TypeError("Signed cookie string must be provided."); | |
if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); | |
var str = val.slice(0, val.lastIndexOf('.')) | |
, mac = exports.sign(str, secret); | |
return sha1(mac) == sha1(val) ? str : false; | |
}; | |
/** | |
* Private | |
*/ | |
function sha1(str){ | |
return crypto.createHash('sha1').update(str).digest('hex'); | |
} | |