diff options
author | Robert Griebl <griebl@gmx.de> | 2002-06-04 20:10:23 +0000 |
---|---|---|
committer | Robert Griebl <griebl@gmx.de> | 2002-06-04 20:10:23 +0000 |
commit | ea1a63a2011a44b143cc46c7d80a8152f5358e24 (patch) | |
tree | 3a71fbfa44c5a0887409c930a682c896aecb7425 | |
parent | c9aca4561ddb1165890fae0c8b921a2504c6273f (diff) | |
download | busybox-w32-ea1a63a2011a44b143cc46c7d80a8152f5358e24.tar.gz busybox-w32-ea1a63a2011a44b143cc46c7d80a8152f5358e24.tar.bz2 busybox-w32-ea1a63a2011a44b143cc46c7d80a8152f5358e24.zip |
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 ed4503caf..29e3d8673 100644 --- a/debianutils/start_stop_daemon.c +++ b/debianutils/start_stop_daemon.c | |||
@@ -16,9 +16,9 @@ | |||
16 | #include <sys/stat.h> | 16 | #include <sys/stat.h> |
17 | #include <dirent.h> | 17 | #include <dirent.h> |
18 | #include <unistd.h> | 18 | #include <unistd.h> |
19 | #include "pwd.h" | ||
20 | 19 | ||
21 | #include "busybox.h" | 20 | #include "busybox.h" |
21 | #include "pwd.h" | ||
22 | 22 | ||
23 | static int start = 0; | 23 | static int start = 0; |
24 | static int stop = 0; | 24 | static int stop = 0; |
diff --git a/include/grp.h b/include/grp.h index 191c2d4e5..12fecd02e 100644 --- a/include/grp.h +++ b/include/grp.h | |||
@@ -1,14 +1,16 @@ | |||
1 | #ifndef __CONFIG_GRP_H | 1 | #ifndef __CONFIG_GRP_H |
2 | #define __CONFIG_GRP_H | 2 | #define __CONFIG_GRP_H |
3 | 3 | ||
4 | #if defined USE_SYSTEM_PWD_GRP | 4 | #if !defined CONFIG_USE_BB_PWD_GRP |
5 | #include <grp.h> | 5 | #include_next <grp.h> |
6 | |||
6 | #else | 7 | #else |
7 | 8 | ||
8 | #include <sys/types.h> | 9 | #include <sys/types.h> |
9 | #include <features.h> | 10 | #include <features.h> |
10 | #include <stdio.h> | 11 | #include <stdio.h> |
11 | 12 | ||
13 | |||
12 | /* The group structure */ | 14 | /* The group structure */ |
13 | struct group | 15 | struct group |
14 | { | 16 | { |
diff --git a/include/pwd.h b/include/pwd.h index 2fd0ab06e..178e9e97a 100644 --- a/include/pwd.h +++ b/include/pwd.h | |||
@@ -1,8 +1,9 @@ | |||
1 | #ifndef __CONFIG_PWD_H | 1 | #ifndef __CONFIG_PWD_H |
2 | #define __CONFIG_PWD_H | 2 | #define __CONFIG_PWD_H |
3 | 3 | ||
4 | #if defined USE_SYSTEM_PWD_GRP | 4 | #if !defined CONFIG_USE_BB_PWD_GRP |
5 | #include <pwd.h> | 5 | #include_next <pwd.h> |
6 | |||
6 | #else | 7 | #else |
7 | 8 | ||
8 | #include <sys/types.h> | 9 | #include <sys/types.h> |
diff --git a/include/shadow.h b/include/shadow.h new file mode 100644 index 000000000..44e4b5878 --- /dev/null +++ b/include/shadow.h | |||
@@ -0,0 +1,81 @@ | |||
1 | /* | ||
2 | * Copyright 1988 - 1994, Julianne Frances Haugh <jockgrrl@austin.rr.com> | ||
3 | * All rights reserved. | ||
4 | * | ||
5 | * Redistribution and use in source and binary forms, with or without | ||
6 | * modification, are permitted provided that the following conditions | ||
7 | * are met: | ||
8 | * 1. Redistributions of source code must retain the above copyright | ||
9 | * notice, this list of conditions and the following disclaimer. | ||
10 | * 2. Redistributions in binary form must reproduce the above copyright | ||
11 | * notice, this list of conditions and the following disclaimer in the | ||
12 | * documentation and/or other materials provided with the distribution. | ||
13 | * 3. Neither the name of Julianne F. Haugh nor the names of its contributors | ||
14 | * may be used to endorse or promote products derived from this software | ||
15 | * without specific prior written permission. | ||
16 | * | ||
17 | * THIS SOFTWARE IS PROVIDED BY JULIE HAUGH AND CONTRIBUTORS ``AS IS'' AND | ||
18 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
19 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||
20 | * ARE DISCLAIMED. IN NO EVENT SHALL JULIE HAUGH OR CONTRIBUTORS BE LIABLE | ||
21 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
22 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | ||
23 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||
24 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | ||
25 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | ||
26 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | ||
27 | * SUCH DAMAGE. | ||
28 | */ | ||
29 | |||
30 | #ifndef __CONFIG_SHADOW_H | ||
31 | #define __CONFIG_SHADOW_H | ||
32 | |||
33 | #if !defined CONFIG_USE_BB_SHADOW | ||
34 | #include_next <shadow.h> | ||
35 | |||
36 | #else | ||
37 | |||
38 | /* | ||
39 | * This information is not derived from AT&T licensed sources. Posted | ||
40 | * to the USENET 11/88, and updated 11/90 with information from SVR4. | ||
41 | * | ||
42 | * $Id: shadow.h,v 1.1 2002/06/04 20:10:10 sandman Exp $ | ||
43 | */ | ||
44 | |||
45 | typedef long sptime; | ||
46 | |||
47 | /* | ||
48 | * Shadow password security file structure. | ||
49 | */ | ||
50 | |||
51 | struct spwd { | ||
52 | char *sp_namp; /* login name */ | ||
53 | char *sp_pwdp; /* encrypted password */ | ||
54 | sptime sp_lstchg; /* date of last change */ | ||
55 | sptime sp_min; /* minimum number of days between changes */ | ||
56 | sptime sp_max; /* maximum number of days between changes */ | ||
57 | sptime sp_warn; /* number of days of warning before password | ||
58 | expires */ | ||
59 | sptime sp_inact; /* number of days after password expires | ||
60 | until the account becomes unusable. */ | ||
61 | sptime sp_expire; /* days since 1/1/70 until account expires */ | ||
62 | unsigned long sp_flag; /* reserved for future use */ | ||
63 | }; | ||
64 | |||
65 | /* | ||
66 | * Shadow password security file functions. | ||
67 | */ | ||
68 | |||
69 | #include <stdio.h> /* for FILE */ | ||
70 | |||
71 | struct spwd *getspent(void); | ||
72 | struct spwd *sgetspent(const char *); | ||
73 | struct spwd *fgetspent(FILE *); | ||
74 | void setspent(void); | ||
75 | void endspent(void); | ||
76 | int putspent(const struct spwd *, FILE *); | ||
77 | struct spwd *getspnam(const char *name); | ||
78 | |||
79 | #endif /* CONFIG_USE_BB_SHADOW */ | ||
80 | |||
81 | #endif /* __CONFIG_SHADOW_H */ | ||
diff --git a/init/start_stop_daemon.c b/init/start_stop_daemon.c index ed4503caf..29e3d8673 100644 --- a/init/start_stop_daemon.c +++ b/init/start_stop_daemon.c | |||
@@ -16,9 +16,9 @@ | |||
16 | #include <sys/stat.h> | 16 | #include <sys/stat.h> |
17 | #include <dirent.h> | 17 | #include <dirent.h> |
18 | #include <unistd.h> | 18 | #include <unistd.h> |
19 | #include "pwd.h" | ||
20 | 19 | ||
21 | #include "busybox.h" | 20 | #include "busybox.h" |
21 | #include "pwd.h" | ||
22 | 22 | ||
23 | static int start = 0; | 23 | static int start = 0; |
24 | static int stop = 0; | 24 | static int stop = 0; |
diff --git a/libbb/my_getgrgid.c b/libbb/my_getgrgid.c index 27b671922..bf2067e46 100644 --- a/libbb/my_getgrgid.c +++ b/libbb/my_getgrgid.c | |||
@@ -21,9 +21,9 @@ | |||
21 | 21 | ||
22 | #include <stdio.h> | 22 | #include <stdio.h> |
23 | #include <string.h> | 23 | #include <string.h> |
24 | #include "libbb.h" | ||
24 | #include "pwd.h" | 25 | #include "pwd.h" |
25 | #include "grp.h" | 26 | #include "grp.h" |
26 | #include "libbb.h" | ||
27 | 27 | ||
28 | 28 | ||
29 | /* gets a groupname given a gid */ | 29 | /* gets a groupname given a gid */ |
diff --git a/libbb/my_getgrnam.c b/libbb/my_getgrnam.c index dbacf5192..f21d482c6 100644 --- a/libbb/my_getgrnam.c +++ b/libbb/my_getgrnam.c | |||
@@ -21,9 +21,9 @@ | |||
21 | 21 | ||
22 | #include <stdio.h> | 22 | #include <stdio.h> |
23 | #include <string.h> | 23 | #include <string.h> |
24 | #include "libbb.h" | ||
24 | #include "pwd.h" | 25 | #include "pwd.h" |
25 | #include "grp.h" | 26 | #include "grp.h" |
26 | #include "libbb.h" | ||
27 | 27 | ||
28 | 28 | ||
29 | /* returns a gid given a group name */ | 29 | /* returns a gid given a group name */ |
diff --git a/libbb/my_getpwnam.c b/libbb/my_getpwnam.c index 90277040e..db7f4a65f 100644 --- a/libbb/my_getpwnam.c +++ b/libbb/my_getpwnam.c | |||
@@ -21,9 +21,9 @@ | |||
21 | 21 | ||
22 | #include <stdio.h> | 22 | #include <stdio.h> |
23 | #include <string.h> | 23 | #include <string.h> |
24 | #include "libbb.h" | ||
24 | #include "pwd.h" | 25 | #include "pwd.h" |
25 | #include "grp.h" | 26 | #include "grp.h" |
26 | #include "libbb.h" | ||
27 | 27 | ||
28 | 28 | ||
29 | /* returns a uid given a username */ | 29 | /* returns a uid given a username */ |
diff --git a/libbb/my_getpwnamegid.c b/libbb/my_getpwnamegid.c index 9c45580b5..4866b9717 100644 --- a/libbb/my_getpwnamegid.c +++ b/libbb/my_getpwnamegid.c | |||
@@ -21,9 +21,9 @@ | |||
21 | 21 | ||
22 | #include <stdio.h> | 22 | #include <stdio.h> |
23 | #include <string.h> | 23 | #include <string.h> |
24 | #include "libbb.h" | ||
24 | #include "pwd.h" | 25 | #include "pwd.h" |
25 | #include "grp.h" | 26 | #include "grp.h" |
26 | #include "libbb.h" | ||
27 | 27 | ||
28 | 28 | ||
29 | 29 | ||
diff --git a/libbb/my_getpwuid.c b/libbb/my_getpwuid.c index 49bc8fb49..5236c7df3 100644 --- a/libbb/my_getpwuid.c +++ b/libbb/my_getpwuid.c | |||
@@ -21,9 +21,9 @@ | |||
21 | 21 | ||
22 | #include <stdio.h> | 22 | #include <stdio.h> |
23 | #include <string.h> | 23 | #include <string.h> |
24 | #include "libbb.h" | ||
24 | #include "pwd.h" | 25 | #include "pwd.h" |
25 | #include "grp.h" | 26 | #include "grp.h" |
26 | #include "libbb.h" | ||
27 | 27 | ||
28 | 28 | ||
29 | 29 | ||
diff --git a/networking/netstat.c b/networking/netstat.c index b083b0dd4..6e7cc5e7b 100644 --- a/networking/netstat.c +++ b/networking/netstat.c | |||
@@ -29,9 +29,9 @@ | |||
29 | #include <sys/stat.h> | 29 | #include <sys/stat.h> |
30 | #include <dirent.h> | 30 | #include <dirent.h> |
31 | #include <unistd.h> | 31 | #include <unistd.h> |
32 | #include <pwd.h> | ||
33 | #include "inet_common.h" | 32 | #include "inet_common.h" |
34 | #include "busybox.h" | 33 | #include "busybox.h" |
34 | #include "pwd.h" | ||
35 | 35 | ||
36 | #ifdef CONFIG_ROUTE | 36 | #ifdef CONFIG_ROUTE |
37 | extern void displayroutes(int noresolve, int netstatfmt); | 37 | extern void displayroutes(int noresolve, int netstatfmt); |
diff --git a/shell/ash.c b/shell/ash.c index f3b641d53..d834cc02a 100644 --- a/shell/ash.c +++ b/shell/ash.c | |||
@@ -68,6 +68,7 @@ | |||
68 | #include <sys/times.h> | 68 | #include <sys/times.h> |
69 | #include <sys/types.h> | 69 | #include <sys/types.h> |
70 | #include <sys/wait.h> | 70 | #include <sys/wait.h> |
71 | #include "busybox.h" | ||
71 | #include "pwd.h" | 72 | #include "pwd.h" |
72 | 73 | ||
73 | 74 | ||
@@ -82,7 +83,6 @@ | |||
82 | #include <termios.h> | 83 | #include <termios.h> |
83 | #endif | 84 | #endif |
84 | 85 | ||
85 | #include "busybox.h" | ||
86 | #include "cmdedit.h" | 86 | #include "cmdedit.h" |
87 | 87 | ||
88 | /* | 88 | /* |
@@ -12442,7 +12442,7 @@ findvar(struct var **vpp, const char *name) | |||
12442 | /* | 12442 | /* |
12443 | * Copyright (c) 1999 Herbert Xu <herbert@debian.org> | 12443 | * Copyright (c) 1999 Herbert Xu <herbert@debian.org> |
12444 | * This file contains code for the times builtin. | 12444 | * This file contains code for the times builtin. |
12445 | * $Id: ash.c,v 1.50 2002/05/14 23:22:06 sandman Exp $ | 12445 | * $Id: ash.c,v 1.51 2002/06/04 20:10:15 sandman Exp $ |
12446 | */ | 12446 | */ |
12447 | static int timescmd (int argc, char **argv) | 12447 | static int timescmd (int argc, char **argv) |
12448 | { | 12448 | { |