summaryrefslogtreecommitdiffstats
path: root/auth2.c
diff options
context:
space:
mode:
authorBen Lindstrom <mouring@eviladmin.org>2001-06-09 01:40:00 +0000
committerBen Lindstrom <mouring@eviladmin.org>2001-06-09 01:40:00 +0000
commit9d0c06667eb4ca616ffa690e88b9dd7c438e3103 (patch)
tree640548fec4f56158a0cfc6b3d3f58eabdc73eeed /auth2.c
parent5acb5d03edecae6ecbd062b9da9f7f4fde382287 (diff)
- markus@cvs.openbsd.org 2001/06/07 19:57:53
[auth2.c] style is used for bsdauth. disconnect on user/service change (ietf-drafts)
Diffstat (limited to 'auth2.c')
-rw-r--r--auth2.c16
1 files changed, 7 insertions, 9 deletions
diff --git a/auth2.c b/auth2.c
index 0b4df9cd..554ca4c1 100644
--- a/auth2.c
+++ b/auth2.c
@@ -23,7 +23,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: auth2.c,v 1.61 2001/05/31 10:30:12 markus Exp $");
+RCSID("$OpenBSD: auth2.c,v 1.62 2001/06/07 19:57:53 markus Exp $");
#include <openssl/evp.h>
@@ -219,14 +219,12 @@ input_userauth_request(int type, int plen, void *ctxt)
setproctitle("%s", pw ? user : "unknown");
authctxt->user = xstrdup(user);
authctxt->service = xstrdup(service);
- authctxt->style = style ? xstrdup(style) : NULL; /* currently unused */
- } else if (authctxt->valid) {
- if (strcmp(user, authctxt->user) != 0 ||
- strcmp(service, authctxt->service) != 0) {
- log("input_userauth_request: mismatch: (%s,%s)!=(%s,%s)",
- user, service, authctxt->user, authctxt->service);
- authctxt->valid = 0;
- }
+ authctxt->style = style ? xstrdup(style) : NULL;
+ } else if (strcmp(user, authctxt->user) != 0 ||
+ strcmp(service, authctxt->service) != 0) {
+ packet_disconnect("Change of username or service not allowed: "
+ "(%s,%s) -> (%s,%s)",
+ authctxt->user, authctxt->service, user, service);
}
/* reset state */
dispatch_set(SSH2_MSG_USERAUTH_INFO_RESPONSE, &protocol_error);