var ERR = require('async-stacktrace'); module.exports = function(app) { //redirects browser to the pad's sanitized url if needed. otherwise, renders the html app.param('pad', function (req, res, next, padId) { //ensure the padname is valid and the url doesn't end with a / if(!app.padManager.isValidPadId(padId) || /\/$/.test(req.url)) { res.send('Such a padname is forbidden', 404); } else { app.padManager.sanitizePadId(padId, function(sanitizedPadId) { //the pad id was sanitized, so we redirect to the sanitized version if(sanitizedPadId != padId) { var real_path = req.path.replace(/^\/p\/[^\/]+/, '/p/' + sanitizedPadId); res.header('Location', real_path); res.send('You should be redirected to ' + real_path + '', 302); } //the pad id was fine, so just render it else { next(); } }); } }); }; module.exports.hasPadAccess = function(app) { //checks for padAccess var hasPadAccess = function hasPadAccess(req, res, callback) { app.securityManager.checkAccess(req.params.pad, req.cookies.sessionid, req.cookies.token, req.cookies.password, function(err, accessObj) { if(ERR(err, callback)) return; //there is access, continue if(accessObj.accessStatus == "grant") { callback(); } //no access else { res.send("403 - Can't touch this", 403); } }); }; return hasPadAccess; };