aboutsummaryrefslogtreecommitdiffstats
path: root/net/http
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2019-10-12 18:27:54 +0200
committerKim Alvefur <zash@zash.se>2019-10-12 18:27:54 +0200
commit3a80fa84005eb38cdfb90125ac667d7fda591bdc (patch)
tree6d89e9b7839f308411ff2cf78ee71cc705326b12 /net/http
parent420d792b3769086b92a5b0d1e949a5de926b3a97 (diff)
downloadprosody-3a80fa84005eb38cdfb90125ac667d7fda591bdc.tar.gz
prosody-3a80fa84005eb38cdfb90125ac667d7fda591bdc.zip
net.http.server: Re-fire unhandled HEAD requsts as GET events (fixes #1447)
BC: This overloads the GET event. Previous commit ensures HEAD requests are sent without a body.
Diffstat (limited to 'net/http')
-rw-r--r--net/http/server.lua11
1 files changed, 11 insertions, 0 deletions
diff --git a/net/http/server.lua b/net/http/server.lua
index 47680455..b649ff5f 100644
--- a/net/http/server.lua
+++ b/net/http/server.lua
@@ -229,6 +229,11 @@ function handle_request(conn, request, finish_cb)
local payload = { request = request, response = response };
log("debug", "Firing event: %s", global_event);
local result = events.fire_event(global_event, payload);
+ if result == nil and is_head_request then
+ local global_head_event = "GET "..request.path:match("[^?]*");
+ log("debug", "Firing event: %s", global_head_event);
+ result = events.fire_event(global_head_event, payload);
+ end
if result == nil then
if not hosts[host] then
if hosts[default_host] then
@@ -249,6 +254,12 @@ function handle_request(conn, request, finish_cb)
local host_event = request.method.." "..host..request.path:match("[^?]*");
log("debug", "Firing event: %s", host_event);
result = events.fire_event(host_event, payload);
+
+ if result == nil and is_head_request then
+ local host_head_event = "GET "..host..request.path:match("[^?]*");
+ log("debug", "Firing event: %s", host_head_event);
+ result = events.fire_event(host_head_event, payload);
+ end
end
if result ~= nil then
if result ~= true then