Spaces:
Running
Running
| /** | |
| * 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'); | |
| } | |