1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Move SSH_MSG_DISCONNECT construction into the BPP.

This is a convenient place for it because it abstracts away the
difference in disconnect packet formats between SSH-1 and -2, so when
I start restructuring, I'll be able to call it even from places that
don't know which version of SSH they're running.
This commit is contained in:
Simon Tatham 2018-09-24 18:14:33 +01:00
parent 6bb847738b
commit 3074440040
7 changed files with 41 additions and 14 deletions

15
ssh.c
View File

@ -1429,19 +1429,8 @@ static void ssh_disconnect(Ssh ssh, const char *client_reason,
error = dupprintf("Disconnected: %s", client_reason); error = dupprintf("Disconnected: %s", client_reason);
else else
error = dupstr("Disconnected"); error = dupstr("Disconnected");
if (wire_reason) { if (wire_reason)
if (ssh->version == 1) { ssh_bpp_queue_disconnect(ssh->bpp, wire_reason, code);
PktOut *pktout = ssh_bpp_new_pktout(ssh->bpp, SSH1_MSG_DISCONNECT);
put_stringz(pktout, wire_reason);
ssh_pkt_write(ssh, pktout);
} else if (ssh->version == 2) {
PktOut *pktout = ssh_bpp_new_pktout(ssh->bpp, SSH2_MSG_DISCONNECT);
put_uint32(pktout, code);
put_stringz(pktout, wire_reason);
put_stringz(pktout, "en"); /* language tag */
ssh_pkt_write(ssh, pktout);
}
}
ssh->close_expected = TRUE; ssh->close_expected = TRUE;
ssh->clean_exit = clean_exit; ssh->clean_exit = clean_exit;
ssh_closing(&ssh->plugvt, error, 0, 0); ssh_closing(&ssh->plugvt, error, 0, 0);

View File

@ -31,6 +31,8 @@ struct ssh1_bpp_state {
static void ssh1_bpp_free(BinaryPacketProtocol *bpp); static void ssh1_bpp_free(BinaryPacketProtocol *bpp);
static void ssh1_bpp_handle_input(BinaryPacketProtocol *bpp); static void ssh1_bpp_handle_input(BinaryPacketProtocol *bpp);
static void ssh1_bpp_handle_output(BinaryPacketProtocol *bpp); static void ssh1_bpp_handle_output(BinaryPacketProtocol *bpp);
static void ssh1_bpp_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category);
static PktOut *ssh1_bpp_new_pktout(int type); static PktOut *ssh1_bpp_new_pktout(int type);
static const struct BinaryPacketProtocolVtable ssh1_bpp_vtable = { static const struct BinaryPacketProtocolVtable ssh1_bpp_vtable = {
@ -38,6 +40,7 @@ static const struct BinaryPacketProtocolVtable ssh1_bpp_vtable = {
ssh1_bpp_handle_input, ssh1_bpp_handle_input,
ssh1_bpp_handle_output, ssh1_bpp_handle_output,
ssh1_bpp_new_pktout, ssh1_bpp_new_pktout,
ssh1_bpp_queue_disconnect,
}; };
BinaryPacketProtocol *ssh1_bpp_new(void) BinaryPacketProtocol *ssh1_bpp_new(void)
@ -302,3 +305,11 @@ static void ssh1_bpp_handle_output(BinaryPacketProtocol *bpp)
ssh_free_pktout(pkt); ssh_free_pktout(pkt);
} }
} }
static void ssh1_bpp_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category)
{
PktOut *pkt = ssh_bpp_new_pktout(bpp, SSH1_MSG_DISCONNECT);
put_stringz(pkt, msg);
pq_push(&bpp->out_pq, pkt);
}

View File

@ -30,6 +30,7 @@ static const struct BinaryPacketProtocolVtable ssh2_bare_bpp_vtable = {
ssh2_bare_bpp_handle_input, ssh2_bare_bpp_handle_input,
ssh2_bare_bpp_handle_output, ssh2_bare_bpp_handle_output,
ssh2_bare_bpp_new_pktout, ssh2_bare_bpp_new_pktout,
ssh2_bpp_queue_disconnect, /* in sshcommon.c */
}; };
BinaryPacketProtocol *ssh2_bare_bpp_new(void) BinaryPacketProtocol *ssh2_bare_bpp_new(void)

View File

@ -48,6 +48,7 @@ static const struct BinaryPacketProtocolVtable ssh2_bpp_vtable = {
ssh2_bpp_handle_input, ssh2_bpp_handle_input,
ssh2_bpp_handle_output, ssh2_bpp_handle_output,
ssh2_bpp_new_pktout, ssh2_bpp_new_pktout,
ssh2_bpp_queue_disconnect, /* in sshcommon.c */
}; };
BinaryPacketProtocol *ssh2_bpp_new(struct DataTransferStats *stats) BinaryPacketProtocol *ssh2_bpp_new(struct DataTransferStats *stats)

View File

