mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
net.httpserver: Fix HTTP after commit c299726d2b4e and add a 500 error response if a request handler fails to make a response to the client
This commit is contained in:
parent
aded42ab97
commit
e3d06ad370
1 changed files with 13 additions and 3 deletions
|
@ -89,10 +89,20 @@ local function call_callback(request, err)
|
|||
end
|
||||
if callback then
|
||||
local _callback = callback;
|
||||
function callback(a, b, c)
|
||||
local status, result = xpcall(function() _callback(a, b, c) end, debug_traceback);
|
||||
if status then return result; end
|
||||
function callback(method, body, request)
|
||||
local ok, result = xpcall(function() return _callback(method, body, request) end, debug_traceback);
|
||||
if ok then return result; end
|
||||
log("error", "Error in HTTP server handler: %s", result);
|
||||
-- TODO: When we support pipelining, request.destroyed
|
||||
-- won't be the right flag - we just want to see if there
|
||||
-- has been a response to this request yet.
|
||||
if not request.destroyed then
|
||||
return {
|
||||
status = "500 Internal Server Error";
|
||||
headers = { ["Content-Type"] = "text/plain" };
|
||||
body = "There was an error processing your request. See the error log for more details.";
|
||||
};
|
||||
end
|
||||
end
|
||||
if err then
|
||||
log("debug", "Request error: "..err);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue