- 1.47 Thu Feb 8 23:11:42 GMT 2001 by dugsong

[serverloop.c sshconnect1.c]
     mitigate SSH1 traffic analysis - from Solar Designer
     <solar@openwall.com>, ok provos@
This commit is contained in:
Ben Lindstrom 2001-02-10 23:44:47 +00:00
parent f7d79c794b
commit aa630def4d
3 changed files with 34 additions and 6 deletions

View File

@ -92,6 +92,10 @@
- itojun@cvs.openbsd.org 2001/02/07 18:04:50 - itojun@cvs.openbsd.org 2001/02/07 18:04:50
[xmalloc.c] [xmalloc.c]
fix size_t -> int cast (use u_long). markus ok fix size_t -> int cast (use u_long). markus ok
- 1.47 Thu Feb 8 23:11:42 GMT 2001 by dugsong
[serverloop.c sshconnect1.c]
mitigate SSH1 traffic analysis - from Solar Designer
<solar@openwall.com>, ok provos@
- (bal) fixed sftp-client.c. Return 'status' instead of '0' - (bal) fixed sftp-client.c. Return 'status' instead of '0'
(from the OpenBSD tree) (from the OpenBSD tree)
- (bal) Synced ssh.1, ssh-add.1 and sshd.8 w/ OpenBSD - (bal) Synced ssh.1, ssh-add.1 and sshd.8 w/ OpenBSD
@ -3880,4 +3884,4 @@
- Wrote replacements for strlcpy and mkdtemp - Wrote replacements for strlcpy and mkdtemp
- Released 1.0pre1 - Released 1.0pre1
$Id: ChangeLog,v 1.736 2001/02/10 23:34:54 mouring Exp $ $Id: ChangeLog,v 1.737 2001/02/10 23:44:47 mouring Exp $

View File

@ -35,7 +35,7 @@
*/ */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: serverloop.c,v 1.46 2001/02/08 19:30:52 itojun Exp $"); RCSID("$OpenBSD: serverloop.c,v 1.47 2001/02/08 23:11:42 dugsong Exp $");
#include "xmalloc.h" #include "xmalloc.h"
#include "packet.h" #include "packet.h"
@ -317,6 +317,7 @@ process_input(fd_set * readset)
void void
process_output(fd_set * writeset) process_output(fd_set * writeset)
{ {
struct termios tio;
int len; int len;
/* Write buffered data to program stdin. */ /* Write buffered data to program stdin. */
@ -336,7 +337,16 @@ process_output(fd_set * writeset)
#endif #endif
fdin = -1; fdin = -1;
} else { } else {
/* Successful write. Consume the data from the buffer. */ /* Successful write. */
if (tcgetattr(fdin, &tio) == 0 &&
!(tio.c_lflag & ECHO)) {
/* Simulate echo to reduce the impact of traffic analysis. */
packet_start(SSH_MSG_IGNORE);
memset(buffer_ptr(&stdin_buffer), 0, len);
packet_put_string(buffer_ptr(&stdin_buffer), len);
packet_send();
}
/* Consume the data from the buffer. */
buffer_consume(&stdin_buffer, len); buffer_consume(&stdin_buffer, len);
/* Update the count of bytes written to the program. */ /* Update the count of bytes written to the program. */
stdin_bytes += len; stdin_bytes += len;

View File

@ -13,7 +13,7 @@
*/ */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: sshconnect1.c,v 1.24 2001/02/08 19:30:52 itojun Exp $"); RCSID("$OpenBSD: sshconnect1.c,v 1.25 2001/02/08 23:11:43 dugsong Exp $");
#include <openssl/bn.h> #include <openssl/bn.h>
#include <openssl/evp.h> #include <openssl/evp.h>
@ -51,6 +51,20 @@ u_int supported_authentications = 0;
extern Options options; extern Options options;
extern char *__progname; extern char *__progname;
void
ssh1_put_password(char *password)
{
int size;
char *padded;
size = roundup(strlen(password), 32);
padded = xmalloc(size);
strlcpy(padded, password, size);
packet_put_string(padded, size);
memset(padded, 0, size);
xfree(padded);
}
/* /*
* Checks if the user has an authentication agent, and if so, tries to * Checks if the user has an authentication agent, and if so, tries to
* authenticate using the agent. * authenticate using the agent.
@ -658,7 +672,7 @@ try_challenge_reponse_authentication(void)
break; break;
} }
packet_start(SSH_CMSG_AUTH_TIS_RESPONSE); packet_start(SSH_CMSG_AUTH_TIS_RESPONSE);
packet_put_string(response, strlen(response)); ssh1_put_password(response);
memset(response, 0, strlen(response)); memset(response, 0, strlen(response));
xfree(response); xfree(response);
packet_send(); packet_send();
@ -691,7 +705,7 @@ try_password_authentication(char *prompt)
error("Permission denied, please try again."); error("Permission denied, please try again.");
password = read_passphrase(prompt, 0); password = read_passphrase(prompt, 0);
packet_start(SSH_CMSG_AUTH_PASSWORD); packet_start(SSH_CMSG_AUTH_PASSWORD);
packet_put_string(password, strlen(password)); ssh1_put_password(password);
memset(password, 0, strlen(password)); memset(password, 0, strlen(password));
xfree(password); xfree(password);
packet_send(); packet_send();