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");