@ -10,6 +10,8 @@ struct BinaryPacketProtocolVtable {
void (*handle_input)(BinaryPacketProtocol *); void (*handle_input)(BinaryPacketProtocol *);
void (*handle_output)(BinaryPacketProtocol *); void (*handle_output)(BinaryPacketProtocol *);
PktOut *(*new_pktout)(int type); PktOut *(*new_pktout)(int type);
void (*queue_disconnect)(BinaryPacketProtocol *,
const char *msg, int category);
}; };
struct BinaryPacketProtocol { struct BinaryPacketProtocol {
@ -39,6 +41,8 @@ struct BinaryPacketProtocol {
#define ssh_bpp_handle_input(bpp) ((bpp)->vt->handle_input(bpp)) #define ssh_bpp_handle_input(bpp) ((bpp)->vt->handle_input(bpp))
#define ssh_bpp_handle_output(bpp) ((bpp)->vt->handle_output(bpp)) #define ssh_bpp_handle_output(bpp) ((bpp)->vt->handle_output(bpp))
#define ssh_bpp_new_pktout(bpp, type) ((bpp)->vt->new_pktout(type)) #define ssh_bpp_new_pktout(bpp, type) ((bpp)->vt->new_pktout(type))
#define ssh_bpp_queue_disconnect(bpp, msg, cat) \
((bpp)->vt->queue_disconnect(bpp, msg, cat))
/* ssh_bpp_free is more than just a macro wrapper on the vtable; it /* ssh_bpp_free is more than just a macro wrapper on the vtable; it
* does centralised parts of the freeing too. */ * does centralised parts of the freeing too. */
@ -58,7 +62,9 @@ void ssh1_bpp_requested_compression(BinaryPacketProtocol *bpp);
* up in_pq and out_pq, and initialising input_consumer. */ * up in_pq and out_pq, and initialising input_consumer. */
void ssh_bpp_common_setup(BinaryPacketProtocol *); void ssh_bpp_common_setup(BinaryPacketProtocol *);
/* Common helper function between the SSH-2 full and bare BPPs */ /* Common helper functions between the SSH-2 full and bare BPPs */
void ssh2_bpp_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category);
int ssh2_bpp_check_unimplemented(BinaryPacketProtocol *bpp, PktIn *pktin); int ssh2_bpp_check_unimplemented(BinaryPacketProtocol *bpp, PktIn *pktin);
/* /*

View File

@ -664,6 +664,16 @@ void ssh_bpp_free(BinaryPacketProtocol *bpp)
bpp->vt->free(bpp); bpp->vt->free(bpp);
} }
void ssh2_bpp_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category)
{
PktOut *pkt = ssh_bpp_new_pktout(bpp, SSH2_MSG_DISCONNECT);
put_uint32(pkt, category);
put_stringz(pkt, msg);
put_stringz(pkt, "en"); /* language tag */
pq_push(&bpp->out_pq, pkt);
}
#define BITMAP_UNIVERSAL(y, name, value) \ #define BITMAP_UNIVERSAL(y, name, value) \
| (value >= y && value < y+32 ? 1UL << (value-y) : 0) | (value >= y && value < y+32 ? 1UL << (value-y) : 0)
#define BITMAP_CONDITIONAL(y, name, value, ctx) \ #define BITMAP_CONDITIONAL(y, name, value, ctx) \

View File

@ -43,12 +43,15 @@ static void ssh_verstring_free(BinaryPacketProtocol *bpp);
static void ssh_verstring_handle_input(BinaryPacketProtocol *bpp); static void ssh_verstring_handle_input(BinaryPacketProtocol *bpp);
static void ssh_verstring_handle_output(BinaryPacketProtocol *bpp); static void ssh_verstring_handle_output(BinaryPacketProtocol *bpp);
static PktOut *ssh_verstring_new_pktout(int type); static PktOut *ssh_verstring_new_pktout(int type);
static void ssh_verstring_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category);
static const struct BinaryPacketProtocolVtable ssh_verstring_vtable = { static const struct BinaryPacketProtocolVtable ssh_verstring_vtable = {
ssh_verstring_free, ssh_verstring_free,
ssh_verstring_handle_input, ssh_verstring_handle_input,
ssh_verstring_handle_output, ssh_verstring_handle_output,
ssh_verstring_new_pktout, ssh_verstring_new_pktout,
ssh_verstring_queue_disconnect,
}; };
static void ssh_detect_bugs(struct ssh_verstring_state *s); static void ssh_detect_bugs(struct ssh_verstring_state *s);
@ -608,3 +611,9 @@ int ssh_verstring_get_bugs(BinaryPacketProtocol *bpp)
FROMFIELD(bpp, struct ssh_verstring_state, bpp); FROMFIELD(bpp, struct ssh_verstring_state, bpp);
return s->remote_bugs; return s->remote_bugs;
} }
static void ssh_verstring_queue_disconnect(BinaryPacketProtocol *bpp,
const char *msg, int category)
{
/* No way to send disconnect messages at this stage of the protocol! */
}