Skip to content

Commit

Permalink
pencilblue#1206 fixed issue where unauthorized access of a route that…
Browse files Browse the repository at this point in the history
… did not have a default "render" handler caused a failure after login
  • Loading branch information
brianhyder committed Jan 22, 2017
1 parent 8a2eca3 commit 4063666
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 4 deletions.
4 changes: 3 additions & 1 deletion include/error/formatters/error_formatters.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
'use strict';

//dependencies
var _ = require('lodash');
var path = require('path');
var HttpStatusCodes = require('http-status-codes');
var XmlErrorFormatter = require('./xml_error_formatter');
Expand Down Expand Up @@ -145,9 +146,10 @@ module.exports = function(pb) {
failedControllerPaths[paths[i]] = true;
}
}

params.request.controllerInstance = new ErrorController();
params.request.controllerInstance.error = params.error;
params.request.themeRoute = params.request.themeRoute || {};
params.request.themeRoute = !!params.request.themeRoute ? _.clone(params.request.themeRoute) : {};
params.request.routeTheme = params.request.routeTheme || {};
params.request.siteObj = params.request.siteObj || pb.SiteService.getGlobalSiteContext();
params.request.themeRoute.handler = 'render';
Expand Down
8 changes: 6 additions & 2 deletions include/http/request_handler.js
Original file line number Diff line number Diff line change
Expand Up @@ -485,8 +485,12 @@ module.exports = function RequestHandlerModule(pb) {
routeDescriptor.themes[site][theme] = {};
routeDescriptor.themes[site].size++;
}
routeDescriptor.themes[site][theme][descriptor.method] = descriptor;
routeDescriptor.themes[site][theme][descriptor.method].controller = Controller;

//set the controller then lock it down to prevent tampering
descriptor.controller = Controller;
routeDescriptor.themes[site][theme][descriptor.method] = Object.freeze(descriptor);



//only add the descriptor it is new. We do it here because we need to
//know that the controller is good.
Expand Down
7 changes: 6 additions & 1 deletion test/include/error/formatters/error_formatters_tests.js
Original file line number Diff line number Diff line change
Expand Up @@ -78,19 +78,24 @@ describe('ErrorFormatters', function() {
var error = new Error('hello world');
error.code = 510;

var themeRoute = Object.freeze({
handler: 'testHandler'
});
var params = {
error: error,
activeTheme: 'pencilblue',
request: {
router: {
continueAfter: function() {}
}
},
themeRoute: themeRoute
}
};
sinon.spy(params.request.router, 'continueAfter');
ErrorFormatters.html(params, function(err, result){});
(typeof params.request.controllerInstance).should.eql('object');
params.request.router.continueAfter.calledOnce.should.eql(true);
params.request.themeRoute.should.not.eql(themeRoute);
});
});

Expand Down

0 comments on commit 4063666

Please sign in to comment.