mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-07-14 09:37:34 -05:00
Move version string exchange out into a BPP.
Getting it out of the overgrown ssh.c is worthwhile in itself! But there are other benefits of this reorganisation too. One is that I get to remove ssh->current_incoming_data_fn, because now _all_ incoming network data is handled by whatever the current BPP is. So now we only indirect through the BPP, not through some other preliminary function pointer _and_ the BPP. Another is that all _outgoing_ network data is now handled centrally, including our outgoing version string - which means that a hex dump of that string now shows up in the raw-data log file, from which it was previously conspicuous by its absence.
This commit is contained in:
17
sshbpp.h
17
sshbpp.h
@ -50,4 +50,21 @@ void ssh2_bpp_new_incoming_crypto(
|
||||
|
||||
BinaryPacketProtocol *ssh2_bare_bpp_new(void);
|
||||
|
||||
/*
|
||||
* The initial code to handle the SSH version exchange is also
|
||||
* structured as an implementation of BinaryPacketProtocol, because
|
||||
* that makes it easy to switch from that to the next BPP once it
|
||||
* tells us which one we're using.
|
||||
*/
|
||||
struct ssh_version_receiver {
|
||||
void (*got_ssh_version)(struct ssh_version_receiver *rcv,
|
||||
int major_version);
|
||||
};
|
||||
BinaryPacketProtocol *ssh_verstring_new(
|
||||
Conf *conf, Frontend *frontend, int bare_connection_mode,
|
||||
const char *protoversion, struct ssh_version_receiver *rcv);
|
||||
const char *ssh_verstring_get_remote(BinaryPacketProtocol *);
|
||||
const char *ssh_verstring_get_local(BinaryPacketProtocol *);
|
||||
int ssh_verstring_get_bugs(BinaryPacketProtocol *);
|
||||
|
||||
#endif /* PUTTY_SSHBPP_H */
|
||||
|
Reference in New Issue
Block a user