mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +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:
parent
6bb847738b
commit
3074440040
15
ssh.c
15
ssh.c
@ -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);
|
||||||
|
11
ssh1bpp.c
11
ssh1bpp.c
@ -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);
|
||||||
|
}
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
8
sshbpp.h
8
sshbpp.h
@ -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);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
10
sshcommon.c
10
sshcommon.c
@ -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) \
|
||||||
|
@ -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! */
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user