Skip to content

Commit

Permalink
ssh: send ext-info-c only once
Browse files Browse the repository at this point in the history
In accordance to RFC8308, send ext-info-c only during the first key
exchange. Some server implementations such as OpenSSH 7 will send an
extInfoMsg message each time when ext-info-c is received. This results
in a closed connection, as our client does not expect this message while
handling the mux.

See https://bugzilla.mindrot.org/show_bug.cgi?id=2929 regarding the
behaviour of OpenSSH if it sees ext-info-c in later key exchanges.

Fixes #51808

Signed-off-by: Peter Verraedt <[email protected]>
  • Loading branch information
peterverraedt committed Mar 21, 2022
1 parent 3147a52 commit fcfe5ed
Showing 1 changed file with 6 additions and 4 deletions.
10 changes: 6 additions & 4 deletions ssh/handshake.go
Original file line number Diff line number Diff line change
Expand Up @@ -479,10 +479,12 @@ func (t *handshakeTransport) sendKexInit() error {

// As a client we opt in to receiving SSH_MSG_EXT_INFO so we know what
// algorithms the server supports for public key authentication. See RFC
// 8303, Section 2.1.
msg.KexAlgos = make([]string, 0, len(t.config.KeyExchanges)+1)
msg.KexAlgos = append(msg.KexAlgos, t.config.KeyExchanges...)
msg.KexAlgos = append(msg.KexAlgos, "ext-info-c")
// 8308, Section 2.1.
if firstKeyExchange := t.sessionID == nil; firstKeyExchange {
msg.KexAlgos = make([]string, 0, len(t.config.KeyExchanges)+1)
msg.KexAlgos = append(msg.KexAlgos, t.config.KeyExchanges...)
msg.KexAlgos = append(msg.KexAlgos, "ext-info-c")
}
}

packet := Marshal(msg)
Expand Down

0 comments on commit fcfe5ed

Please sign in to comment.