aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-02-26 10:01:18 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-02-26 10:01:18 +0100
commit26ffe81188a5555824bc86b1953517f7ba4524a9 (patch)
tree79b05ca36349747f5bf5eee0cfcf87a29db5f233
parentfd686a262fa34b71900b010b4b31d7e2e3f3385c (diff)
downloadbusybox-w32-26ffe81188a5555824bc86b1953517f7ba4524a9.tar.gz
busybox-w32-26ffe81188a5555824bc86b1953517f7ba4524a9.tar.bz2
busybox-w32-26ffe81188a5555824bc86b1953517f7ba4524a9.zip
su: move restricted_shell into su.c (the only user)
function old new delta su_main 448 468 +20 buffer_fill_and_print 179 196 +17 scriptreplay_main 205 208 +3 localcmd 275 277 +2 hash_find 233 234 +1 devmem_main 469 463 -6 install_main 724 716 -8 setusershell 11 - -11 find_pair 187 169 -18 restricted_shell 49 - -49 ------------------------------------------------------------------------------ (add/remove: 0/3 grow/shrink: 5/3 up/down: 43/-92) Total: -49 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--include/libbb.h1
-rw-r--r--libbb/Kbuild1
-rw-r--r--libbb/restricted_shell.c46
-rw-r--r--loginutils/su.c19
4 files changed, 18 insertions, 49 deletions
diff --git a/include/libbb.h b/include/libbb.h
index 98080e841..515e995d0 100644
--- a/include/libbb.h
+++ b/include/libbb.h
@@ -1139,7 +1139,6 @@ extern void selinux_preserve_fcontext(int fdesc) FAST_FUNC;
1139#define selinux_preserve_fcontext(fdesc) ((void)0) 1139#define selinux_preserve_fcontext(fdesc) ((void)0)
1140#endif 1140#endif
1141extern void selinux_or_die(void) FAST_FUNC; 1141extern void selinux_or_die(void) FAST_FUNC;
1142extern int restricted_shell(const char *shell) FAST_FUNC;
1143 1142
1144/* setup_environment: 1143/* setup_environment:
1145 * if chdir pw->pw_dir: ok: else if to_tmp == 1: goto /tmp else: goto / or die 1144 * if chdir pw->pw_dir: ok: else if to_tmp == 1: goto /tmp else: goto / or die
diff --git a/libbb/Kbuild b/libbb/Kbuild
index c205ceb4c..49cf4b8ad 100644
--- a/libbb/Kbuild
+++ b/libbb/Kbuild
@@ -84,7 +84,6 @@ lib-y += read.o
84lib-y += read_key.o 84lib-y += read_key.o
85lib-y += recursive_action.o 85lib-y += recursive_action.o
86lib-y += remove_file.o 86lib-y += remove_file.o
87lib-y += restricted_shell.o
88lib-y += run_shell.o 87lib-y += run_shell.o
89lib-y += safe_gethostname.o 88lib-y += safe_gethostname.o
90lib-y += safe_poll.o 89lib-y += safe_poll.o
diff --git a/libbb/restricted_shell.c b/libbb/restricted_shell.c
deleted file mode 100644
index 2a5073f03..000000000
--- a/libbb/restricted_shell.c
+++ /dev/null
@@ -1,46 +0,0 @@
1/* vi: set sw=4 ts=4: */
2/*
3 * Copyright 1989 - 1991, Julianne Frances Haugh <jockgrrl@austin.rr.com>
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * 3. Neither the name of Julianne F. Haugh nor the names of its contributors
15 * may be used to endorse or promote products derived from this software
16 * without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY JULIE HAUGH AND CONTRIBUTORS ``AS IS'' AND
19 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 * ARE DISCLAIMED. IN NO EVENT SHALL JULIE HAUGH OR CONTRIBUTORS BE LIABLE
22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28 * SUCH DAMAGE.
29 */
30
31#include "libbb.h"
32
33/* Return 1 if SHELL is a restricted shell (one not returned by
34 getusershell), else 0, meaning it is a standard shell. */
35int FAST_FUNC restricted_shell(const char *shell)
36{
37 char *line;
38
39 setusershell();
40 while ((line = getusershell())) {
41 if (*line != '#' && strcmp(line, shell) == 0)
42 return 0;
43 }
44 endusershell();
45 return 1;
46}
diff --git a/loginutils/su.c b/loginutils/su.c
index 6356631b8..af25655fd 100644
--- a/loginutils/su.c
+++ b/loginutils/su.c
@@ -8,6 +8,23 @@
8#include "libbb.h" 8#include "libbb.h"
9#include <syslog.h> 9#include <syslog.h>
10 10
11#if ENABLE_FEATURE_SU_CHECKS_SHELLS
12/* Return 1 if SHELL is a restricted shell (one not returned by
13 getusershell), else 0, meaning it is a standard shell. */
14static int restricted_shell(const char *shell)
15{
16 char *line;
17
18 /*setusershell(); - getusershell does it itself*/
19 while ((line = getusershell()) != NULL) {
20 if (/* *line != '#' && */ strcmp(line, shell) == 0)
21 return 0;
22 }
23 endusershell();
24 return 1;
25}
26#endif
27
11#define SU_OPT_mp (3) 28#define SU_OPT_mp (3)
12#define SU_OPT_l (4) 29#define SU_OPT_l (4)
13 30
@@ -89,7 +106,7 @@ int su_main(int argc UNUSED_PARAM, char **argv)
89 opt_shell = getenv("SHELL"); 106 opt_shell = getenv("SHELL");
90 107
91#if ENABLE_FEATURE_SU_CHECKS_SHELLS 108#if ENABLE_FEATURE_SU_CHECKS_SHELLS
92 if (opt_shell && cur_uid && restricted_shell(pw->pw_shell)) { 109 if (opt_shell && cur_uid != 0 && restricted_shell(pw->pw_shell)) {
93 /* The user being su'd to has a nonstandard shell, and so is 110 /* The user being su'd to has a nonstandard shell, and so is
94 probably a uucp account or has restricted access. Don't 111 probably a uucp account or has restricted access. Don't
95 compromise the account by allowing access with a standard 112 compromise the account by allowing access with a standard