| /* vi: set sw=4 ts=4: */ |
| /* |
| * setpriv implementation for busybox based on linux-utils-ng 2.29 |
| * |
| * Copyright (C) 2017 by <assafgordon@gmail.com> |
| * |
| * Licensed under GPLv2 or later, see file LICENSE in this source tree. |
| * |
| */ |
| //config:config SETPRIV |
| //config: bool "setpriv" |
| //config: default y |
| //config: select PLATFORM_LINUX |
| //config: select LONG_OPTS |
| //config: help |
| //config: Run a program with different Linux privilege settings. |
| //config: Requires kernel >= 3.5 |
| |
| //applet:IF_SETPRIV(APPLET(setpriv, BB_DIR_BIN, BB_SUID_DROP)) |
| |
| //kbuild:lib-$(CONFIG_SETPRIV) += setpriv.o |
| |
| //usage:#define setpriv_trivial_usage |
| //usage: "[OPTIONS] PROG [ARGS]" |
| //usage:#define setpriv_full_usage "\n\n" |
| //usage: "Run PROG with different privilege settings\n" |
| //usage: "\n--nnp,--no-new-privs Ignore setuid/setgid bits and file capabilities" |
| |
| //setpriv from util-linux 2.28: |
| // -d, --dump show current state (and do not exec anything) |
| // --nnp, --no-new-privs disallow granting new privileges |
| // --inh-caps <caps,...> set inheritable capabilities |
| // --bounding-set <caps> set capability bounding set |
| // --ruid <uid> set real uid |
| // --euid <uid> set effective uid |
| // --rgid <gid> set real gid |
| // --egid <gid> set effective gid |
| // --reuid <uid> set real and effective uid |
| // --regid <gid> set real and effective gid |
| // --clear-groups clear supplementary groups |
| // --keep-groups keep supplementary groups |
| // --groups <group,...> set supplementary groups |
| // --securebits <bits> set securebits |
| // --selinux-label <label> set SELinux label |
| // --apparmor-profile <pr> set AppArmor profile |
| |
| #include <sys/prctl.h> |
| #include "libbb.h" |
| |
| #ifndef PR_SET_NO_NEW_PRIVS |
| #define PR_SET_NO_NEW_PRIVS 38 |
| #endif |
| |
| int setpriv_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
| int setpriv_main(int argc UNUSED_PARAM, char **argv) |
| { |
| static const char setpriv_longopts[] ALIGN1 = |
| "nnp\0" No_argument "\xff" |
| "no-new-privs\0" No_argument "\xff" |
| ; |
| int opts; |
| |
| opt_complementary = "-1"; |
| applet_long_options = setpriv_longopts; |
| opts = getopt32(argv, ""); |
| if (opts) { |
| if (prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0)) |
| bb_simple_perror_msg_and_die("prctl: NO_NEW_PRIVS"); |
| } |
| |
| argv += optind; |
| BB_EXECVP_or_die(argv); |
| } |