From 51000ea3a85cac863938db75c6032d846b2a79f2 Mon Sep 17 00:00:00 2001 From: Jakub Witczak Date: Mon, 28 Oct 2024 08:57:02 +0100 Subject: [PATCH] ssh: avoid crash upon exit-signal MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - avoid code crash when exit signal is received for closed channel Co-authored-by: Torbjörn Törnkvist --- lib/ssh/src/ssh_connection.erl | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/lib/ssh/src/ssh_connection.erl b/lib/ssh/src/ssh_connection.erl index 34e97ba6ca1f..2645ba421476 100644 --- a/lib/ssh/src/ssh_connection.erl +++ b/lib/ssh/src/ssh_connection.erl @@ -739,21 +739,25 @@ handle_msg(#ssh_msg_channel_request{recipient_channel = ChannelId, handle_msg(#ssh_msg_channel_request{recipient_channel = ChannelId, request_type = "exit-signal", want_reply = false, - data = Data}, + data = Data}, #connection{channel_cache = Cache} = Connection0, _, _SSH) -> <> = Data, - Channel = ssh_client_channel:cache_lookup(Cache, ChannelId), - RemoteId = Channel#channel.remote_id, - {Reply, Connection} = reply_msg(Channel, Connection0, - {exit_signal, ChannelId, - binary_to_list(SigName), - binary_to_list(Err), - binary_to_list(Lang)}), - CloseMsg = channel_close_msg(RemoteId), - {[{connection_reply, CloseMsg}|Reply], Connection}; + case ssh_client_channel:cache_lookup(Cache, ChannelId) of + #channel{remote_id = RemoteId} = Channel -> + {Reply, Connection} = reply_msg(Channel, Connection0, + {exit_signal, ChannelId, + binary_to_list(SigName), + binary_to_list(Err), + binary_to_list(Lang)}), + ChannelCloseMsg = channel_close_msg(RemoteId), + {[{connection_reply, ChannelCloseMsg}|Reply], Connection}; + _ -> + %% Channel already closed by peer + {[], Connection0} + end; handle_msg(#ssh_msg_channel_request{recipient_channel = ChannelId, request_type = "xon-xoff",