1
0
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:
Simon Tatham 2002-01-10 19:50:53 +00:00
parent 3e7e1eb9e8
commit e6cc16b8b2

153
ssh.c
View File

@ -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);