diff options
author | Robert Griebl | 2002-06-04 20:10:23 +0000 |
---|---|---|
committer | Robert Griebl | 2002-06-04 20:10:23 +0000 |
commit | ea1a63a2011a44b143cc46c7d80a8152f5358e24 (patch) | |
tree | 3a71fbfa44c5a0887409c930a682c896aecb7425 | |
parent | c9aca4561ddb1165890fae0c8b921a2504c6273f (diff) | |
download | busybox-ea1a63a2011a44b143cc46c7d80a8152f5358e24.zip busybox-ea1a63a2011a44b143cc46c7d80a8152f5358e24.tar.gz |
Fix for broken handling off BusyBox's own pwd/grp implementations
[Parts of this patch may overlap with my other two patches]
-rw-r--r-- | debianutils/start_stop_daemon.c | 2 | ||||
-rw-r--r-- | include/grp.h | 6 | ||||
-rw-r--r-- | include/pwd.h | 5 | ||||
-rw-r--r-- | include/shadow.h | 81 | ||||
-rw-r--r-- | init/start_stop_daemon.c | 2 | ||||
-rw-r--r-- | libbb/my_getgrgid.c | 2 | ||||
-rw-r--r-- | libbb/my_getgrnam.c | 2 | ||||
-rw-r--r-- | libbb/my_getpwnam.c | 2 | ||||
-rw-r--r-- | libbb/my_getpwnamegid.c | 2 | ||||
-rw-r--r-- | libbb/my_getpwuid.c | 2 | ||||
-rw-r--r-- | networking/netstat.c | 2 | ||||
-rw-r--r-- | shell/ash.c | 4 |
12 files changed, 98 insertions, 14 deletions
diff --git a/debianutils/start_stop_daemon.c b/debianutils/start_stop_daemon.c index ed4503c..29e3d86 100644 --- a/debianutils/start_stop_daemon.c +++ b/debianutils/start_stop_daemon.c @@ -16,9 +16,9 @@ #include <sys/stat.h> #include <dirent.h> #include <unistd.h> -#include "pwd.h" #include "busybox.h" +#include "pwd.h" static int start = 0; static int stop = 0; diff --git a/include/grp.h b/include/grp.h index 191c2d4..12fecd0 100644 --- a/include/grp.h +++ b/include/grp.h @@ -1,14 +1,16 @@ #ifndef __CONFIG_GRP_H #define __CONFIG_GRP_H -#if defined USE_SYSTEM_PWD_GRP -#include <grp.h> +#if !defined CONFIG_USE_BB_PWD_GRP +#include_next <grp.h> + #else #include <sys/types.h> #include <features.h> #include <stdio.h> + /* The group structure */ struct group { diff --git a/include/pwd.h b/include/pwd.h index 2fd0ab0..178e9e9 100644 --- a/include/pwd.h +++ b/include/pwd.h @@ -1,8 +1,9 @@ #ifndef __CONFIG_PWD_H #define __CONFIG_PWD_H -#if defined USE_SYSTEM_PWD_GRP -#include <pwd.h> +#if !defined CONFIG_USE_BB_PWD_GRP +#include_next <pwd.h> + #else #include <sys/types.h> diff --git a/include/shadow.h b/include/shadow.h new file mode 100644 index 0000000..44e4b58 --- /dev/null +++ b/include/shadow.h @@ -0,0 +1,81 @@ +/* + * Copyright 1988 - 1994, Julianne Frances Haugh <jockgrrl@austin.rr.com> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of Julianne F. Haugh nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY JULIE HAUGH AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL JULIE HAUGH OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#ifndef __CONFIG_SHADOW_H +#define __CONFIG_SHADOW_H + +#if !defined CONFIG_USE_BB_SHADOW +#include_next <shadow.h> + +#else + +/* + * This information is not derived from AT&T licensed sources. Posted + * to the USENET 11/88, and updated 11/90 with information from SVR4. + * + * $Id: shadow.h,v 1.1 2002/06/04 20:10:10 sandman Exp $ + */ + +typedef long sptime; + +/* + * Shadow password security file structure. + */ + +struct spwd { + char *sp_namp; /* login name */ + char *sp_pwdp; /* encrypted password */ + sptime sp_lstchg; /* date of last change */ + sptime sp_min; /* minimum number of days between changes */ + sptime sp_max; /* maximum number of days between changes */ + sptime sp_warn; /* number of days of warning before password + expires */ + sptime sp_inact; /* number of days after password expires + until the account becomes unusable. */ + sptime sp_expire; /* days since 1/1/70 until account expires */ + unsigned long sp_flag; /* reserved for future use */ +}; + +/* + * Shadow password security file functions. + */ + +#include <stdio.h> /* for FILE */ + +struct spwd *getspent(void); +struct spwd *sgetspent(const char *); +struct spwd *fgetspent(FILE *); +void setspent(void); +void endspent(void); +int putspent(const struct spwd *, FILE *); +struct spwd *getspnam(const char *name); + +#endif /* CONFIG_USE_BB_SHADOW */ + +#endif /* __CONFIG_SHADOW_H */ diff --git a/init/start_stop_daemon.c b/init/start_stop_daemon.c index ed4503c..29e3d86 100644 --- a/init/start_stop_daemon.c +++ b/init/start_stop_daemon.c @@ -16,9 +16,9 @@ #include <sys/stat.h> #include <dirent.h> #include <unistd.h> -#include "pwd.h" #include "busybox.h" +#include "pwd.h" static int start = 0; static int stop = 0; diff --git a/libbb/my_getgrgid.c b/libbb/my_getgrgid.c index 27b6719..bf2067e 100644 --- a/libbb/my_getgrgid.c +++ b/libbb/my_getgrgid.c @@ -21,9 +21,9 @@ #include <stdio.h> #include <string.h> +#include "libbb.h" #include "pwd.h" #include "grp.h" -#include "libbb.h" /* gets a groupname given a gid */ diff --git a/libbb/my_getgrnam.c b/libbb/my_getgrnam.c index dbacf51..f21d482 100644 --- a/libbb/my_getgrnam.c +++ b/libbb/my_getgrnam.c @@ -21,9 +21,9 @@ #include <stdio.h> #include <string.h> +#include "libbb.h" #include "pwd.h" #include "grp.h" -#include "libbb.h" /* returns a gid given a group name */ diff --git a/libbb/my_getpwnam.c b/libbb/my_getpwnam.c index 9027704..db7f4a6 100644 --- a/libbb/my_getpwnam.c +++ b/libbb/my_getpwnam.c @@ -21,9 +21,9 @@ #include <stdio.h> #include <string.h> +#include "libbb.h" #include "pwd.h" #include "grp.h" -#include "libbb.h" /* returns a uid given a username */ diff --git a/libbb/my_getpwnamegid.c b/libbb/my_getpwnamegid.c index 9c45580..4866b97 100644 --- a/libbb/my_getpwnamegid.c +++ b/libbb/my_getpwnamegid.c @@ -21,9 +21,9 @@ #include <stdio.h> #include <string.h> +#include "libbb.h" #include "pwd.h" #include "grp.h" -#include "libbb.h" diff --git a/libbb/my_getpwuid.c b/libbb/my_getpwuid.c index 49bc8fb..5236c7d 100644 --- a/libbb/my_getpwuid.c +++ b/libbb/my_getpwuid.c @@ -21,9 +21,9 @@ #include <stdio.h> #include <string.h> +#include "libbb.h" #include "pwd.h" #include "grp.h" -#include "libbb.h" diff --git a/networking/netstat.c b/networking/netstat.c index b083b0d..6e7cc5e 100644 --- a/networking/netstat.c +++ b/networking/netstat.c @@ -29,9 +29,9 @@ #include <sys/stat.h> #include <dirent.h> #include <unistd.h> -#include <pwd.h> #include "inet_common.h" #include "busybox.h" +#include "pwd.h" #ifdef CONFIG_ROUTE extern void displayroutes(int noresolve, int netstatfmt); diff --git a/shell/ash.c b/shell/ash.c index f3b641d..d834cc0 100644 --- a/shell/ash.c +++ b/shell/ash.c @@ -68,6 +68,7 @@ #include <sys/times.h> #include <sys/types.h> #include <sys/wait.h> +#include "busybox.h" #include "pwd.h" @@ -82,7 +83,6 @@ #include <termios.h> #endif -#include "busybox.h" #include "cmdedit.h" /* @@ -12442,7 +12442,7 @@ findvar(struct var **vpp, const char *name) /* * Copyright (c) 1999 Herbert Xu <herbert@debian.org> * This file contains code for the times builtin. - * $Id: ash.c,v 1.50 2002/05/14 23:22:06 sandman Exp $ + * $Id: ash.c,v 1.51 2002/06/04 20:10:15 sandman Exp $ */ static int timescmd (int argc, char **argv) { |