4 * Based on libselinux 1.33.1
5 * Port to BusyBox Hiroshi Shinji <shiroshi@my.email.ne.jp>
7 * Licensed under GPLv2, see file LICENSE in this source tree.
10 //usage:#define setenforce_trivial_usage
11 //usage: "[Enforcing | Permissive | 1 | 0]"
12 //usage:#define setenforce_full_usage ""
16 /* These strings are arranged so that odd ones
17 * result in security_setenforce(1) being done,
18 * the rest will do security_setenforce(0) */
19 static const char *const setenforce_cmd
[] = {
27 int setenforce_main(int argc
, char **argv
) MAIN_EXTERNALLY_VISIBLE
;
28 int setenforce_main(int argc UNUSED_PARAM
, char **argv
)
32 if (!argv
[1] || argv
[2])
37 for (i
= 0; setenforce_cmd
[i
]; i
++) {
38 if (strcasecmp(argv
[1], setenforce_cmd
[i
]) != 0)
40 rc
= security_setenforce(i
& 1);
42 bb_perror_msg_and_die("setenforce() failed");