Returns 404 page instead of crashing a server whenever special characters are used for tag filtering

closes #5808
refs #5816
- adds additional filtering any 'slug' containing content in `renderChannel` for frontend
- adds test for invalid characters in tag slug
This commit is contained in:
Nazar Gargol 2015-09-10 19:16:16 +02:00
parent ed7bfe8f4a
commit fd7e118ed5
2 changed files with 11 additions and 2 deletions

View File

@ -14,6 +14,7 @@ var _ = require('lodash'),
Promise = require('bluebird'),
template = require('../helpers/template'),
routeMatch = require('path-match')(),
safeString = require('../utils/index').safeString,
frontendControllers,
staticPostPermalink = routeMatch('/:slug/:edit?');
@ -160,8 +161,8 @@ function renderChannel(channelOpts) {
filter, filterKey;
// Add the slug if it exists in the route
if (channelOpts.route.indexOf(':slug') !== -1) {
options[channelOpts.name] = req.params.slug;
if (channelOpts.route.indexOf(':slug') !== -1 && req.params.slug) {
options[channelOpts.name] = safeString(req.params.slug);
hasSlug = true;
}

View File

@ -79,6 +79,14 @@ describe('Frontend Routing', function () {
.end(doEnd(done));
});
it('should 404 for unknown tag with invalid characters', function (done) {
request.get('/tag/~$pectacular~/')
.expect('Cache-Control', testUtils.cacheRules['private'])
.expect(404)
.expect(/Page not found/)
.end(doEnd(done));
});
it('should 404 for unknown author', function (done) {
request.get('/author/spectacular/')
.expect('Cache-Control', testUtils.cacheRules['private'])