etherpad-lite/src/node/hooks/express/padurlsanitize.js

30 lines
1.1 KiB
JavaScript
Raw Normal View History

2020-11-23 13:24:19 -05:00
const padManager = require('../../db/PadManager');
const url = require('url');
2012-02-25 16:53:15 +01:00
exports.expressCreateServer = function (hook_name, args, cb) {
// redirects browser to the pad's sanitized url if needed. otherwise, renders the html
2020-11-23 13:24:19 -05:00
args.app.param('pad', async (req, res, next, padId) => {
// ensure the padname is valid and the url doesn't end with a /
if (!padManager.isValidPadId(padId) || /\/$/.test(req.url)) {
res.status(404).send('Such a padname is forbidden');
return;
}
2020-11-23 13:24:19 -05:00
const sanitizedPadId = await padManager.sanitizePadId(padId);
if (sanitizedPadId === padId) {
// the pad id was fine, so just render it
next();
} else {
// the pad id was sanitized, so we redirect to the sanitized version
2020-11-23 13:24:19 -05:00
let real_url = sanitizedPadId;
real_url = encodeURIComponent(real_url);
2020-11-23 13:24:19 -05:00
const query = url.parse(req.url).query;
if (query) real_url += `?${query}`;
res.header('Location', real_url);
2020-11-23 13:24:19 -05:00
res.status(302).send(`You should be redirected to <a href="${real_url}">${real_url}</a>`);
}
});
return cb();
2020-11-23 13:24:19 -05:00
};