aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaweł Chmielowski <pawel@process-one.net>2022-02-02 16:19:13 +0100
committerPaweł Chmielowski <pawel@process-one.net>2022-02-02 16:19:13 +0100
commit8824a912ef95c8e4afb42f2d682c9a737f277016 (patch)
tree293d9f59b876407160b3ee54a1c274183715862e
parentStore all mucsub notifications not only message notifications (diff)
Don't expect that socket will be available in c2s_terminated hook
For detached connection we free socket, so let's make code account for this (and we really need it for printing debug informations). This makes sure we call ejabberd_sm:close_session
-rw-r--r--src/ejabberd_c2s.erl6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/ejabberd_c2s.erl b/src/ejabberd_c2s.erl
index 3218cce51..e378953af 100644
--- a/src/ejabberd_c2s.erl
+++ b/src/ejabberd_c2s.erl
@@ -285,12 +285,12 @@ process_closed(State, Reason) ->
stop_async(self()),
State#{stop_reason => Reason}.
-process_terminated(#{sid := SID, socket := Socket,
- jid := JID, user := U, server := S, resource := R} = State,
+process_terminated(#{sid := SID, jid := JID, user := U, server := S, resource := R} = State,
Reason) ->
Status = format_reason(State, Reason),
?INFO_MSG("(~ts) Closing c2s session for ~ts: ~ts",
- [xmpp_socket:pp(Socket), jid:encode(JID), Status]),
+ [case State of #{socket := Socket} -> xmpp_socket:pp(Socket); _ -> <<"unknown">> end,
+ jid:encode(JID), Status]),
Pres = #presence{type = unavailable,
from = JID,
to = jid:remove_resource(JID)},