mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Add support for sending SSH2_MSG_UNIMPLEMENTED for unrecognised
messages; also do something with the debugging messages sent as SSH2_MSG_DEBUG. [originally from svn r1544]
This commit is contained in:
parent
3e7e1eb9e8
commit
e6cc16b8b2
153
ssh.c
153
ssh.c
@ -309,6 +309,18 @@ extern void pfd_confirm(Socket s);
|
|||||||
extern void pfd_unthrottle(Socket s);
|
extern void pfd_unthrottle(Socket s);
|
||||||
extern void pfd_override_throttle(Socket s, int enable);
|
extern void pfd_override_throttle(Socket s, int enable);
|
||||||
|
|
||||||
|
static void ssh2_pkt_init(int pkt_type);
|
||||||
|
static void ssh2_pkt_addbool(unsigned char value);
|
||||||
|
static void ssh2_pkt_adduint32(unsigned long value);
|
||||||
|
static void ssh2_pkt_addstring_start(void);
|
||||||
|
static void ssh2_pkt_addstring_str(char *data);
|
||||||
|
static void ssh2_pkt_addstring_data(char *data, int len);
|
||||||
|
static void ssh2_pkt_addstring(char *data);
|
||||||
|
static char *ssh2_mpint_fmt(Bignum b, int *len);
|
||||||
|
static void ssh2_pkt_addmp(Bignum b);
|
||||||
|
static int ssh2_pkt_construct(void);
|
||||||
|
static void ssh2_pkt_send(void);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Buffer management constants. There are several of these for
|
* Buffer management constants. There are several of these for
|
||||||
* various different purposes:
|
* various different purposes:
|
||||||
@ -770,8 +782,8 @@ static int ssh1_rdpkt(unsigned char **data, int *datalen)
|
|||||||
pktin.type == SSH1_MSG_DEBUG ||
|
pktin.type == SSH1_MSG_DEBUG ||
|
||||||
pktin.type == SSH1_SMSG_AUTH_TIS_CHALLENGE ||
|
pktin.type == SSH1_SMSG_AUTH_TIS_CHALLENGE ||
|
||||||
pktin.type == SSH1_SMSG_AUTH_CCARD_CHALLENGE) {
|
pktin.type == SSH1_SMSG_AUTH_CCARD_CHALLENGE) {
|
||||||
long strlen = GET_32BIT(pktin.body);
|
long stringlen = GET_32BIT(pktin.body);
|
||||||
if (strlen + 4 != pktin.length) {
|
if (stringlen + 4 != pktin.length) {
|
||||||
bombout(("Received data packet with bogus string length"));
|
bombout(("Received data packet with bogus string length"));
|
||||||
crReturn(0);
|
crReturn(0);
|
||||||
}
|
}
|
||||||
@ -780,12 +792,12 @@ static int ssh1_rdpkt(unsigned char **data, int *datalen)
|
|||||||
if (pktin.type == SSH1_MSG_DEBUG) {
|
if (pktin.type == SSH1_MSG_DEBUG) {
|
||||||
/* log debug message */
|
/* log debug message */
|
||||||
char buf[80];
|
char buf[80];
|
||||||
int strlen = GET_32BIT(pktin.body);
|
int stringlen = GET_32BIT(pktin.body);
|
||||||
strcpy(buf, "Remote: ");
|
strcpy(buf, "Remote: ");
|
||||||
if (strlen > 70)
|
if (stringlen > 70)
|
||||||
strlen = 70;
|
stringlen = 70;
|
||||||
memcpy(buf + 8, pktin.body + 4, strlen);
|
memcpy(buf + 8, pktin.body + 4, stringlen);
|
||||||
buf[8 + strlen] = '\0';
|
buf[8 + stringlen] = '\0';
|
||||||
logevent(buf);
|
logevent(buf);
|
||||||
goto next_packet;
|
goto next_packet;
|
||||||
} else if (pktin.type == SSH1_MSG_IGNORE) {
|
} else if (pktin.type == SSH1_MSG_IGNORE) {
|
||||||
@ -945,36 +957,105 @@ static int ssh2_rdpkt(unsigned char **data, int *datalen)
|
|||||||
log_packet(PKT_INCOMING, pktin.type, ssh2_pkt_type(pktin.type),
|
log_packet(PKT_INCOMING, pktin.type, ssh2_pkt_type(pktin.type),
|
||||||
pktin.data+6, pktin.length-6);
|
pktin.data+6, pktin.length-6);
|
||||||
|
|
||||||
if (pktin.type == SSH2_MSG_IGNORE || pktin.type == SSH2_MSG_DEBUG)
|
switch (pktin.type) {
|
||||||
goto next_packet; /* FIXME: print DEBUG message */
|
/*
|
||||||
|
* These packets we must handle instantly.
|
||||||
if (pktin.type == SSH2_MSG_DISCONNECT) {
|
*/
|
||||||
/* log reason code in disconnect message */
|
case SSH2_MSG_DISCONNECT:
|
||||||
char buf[256];
|
{
|
||||||
int reason = GET_32BIT(pktin.data + 6);
|
/* log reason code in disconnect message */
|
||||||
unsigned msglen = GET_32BIT(pktin.data + 10);
|
char buf[256];
|
||||||
unsigned nowlen;
|
int reason = GET_32BIT(pktin.data + 6);
|
||||||
if (reason > 0 && reason < lenof(ssh2_disconnect_reasons)) {
|
unsigned msglen = GET_32BIT(pktin.data + 10);
|
||||||
sprintf(buf, "Received disconnect message (%s)",
|
unsigned nowlen;
|
||||||
ssh2_disconnect_reasons[reason]);
|
if (reason > 0 && reason < lenof(ssh2_disconnect_reasons)) {
|
||||||
} else {
|
sprintf(buf, "Received disconnect message (%s)",
|
||||||
sprintf(buf, "Received disconnect message (unknown type %d)",
|
ssh2_disconnect_reasons[reason]);
|
||||||
reason);
|
} else {
|
||||||
|
sprintf(buf, "Received disconnect message (unknown type %d)",
|
||||||
|
reason);
|
||||||
|
}
|
||||||
|
logevent(buf);
|
||||||
|
strcpy(buf, "Disconnection message text: ");
|
||||||
|
nowlen = strlen(buf);
|
||||||
|
if (msglen > sizeof(buf) - nowlen - 1)
|
||||||
|
msglen = sizeof(buf) - nowlen - 1;
|
||||||
|
memcpy(buf + nowlen, pktin.data + 14, msglen);
|
||||||
|
buf[nowlen + msglen] = '\0';
|
||||||
|
logevent(buf);
|
||||||
|
bombout(("Server sent disconnect message\ntype %d (%s):\n\"%s\"",
|
||||||
|
reason,
|
||||||
|
(reason > 0 && reason < lenof(ssh2_disconnect_reasons)) ?
|
||||||
|
ssh2_disconnect_reasons[reason] : "unknown",
|
||||||
|
buf+nowlen));
|
||||||
|
crReturn(0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case SSH2_MSG_IGNORE:
|
||||||
|
goto next_packet;
|
||||||
|
case SSH2_MSG_DEBUG:
|
||||||
|
{
|
||||||
|
/* log the debug message */
|
||||||
|
char buf[512];
|
||||||
|
/* int display = pktin.body[6]; */
|
||||||
|
int stringlen = GET_32BIT(pktin.data+7);
|
||||||
|
int prefix;
|
||||||
|
strcpy(buf, "Remote debug message: ");
|
||||||
|
prefix = strlen(buf);
|
||||||
|
if (stringlen > sizeof(buf)-prefix-1)
|
||||||
|
stringlen = sizeof(buf)-prefix-1;
|
||||||
|
memcpy(buf + prefix, pktin.data + 11, stringlen);
|
||||||
|
buf[prefix + stringlen] = '\0';
|
||||||
|
logevent(buf);
|
||||||
}
|
}
|
||||||
logevent(buf);
|
goto next_packet; /* FIXME: print the debug message */
|
||||||
strcpy(buf, "Disconnection message text: ");
|
|
||||||
nowlen = strlen(buf);
|
/*
|
||||||
if (msglen > sizeof(buf) - nowlen - 1)
|
* These packets we need do nothing about here.
|
||||||
msglen = sizeof(buf) - nowlen - 1;
|
*/
|
||||||
memcpy(buf + nowlen, pktin.data + 14, msglen);
|
case SSH2_MSG_UNIMPLEMENTED:
|
||||||
buf[nowlen + msglen] = '\0';
|
case SSH2_MSG_SERVICE_REQUEST:
|
||||||
logevent(buf);
|
case SSH2_MSG_SERVICE_ACCEPT:
|
||||||
bombout(("Server sent disconnect message\ntype %d (%s):\n\"%s\"",
|
case SSH2_MSG_KEXINIT:
|
||||||
reason,
|
case SSH2_MSG_NEWKEYS:
|
||||||
(reason > 0 && reason < lenof(ssh2_disconnect_reasons)) ?
|
case SSH2_MSG_KEXDH_INIT:
|
||||||
ssh2_disconnect_reasons[reason] : "unknown",
|
case SSH2_MSG_KEXDH_REPLY:
|
||||||
buf+nowlen));
|
/* case SSH2_MSG_KEX_DH_GEX_REQUEST: duplicate case value */
|
||||||
crReturn(0);
|
/* case SSH2_MSG_KEX_DH_GEX_GROUP: duplicate case value */
|
||||||
|
case SSH2_MSG_KEX_DH_GEX_INIT:
|
||||||
|
case SSH2_MSG_KEX_DH_GEX_REPLY:
|
||||||
|
case SSH2_MSG_USERAUTH_REQUEST:
|
||||||
|
case SSH2_MSG_USERAUTH_FAILURE:
|
||||||
|
case SSH2_MSG_USERAUTH_SUCCESS:
|
||||||
|
case SSH2_MSG_USERAUTH_BANNER:
|
||||||
|
case SSH2_MSG_USERAUTH_PK_OK:
|
||||||
|
/* case SSH2_MSG_USERAUTH_PASSWD_CHANGEREQ: duplicate case value */
|
||||||
|
/* case SSH2_MSG_USERAUTH_INFO_REQUEST: duplicate case value */
|
||||||
|
case SSH2_MSG_USERAUTH_INFO_RESPONSE:
|
||||||
|
case SSH2_MSG_GLOBAL_REQUEST:
|
||||||
|
case SSH2_MSG_REQUEST_SUCCESS:
|
||||||
|
case SSH2_MSG_REQUEST_FAILURE:
|
||||||
|
case SSH2_MSG_CHANNEL_OPEN:
|
||||||
|
case SSH2_MSG_CHANNEL_OPEN_CONFIRMATION:
|
||||||
|
case SSH2_MSG_CHANNEL_OPEN_FAILURE:
|
||||||
|
case SSH2_MSG_CHANNEL_WINDOW_ADJUST:
|
||||||
|
case SSH2_MSG_CHANNEL_DATA:
|
||||||
|
case SSH2_MSG_CHANNEL_EXTENDED_DATA:
|
||||||
|
case SSH2_MSG_CHANNEL_EOF:
|
||||||
|
case SSH2_MSG_CHANNEL_CLOSE:
|
||||||
|
case SSH2_MSG_CHANNEL_REQUEST:
|
||||||
|
case SSH2_MSG_CHANNEL_SUCCESS:
|
||||||
|
case SSH2_MSG_CHANNEL_FAILURE:
|
||||||
|
break;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* For anything else we send SSH2_MSG_UNIMPLEMENTED.
|
||||||
|
*/
|
||||||
|
default:
|
||||||
|
ssh2_pkt_init(SSH2_MSG_UNIMPLEMENTED);
|
||||||
|
ssh2_pkt_adduint32(st->incoming_sequence - 1);
|
||||||
|
ssh2_pkt_send();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
crFinish(0);
|
crFinish(0);
|
||||||
|
Loading…
Reference in New Issue
Block a user