From f27a7effacf3dace14c48a4863a259dbfcd96139 Mon Sep 17 00:00:00 2001 From: peter Date: Sun, 12 Nov 1995 18:31:23 +0000 Subject: Move the setlogin() call a little earlier.. It was being done in the child process - which would be no longer allowed if the setlogin() changes go through. Now the parent (the session leader, when started by inetd) does it. --- libexec/rshd/rshd.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) (limited to 'libexec/rshd') diff --git a/libexec/rshd/rshd.c b/libexec/rshd/rshd.c index 7763601..4469d4a 100644 --- a/libexec/rshd/rshd.c +++ b/libexec/rshd/rshd.c @@ -469,6 +469,11 @@ fail: error("Logins currently disabled.\n"); exit(1); } +#if BSD > 43 + /* before fork, while we're session leader */ + if (setlogin(pwd->pw_name) < 0) + syslog(LOG_ERR, "setlogin() failed: %m"); +#endif (void) write(STDERR_FILENO, "\0", 1); sent_null = 1; @@ -643,10 +648,6 @@ fail: } if (*pwd->pw_shell == '\0') pwd->pw_shell = _PATH_BSHELL; -#if BSD > 43 - if (setlogin(pwd->pw_name) < 0) - syslog(LOG_ERR, "setlogin() failed: %m"); -#endif (void) setgid((gid_t)pwd->pw_gid); initgroups(pwd->pw_name, pwd->pw_gid); (void) setuid((uid_t)pwd->pw_uid); -- cgit v1.1