summaryrefslogtreecommitdiffstats
path: root/usr.bin/ssh/auth1.c
diff options
context:
space:
mode:
authoritojun <itojun@openbsd.org>2002-09-09 06:48:06 +0000
committeritojun <itojun@openbsd.org>2002-09-09 06:48:06 +0000
commiteedb1b6e77bc55894fc71ca16bd43d3301da13f9 (patch)
treecd5dab529c0d5c2d016eafc4378ce5066fe1928f /usr.bin/ssh/auth1.c
parentTry to make the minor number calculation match the driver. (diff)
downloadwireguard-openbsd-eedb1b6e77bc55894fc71ca16bd43d3301da13f9.tar.xz
wireguard-openbsd-eedb1b6e77bc55894fc71ca16bd43d3301da13f9.zip
kerberos support for privsep. confirmed to work by lha@stacken.kth.se
patch from markus
Diffstat (limited to 'usr.bin/ssh/auth1.c')
-rw-r--r--usr.bin/ssh/auth1.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/usr.bin/ssh/auth1.c b/usr.bin/ssh/auth1.c
index 661ed5a176c..359eeea0d36 100644
--- a/usr.bin/ssh/auth1.c
+++ b/usr.bin/ssh/auth1.c
@@ -10,7 +10,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: auth1.c,v 1.42 2002/08/22 21:33:58 markus Exp $");
+RCSID("$OpenBSD: auth1.c,v 1.43 2002/09/09 06:48:06 itojun Exp $");
#include "xmalloc.h"
#include "rsa.h"
@@ -132,15 +132,27 @@ do_authloop(Authctxt *authctxt)
#endif /* KRB4 */
} else {
#ifdef KRB5
- krb5_data tkt;
+ krb5_data tkt, reply;
tkt.length = dlen;
tkt.data = kdata;
- if (auth_krb5(authctxt, &tkt, &client_user)) {
+ if (PRIVSEP(auth_krb5(authctxt, &tkt,
+ &client_user, &reply))) {
authenticated = 1;
snprintf(info, sizeof(info),
" tktuser %.100s",
client_user);
+
+ /* Send response to client */
+ packet_start(
+ SSH_SMSG_AUTH_KERBEROS_RESPONSE);
+ packet_put_string((char *)
+ reply.data, reply.length);
+ packet_send();
+ packet_write_wait();
+
+ if (reply.length)
+ xfree(reply.data);
xfree(client_user);
}
#endif /* KRB5 */