From 67a0ef27644ad3ae9cd0df362ed185d28e53bca5 Mon Sep 17 00:00:00 2001 From: "Andrey A. Chernov" Date: Tue, 25 Sep 2001 11:07:26 +0000 Subject: 1) Back out ~/.login_conf disable 2) Pick only "me" class from ~/.login_conf as documented --- libutil/login_cap.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) (limited to 'libutil/login_cap.c') diff --git a/libutil/login_cap.c b/libutil/login_cap.c index bb4c080..f841961 100644 --- a/libutil/login_cap.c +++ b/libutil/login_cap.c @@ -184,18 +184,17 @@ login_getclassbyname(char const *name, const struct passwd *pwd) login_cap_t *lc; if ((lc = malloc(sizeof(login_cap_t))) != NULL) { - int r, i = 0; + int r, me, i = 0; uid_t euid = 0; gid_t egid = 0; const char *msg = NULL; - const char *dir = (pwd == NULL) ? NULL : pwd->pw_dir; + const char *dir; char userpath[MAXPATHLEN]; static char *login_dbarray[] = { NULL, NULL, NULL }; -#ifndef _FILE_LOGIN_CONF_WORKS - dir = NULL; -#endif + me = (name != NULL && strcmp(name, LOGIN_MECLASS) == 0); + dir = (!me || pwd == NULL) ? NULL : pwd->pw_dir; /* * Switch to user mode before checking/reading its ~/.login_conf * - some NFSes have root read access disabled. @@ -227,7 +226,7 @@ login_getclassbyname(char const *name, const struct passwd *pwd) switch (cgetent(&lc->lc_cap, login_dbarray, (char*)name)) { case -1: /* Failed, entry does not exist */ - if (strcmp(name, LOGIN_MECLASS) == 0) + if (me) break; /* Don't retry default on 'me' */ if (i == 0) r = -1; -- cgit v1.2.3-56-ge451