diff options
author | Paweł Chmielowski <pawel@process-one.net> | 2022-02-02 16:19:13 +0100 |
---|---|---|
committer | Paweł Chmielowski <pawel@process-one.net> | 2022-02-02 16:19:13 +0100 |
commit | 8824a912ef95c8e4afb42f2d682c9a737f277016 (patch) | |
tree | 293d9f59b876407160b3ee54a1c274183715862e /src | |
parent | Store 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
Diffstat (limited to 'src')
-rw-r--r-- | src/ejabberd_c2s.erl | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/ejabberd_c2s.erl b/src/ejabberd_c2s.erl index 3218cce5..e378953a 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)}, |