http: path parsing.

This commit is contained in:
Christopher Jeffrey 2017-01-12 12:40:31 -08:00
parent 72f6a1d239
commit 9e0b10f314
No known key found for this signature in database
GPG Key ID: 8962AB9DE6666BBD

View File

@ -114,9 +114,13 @@ HTTPBase.prototype._initRouter = function _initRouter() {
*/
HTTPBase.prototype.handleRequest = co(function* handleRequest(req, res) {
var url = initRequest(req, res, this.keyLimit);
var i, routes, route, params;
initRequest(req, res, this.keyLimit);
if (url.trailingSlash) {
res.redirect(302, req.url);
return;
}
this.emit('request', req, res);
@ -587,6 +591,8 @@ Routes.prototype.getHandlers = function getHandlers(method) {
function nop() {}
function initRequest(req, res, limit) {
var url;
req.on('error', nop);
assert(req.contentType == null);
@ -618,12 +624,21 @@ function initRequest(req, res, limit) {
assert(res.sent == null);
assert(res.send == null);
assert(res.error == null);
assert(res.redirect == null);
res.sent = false;
res.send = makeSend(res);
res.error = makeSendError(req, res);
res.redirect = makeRedirect(res);
parsePath(req, limit);
url = parseURL(req.url, limit);
req.url = url.url;
req.pathname = url.pathname;
req.path = url.path;
req.query = url.query;
return url;
}
function makeSend(res) {
@ -714,6 +729,18 @@ function sendError(req, res, err) {
}
}
function makeRedirect(res) {
return function redirect(code, url) {
if (!url) {
url = code;
code = 302;
}
res.statusCode = code;
res.setHeader('Location', url);
res.end();
};
}
function parsePairs(str, limit) {
var parts = str.split('&');
var data = Object.create(null);
@ -749,10 +776,12 @@ function parsePairs(str, limit) {
return data;
}
function parsePath(req, limit) {
var uri = URL.parse(req.url);
function parseURL(reqUrl, limit) {
var uri = URL.parse(reqUrl);
var parsed = new ParsedURL(reqUrl);
var pathname = uri.pathname;
var query = Object.create(null);
var trailing = false;
var path, parts, url;
if (pathname) {
@ -762,8 +791,10 @@ function parsePath(req, limit) {
pathname = '/' + pathname;
if (pathname.length > 1) {
if (pathname[pathname.length - 1] === '/')
if (pathname[pathname.length - 1] === '/') {
pathname = pathname.slice(0, -1);
trailing = true;
}
}
pathname = unescape(pathname);
@ -804,10 +835,22 @@ function parsePath(req, limit) {
if (uri.query)
query = parsePairs(uri.query, limit);
req.url = url;
req.pathname = pathname;
req.path = parts;
req.query = query;
parsed.url = url;
parsed.pathname = pathname;
parsed.path = path;
parsed.query = query;
parsed.trailingSlash = trailing;
return parsed;
}
function ParsedURL(original) {
this.original = original;
this.url = null;
this.pathname = null;
this.path = null;
this.query = null;
this.trailingSlash = false;
}
function unescape(str) {