# HG changeset patch # User Matthew Wild # Date 1307273329 -3600 # Node ID 42d7d09fdda0b63274ec3cdb5da763a92ff95955 # Parent bcdff2b1d3ecc63a9ee28c66cad0952b57eda005 Backout commit d6366294f618 which I was testing and didn't mean to push to 0.8 diff -r bcdff2b1d3ec -r 42d7d09fdda0 plugins/mod_bosh.lua --- a/plugins/mod_bosh.lua Sun Jun 05 12:18:24 2011 +0100 +++ b/plugins/mod_bosh.lua Sun Jun 05 12:28:49 2011 +0100 @@ -162,13 +162,7 @@ end end - if session.bosh_terminate then - session.log("debug", "Closing session with %d requests open", #session.requests); - session:close(); - return nil; - else - return true; -- Inform httpserver we shall reply later - end + return true; -- Inform httpserver we shall reply later end end @@ -208,6 +202,7 @@ local session_close_response = { headers = default_headers, body = tostring(close_reply) }; + --FIXME: Quite sure we shouldn't reply to all requests with the error for _, held_request in ipairs(session.requests) do held_request:send(session_close_response); held_request:destroy(); @@ -260,13 +255,7 @@ local oldest_request = r[1]; if oldest_request then log("debug", "We have an open request, so sending on that"); - response.body = t_concat({ - "", - tostring(s), - "" - }); + response.body = t_concat{"", tostring(s), "" }; oldest_request:send(response); --log("debug", "Sent"); if oldest_request.stayopen then @@ -338,6 +327,13 @@ session.rid = rid; end + if attr.type == "terminate" then + -- Client wants to end this session + session:close(); + request.notopen = nil; + return; + end + if session.notopen then local features = st.stanza("stream:features"); hosts[session.host].events.fire_event("stream-features", { origin = session, features = features }); @@ -346,12 +342,6 @@ session.notopen = nil; end - if attr.type == "terminate" then - -- Client wants to end this session, which we'll do - -- after processing any stanzas in this request - session.bosh_terminate = true; - end - request.notopen = nil; -- Signals that we accept this opening tag t_insert(session.requests, request); request.sid = sid;