summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/libc/gen/auth_subr.c10
-rw-r--r--lib/libc/gen/authenticate.c28
2 files changed, 18 insertions, 20 deletions
diff --git a/lib/libc/gen/auth_subr.c b/lib/libc/gen/auth_subr.c
index 73d5bff7581..e2612078e03 100644
--- a/lib/libc/gen/auth_subr.c
+++ b/lib/libc/gen/auth_subr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: auth_subr.c,v 1.35 2008/03/24 16:10:59 deraadt Exp $ */
+/* $OpenBSD: auth_subr.c,v 1.36 2009/01/15 13:14:30 millert Exp $ */
/*
* Copyright (c) 2000-2002,2004 Todd C. Miller <Todd.Miller@courtesan.com>
@@ -628,11 +628,11 @@ auth_setpwd(auth_session_t *as, struct passwd *pwd)
if (as->name == NULL)
return (0);
if ((pwd = getpwnam(as->name)) == NULL) {
- instance = strpbrk(as->name, "./");
- if (instance++ == NULL)
+ instance = strchr(as->name, '/');
+ if (instance == NULL)
return (as->pwd ? 0 : 1);
- if (strcmp(instance, "root") == 0)
- pwd = getpwnam(instance);
+ if (strcmp(instance, "/root") == 0)
+ pwd = getpwnam(instance + 1);
if (pwd == NULL)
return (as->pwd ? 0 : 1);
}
diff --git a/lib/libc/gen/authenticate.c b/lib/libc/gen/authenticate.c
index b9cd63a0928..c1b20b6e164 100644
--- a/lib/libc/gen/authenticate.c
+++ b/lib/libc/gen/authenticate.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: authenticate.c,v 1.17 2008/04/04 17:42:39 millert Exp $ */
+/* $OpenBSD: authenticate.c,v 1.18 2009/01/15 13:14:30 millert Exp $ */
/*-
* Copyright (c) 1997 Berkeley Software Design, Inc. All rights reserved.
@@ -307,7 +307,7 @@ auth_usercheck(char *name, char *style, char *type, char *password)
auth_session_t *as;
login_cap_t *lc;
struct passwd *pwd;
- char *sep, save;
+ char *slash;
if (strlcpy(namebuf, name, sizeof(namebuf)) >= sizeof(namebuf))
return (NULL);
@@ -320,16 +320,15 @@ auth_usercheck(char *name, char *style, char *type, char *password)
*style++ = '\0';
/*
- * Cope with user[./]instance. We are only using this to get
- * the class so it is okay if we strip a root instance
+ * Cope with user/instance. We are only using this to get
+ * the class so it is okay if we strip a /root instance
* The actual login script will pay attention to the instance.
*/
if ((pwd = getpwnam(name)) == NULL) {
- if ((sep = strpbrk(name, "./")) != NULL) {
- save = *sep;
- *sep = '\0';
+ if ((slash = strchr(name, '/')) != NULL) {
+ *slash = '\0';
pwd = getpwnam(name);
- *sep = save;
+ *slash = '/';
}
}
if ((lc = login_getclass(pwd ? pwd->pw_class : NULL)) == NULL)
@@ -373,7 +372,7 @@ auth_userchallenge(char *name, char *style, char *type, char **challengep)
auth_session_t *as;
login_cap_t *lc;
struct passwd *pwd;
- char *sep, save;
+ char *slash;
if (strlen(name) >= sizeof(namebuf))
return (NULL);
@@ -387,16 +386,15 @@ auth_userchallenge(char *name, char *style, char *type, char **challengep)
*style++ = '\0';
/*
- * Cope with user[./]instance. We are only using this to get
- * the class so it is okay if we strip a root instance
+ * Cope with user/instance. We are only using this to get
+ * the class so it is okay if we strip a /root instance
* The actual login script will pay attention to the instance.
*/
if ((pwd = getpwnam(name)) == NULL) {
- if ((sep = strpbrk(name, "./")) != NULL) {
- save = *sep;
- *sep = '\0';
+ if ((slash = strchr(name, '/')) != NULL) {
+ *slash = '\0';
pwd = getpwnam(name);
- *sep = save;
+ *slash = '/';
}
}
if ((lc = login_getclass(pwd ? pwd->pw_class : NULL)) == NULL)