[sshd.c]
     add privsep_preauth() and remove 1 goto; ok provos@
This commit is contained in:
Ben Lindstrom 2002-03-22 03:43:46 +00:00
parent fa1336ff47
commit 943481cc77
2 changed files with 59 additions and 44 deletions

View File

@ -133,6 +133,9 @@
- markus@cvs.openbsd.org 2002/03/21 20:51:12 - markus@cvs.openbsd.org 2002/03/21 20:51:12
[sshd_config] [sshd_config]
add privsep (off) add privsep (off)
- markus@cvs.openbsd.org 2002/03/21 21:23:34
[sshd.c]
add privsep_preauth() and remove 1 goto; ok provos@
20020317 20020317
- (tim) [configure.ac] Assume path given with --with-pid-dir=PATH is wanted, - (tim) [configure.ac] Assume path given with --with-pid-dir=PATH is wanted,
@ -7979,4 +7982,4 @@
- Wrote replacements for strlcpy and mkdtemp - Wrote replacements for strlcpy and mkdtemp
- Released 1.0pre1 - Released 1.0pre1
$Id: ChangeLog,v 1.1962 2002/03/22 03:40:58 mouring Exp $ $Id: ChangeLog,v 1.1963 2002/03/22 03:43:46 mouring Exp $

98
sshd.c
View File

@ -42,7 +42,7 @@
*/ */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: sshd.c,v 1.236 2002/03/20 21:08:08 stevesk Exp $"); RCSID("$OpenBSD: sshd.c,v 1.237 2002/03/21 21:23:34 markus Exp $");
#include <openssl/dh.h> #include <openssl/dh.h>
#include <openssl/bn.h> #include <openssl/bn.h>
@ -551,14 +551,51 @@ privsep_preauth_child(void)
do_setusercontext(pw); do_setusercontext(pw);
} }
static Authctxt*
privsep_preauth(void)
{
Authctxt *authctxt = NULL;
int status;
pid_t pid;
/* Set up unprivileged child process to deal with network data */
monitor = monitor_init();
/* Store a pointer to the kex for later rekeying */
monitor->m_pkex = &xxx_kex;
pid = fork();
if (pid == -1) {
fatal("fork of unprivileged child failed");
} else if (pid != 0) {
debug2("Network child is on pid %d", pid);
close(monitor->m_recvfd);
authctxt = monitor_child_preauth(monitor);
close(monitor->m_sendfd);
/* Sync memory */
monitor_sync(monitor);
/* Wait for the child's exit status */
waitpid(pid, &status, 0);
return (authctxt);
} else {
/* child */
close(monitor->m_sendfd);
/* Demote the child */
if (getuid() == 0 || geteuid() == 0)
privsep_preauth_child();
}
return (NULL);
}
static void static void
privsep_postauth(Authctxt *authctxt, pid_t pid) privsep_postauth(Authctxt *authctxt)
{ {
extern Authctxt *x_authctxt; extern Authctxt *x_authctxt;
int status;
/* Wait for the child's exit status */
waitpid(pid, &status, 0);
/* XXX - Remote port forwarding */ /* XXX - Remote port forwarding */
x_authctxt = authctxt; x_authctxt = authctxt;
@ -584,7 +621,7 @@ privsep_postauth(Authctxt *authctxt, pid_t pid)
if (monitor->m_pid == -1) if (monitor->m_pid == -1)
fatal("fork of unprivileged child failed"); fatal("fork of unprivileged child failed");
else if (monitor->m_pid != 0) { else if (monitor->m_pid != 0) {
debug2("User child is on pid %d", pid); debug2("User child is on pid %d", monitor->m_pid);
close(monitor->m_recvfd); close(monitor->m_recvfd);
monitor_child_postauth(monitor); monitor_child_postauth(monitor);
@ -604,7 +641,6 @@ privsep_postauth(Authctxt *authctxt, pid_t pid)
monitor_apply_keystate(monitor); monitor_apply_keystate(monitor);
} }
static char * static char *
list_hostkey_types(void) list_hostkey_types(void)
{ {
@ -1379,36 +1415,9 @@ main(int ac, char **av)
packet_set_nonblocking(); packet_set_nonblocking();
if (!use_privsep) if (use_privsep)
goto skip_privilegeseparation; if ((authctxt = privsep_preauth()) != NULL)
goto authenticated;
/* Set up unprivileged child process to deal with network data */
monitor = monitor_init();
/* Store a pointer to the kex for later rekeying */
monitor->m_pkex = &xxx_kex;
pid = fork();
if (pid == -1)
fatal("fork of unprivileged child failed");
else if (pid != 0) {
debug2("Network child is on pid %d", pid);
close(monitor->m_recvfd);
authctxt = monitor_child_preauth(monitor);
close(monitor->m_sendfd);
/* Sync memory */
monitor_sync(monitor);
goto authenticated;
} else {
close(monitor->m_sendfd);
/* Demote the child */
if (getuid() == 0 || geteuid() == 0)
privsep_preauth_child();
}
skip_privilegeseparation:
/* perform the key exchange */ /* perform the key exchange */
/* authenticate user and start session */ /* authenticate user and start session */
@ -1419,12 +1428,14 @@ main(int ac, char **av)
do_ssh1_kex(); do_ssh1_kex();
authctxt = do_authentication(); authctxt = do_authentication();
} }
if (use_privsep) /*
* If we use privilege separation, the unprivileged child transfers
* the current keystate and exits
*/
if (use_privsep) {
mm_send_keystate(monitor); mm_send_keystate(monitor);
/* If we use privilege separation, the unprivileged child exits */
if (use_privsep)
exit(0); exit(0);
}
authenticated: authenticated:
/* /*
@ -1432,7 +1443,8 @@ main(int ac, char **av)
* file descriptor passing. * file descriptor passing.
*/ */
if (use_privsep) { if (use_privsep) {
privsep_postauth(authctxt, pid); privsep_postauth(authctxt);
/* the monitor process [priv] will not return */
if (!compat20) if (!compat20)
destroy_sensitive_data(); destroy_sensitive_data();
} }