diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/applets.h | 5 | ||||
-rw-r--r-- | include/libbb.h | 7 | ||||
-rw-r--r-- | include/usage.h | 64 |
3 files changed, 73 insertions, 3 deletions
diff --git a/include/applets.h b/include/applets.h index e12f6027c..328848478 100644 --- a/include/applets.h +++ b/include/applets.h | |||
@@ -70,6 +70,7 @@ USE_CHATTR(APPLET(chattr, _BB_DIR_BIN, _BB_SUID_NEVER)) | |||
70 | USE_CHGRP(APPLET(chgrp, _BB_DIR_BIN, _BB_SUID_NEVER)) | 70 | USE_CHGRP(APPLET(chgrp, _BB_DIR_BIN, _BB_SUID_NEVER)) |
71 | USE_CHMOD(APPLET(chmod, _BB_DIR_BIN, _BB_SUID_NEVER)) | 71 | USE_CHMOD(APPLET(chmod, _BB_DIR_BIN, _BB_SUID_NEVER)) |
72 | USE_CHOWN(APPLET(chown, _BB_DIR_BIN, _BB_SUID_NEVER)) | 72 | USE_CHOWN(APPLET(chown, _BB_DIR_BIN, _BB_SUID_NEVER)) |
73 | USE_CHPST(APPLET(chpst, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | ||
73 | USE_CHROOT(APPLET(chroot, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) | 74 | USE_CHROOT(APPLET(chroot, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) |
74 | USE_CHVT(APPLET(chvt, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 75 | USE_CHVT(APPLET(chvt, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
75 | USE_CKSUM(APPLET(cksum, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 76 | USE_CKSUM(APPLET(cksum, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
@@ -106,6 +107,8 @@ USE_ED(APPLET(ed, _BB_DIR_BIN, _BB_SUID_NEVER)) | |||
106 | USE_FEATURE_GREP_EGREP_ALIAS(APPLET_NOUSAGE(egrep, grep, _BB_DIR_BIN, _BB_SUID_NEVER)) | 107 | USE_FEATURE_GREP_EGREP_ALIAS(APPLET_NOUSAGE(egrep, grep, _BB_DIR_BIN, _BB_SUID_NEVER)) |
107 | USE_EJECT(APPLET(eject, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 108 | USE_EJECT(APPLET(eject, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
108 | USE_ENV(APPLET(env, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 109 | USE_ENV(APPLET(env, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
110 | USE_ENVDIR(APPLET_ODDNAME(envdir, chpst, _BB_DIR_USR_BIN, _BB_SUID_NEVER, envdir)) | ||
111 | USE_ENVUIDGID(APPLET_ODDNAME(envuidgid, chpst, _BB_DIR_USR_BIN, _BB_SUID_NEVER, envuidgid)) | ||
109 | USE_ETHER_WAKE(APPLET_ODDNAME(ether-wake, ether_wake, _BB_DIR_USR_BIN, _BB_SUID_NEVER, ether_wake)) | 112 | USE_ETHER_WAKE(APPLET_ODDNAME(ether-wake, ether_wake, _BB_DIR_USR_BIN, _BB_SUID_NEVER, ether_wake)) |
110 | USE_EXPR(APPLET(expr, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 113 | USE_EXPR(APPLET(expr, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
111 | USE_FAKEIDENTD(APPLET(fakeidentd, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) | 114 | USE_FAKEIDENTD(APPLET(fakeidentd, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) |
@@ -244,12 +247,14 @@ USE_SETCONSOLE(APPLET(setconsole, _BB_DIR_SBIN, _BB_SUID_NEVER)) | |||
244 | USE_SETKEYCODES(APPLET(setkeycodes, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 247 | USE_SETKEYCODES(APPLET(setkeycodes, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
245 | USE_SETLOGCONS(APPLET(setlogcons, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) | 248 | USE_SETLOGCONS(APPLET(setlogcons, _BB_DIR_USR_SBIN, _BB_SUID_NEVER)) |
246 | USE_SETSID(APPLET(setsid, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 249 | USE_SETSID(APPLET(setsid, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
250 | USE_SETUIDGID(APPLET_ODDNAME(setuidgid, chpst, _BB_DIR_USR_BIN, _BB_SUID_NEVER, setuidgid)) | ||
247 | USE_FEATURE_SH_IS_ASH(APPLET_NOUSAGE(sh, ash, _BB_DIR_BIN, _BB_SUID_NEVER)) | 251 | USE_FEATURE_SH_IS_ASH(APPLET_NOUSAGE(sh, ash, _BB_DIR_BIN, _BB_SUID_NEVER)) |
248 | USE_FEATURE_SH_IS_HUSH(APPLET_NOUSAGE(sh, hush, _BB_DIR_BIN, _BB_SUID_NEVER)) | 252 | USE_FEATURE_SH_IS_HUSH(APPLET_NOUSAGE(sh, hush, _BB_DIR_BIN, _BB_SUID_NEVER)) |
249 | USE_FEATURE_SH_IS_LASH(APPLET_NOUSAGE(sh, lash, _BB_DIR_BIN, _BB_SUID_NEVER)) | 253 | USE_FEATURE_SH_IS_LASH(APPLET_NOUSAGE(sh, lash, _BB_DIR_BIN, _BB_SUID_NEVER)) |
250 | USE_FEATURE_SH_IS_MSH(APPLET_NOUSAGE(sh, msh, _BB_DIR_BIN, _BB_SUID_NEVER)) | 254 | USE_FEATURE_SH_IS_MSH(APPLET_NOUSAGE(sh, msh, _BB_DIR_BIN, _BB_SUID_NEVER)) |
251 | USE_SHA1SUM(APPLET_ODDNAME(sha1sum, md5_sha1_sum, _BB_DIR_USR_BIN, _BB_SUID_NEVER, sha1sum)) | 255 | USE_SHA1SUM(APPLET_ODDNAME(sha1sum, md5_sha1_sum, _BB_DIR_USR_BIN, _BB_SUID_NEVER, sha1sum)) |
252 | USE_SLEEP(APPLET(sleep, _BB_DIR_BIN, _BB_SUID_NEVER)) | 256 | USE_SLEEP(APPLET(sleep, _BB_DIR_BIN, _BB_SUID_NEVER)) |
257 | USE_SOFTLIMIT(APPLET_ODDNAME(softlimit, chpst, _BB_DIR_USR_BIN, _BB_SUID_NEVER, softlimit)) | ||
253 | USE_SORT(APPLET(sort, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) | 258 | USE_SORT(APPLET(sort, _BB_DIR_USR_BIN, _BB_SUID_NEVER)) |
254 | USE_START_STOP_DAEMON(APPLET_ODDNAME(start-stop-daemon, start_stop_daemon, _BB_DIR_SBIN, _BB_SUID_NEVER, start_stop_daemon)) | 259 | USE_START_STOP_DAEMON(APPLET_ODDNAME(start-stop-daemon, start_stop_daemon, _BB_DIR_SBIN, _BB_SUID_NEVER, start_stop_daemon)) |
255 | USE_STAT(APPLET(stat, _BB_DIR_BIN, _BB_SUID_NEVER)) | 260 | USE_STAT(APPLET(stat, _BB_DIR_BIN, _BB_SUID_NEVER)) |
diff --git a/include/libbb.h b/include/libbb.h index b4516e99a..222b4acec 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
@@ -488,12 +488,13 @@ extern void renew_current_security_context(void); | |||
488 | extern void set_current_security_context(security_context_t sid); | 488 | extern void set_current_security_context(security_context_t sid); |
489 | #endif | 489 | #endif |
490 | extern int run_parts(char **args, const unsigned char test_mode, char **env); | 490 | extern int run_parts(char **args, const unsigned char test_mode, char **env); |
491 | extern int restricted_shell ( const char *shell ); | 491 | extern int restricted_shell(const char *shell); |
492 | extern void setup_environment ( const char *shell, int loginshell, int changeenv, const struct passwd *pw ); | 492 | extern void setup_environment(const char *shell, int loginshell, int changeenv, const struct passwd *pw); |
493 | extern int correct_password ( const struct passwd *pw ); | 493 | extern int correct_password(const struct passwd *pw); |
494 | extern char *pw_encrypt(const char *clear, const char *salt); | 494 | extern char *pw_encrypt(const char *clear, const char *salt); |
495 | extern int obscure(const char *old, const char *newval, const struct passwd *pwdp); | 495 | extern int obscure(const char *old, const char *newval, const struct passwd *pwdp); |
496 | 496 | ||
497 | extern void xsetenv(const char *key, const char *value); | ||
497 | extern int xopen(const char *pathname, int flags); | 498 | extern int xopen(const char *pathname, int flags); |
498 | extern int xopen3(const char *pathname, int flags, int mode); | 499 | extern int xopen3(const char *pathname, int flags, int mode); |
499 | extern void xread(int fd, void *buf, size_t count); | 500 | extern void xread(int fd, void *buf, size_t count); |
diff --git a/include/usage.h b/include/usage.h index 40676c113..34b0566cd 100644 --- a/include/usage.h +++ b/include/usage.h | |||
@@ -215,6 +215,70 @@ | |||
215 | "ls -l /tmp/foo\n" \ | 215 | "ls -l /tmp/foo\n" \ |
216 | "-r--r--r-- 1 root root 0 Apr 12 18:25 /tmp/foo\n" | 216 | "-r--r--r-- 1 root root 0 Apr 12 18:25 /tmp/foo\n" |
217 | 217 | ||
218 | #define chpst_trivial_usage \ | ||
219 | "[-vP012] [-u user[:group]] [-U user[:group]] [-e dir] " \ | ||
220 | "[-/ dir] [-n nice] [-m bytes] [-d bytes] [-o files] " \ | ||
221 | "[-p processes] [-f bytes] [-c bytes] prog args" | ||
222 | #define chpst_full_usage \ | ||
223 | "Change the process state and run specified program.\n\n" \ | ||
224 | "-u user[:grp] set uid and gid\n" \ | ||
225 | "-U user[:grp] set environment variables UID and GID\n" \ | ||
226 | "-e dir set environment variables as specified by files\n" \ | ||
227 | " in the directory: file=1st_line_of_file\n" \ | ||
228 | "-/ dir chroot to dir\n" \ | ||
229 | "-n inc add inc to nice value\n" \ | ||
230 | "-m bytes limit data segment, stack segment, locked physical pages,\n" \ | ||
231 | " and total of all segment per process to bytes bytes each\n" \ | ||
232 | "-d bytes limit data segment\n" \ | ||
233 | "-o n limit the number of open file descriptors per process to n\n" \ | ||
234 | "-p n limit number of processes per uid to n\n" \ | ||
235 | "-f bytes limit output file size to bytes bytes\n" \ | ||
236 | "-c bytes limit core file size to bytes bytes\n" \ | ||
237 | "-v verbose\n" \ | ||
238 | "-P run prog in a new process group\n" \ | ||
239 | "-0 close standard input\n" \ | ||
240 | "-1 close standard output\n" \ | ||
241 | "-2 close standard error" | ||
242 | #define setuidgid_trivial_usage \ | ||
243 | "account prog args" | ||
244 | #define setuidgid_full_usage \ | ||
245 | "Sets uid and gid to account's uid and gid, removing all supplementary\n" \ | ||
246 | "groups, then runs prog" | ||
247 | #define envuidgid_trivial_usage \ | ||
248 | "account prog args" | ||
249 | #define envuidgid_full_usage \ | ||
250 | "Sets $UID to account's uid and $GID to account's gid, then runs prog" | ||
251 | #define envdir_trivial_usage \ | ||
252 | "dir prog args" | ||
253 | #define envdir_full_usage \ | ||
254 | "Sets various environment variables as specified by files\n" \ | ||
255 | "in the directory dir, then runs prog" | ||
256 | #define softlimit_trivial_usage \ | ||
257 | "[-a allbytes] [-c corebytes] [-d databytes] [-f filebytes] " \ | ||
258 | "[-l lockbytes] [-m membytes] [-o openfiles] [-p processes] " \ | ||
259 | "[-r residentbytes] [-s stackbytes] [-t cpusecs] prog args" | ||
260 | #define softlimit_full_usage \ | ||
261 | "Sets soft resource limits as specified by options, then runs prog\n" \ | ||
262 | "\n" \ | ||
263 | "-m n Same as -d n -s n -l n -a n\n" \ | ||
264 | "-d n Limit the data segment per process to n bytes\n" \ | ||
265 | "-s n Limit the stack segment per process to n bytes\n" \ | ||
266 | "-l n Limit the locked physical pages per process to n bytes\n" \ | ||
267 | "-a n Limit the total of all segments per process to n bytes\n" \ | ||
268 | "-o n Limit the number of open file descriptors per process to n\n" \ | ||
269 | "-p n Limit the number of processes per uid to n\n" \ | ||
270 | "Options controlling file sizes:\n" \ | ||
271 | "-f n Limit output file sizes to n bytes\n" \ | ||
272 | "-c n Limit core file sizes to n bytes\n" \ | ||
273 | "Efficiency opts:\n" \ | ||
274 | "-r n Limit the resident set size to n bytes. This limit is not\n" \ | ||
275 | " enforced unless physical memory is full\n" \ | ||
276 | "-t n Limit the CPU time to n seconds. This limit is not enforced\n" \ | ||
277 | " except that the process receives a SIGXCPU signal after n seconds\n" \ | ||
278 | "\n" \ | ||
279 | "Some options may have no effect on some operating systems\n" \ | ||
280 | "n may be =, indicating that soft limit should be set equal to hard limit" | ||
281 | |||
218 | #define chroot_trivial_usage \ | 282 | #define chroot_trivial_usage \ |
219 | "NEWROOT [COMMAND...]" | 283 | "NEWROOT [COMMAND...]" |
220 | #define chroot_full_usage \ | 284 | #define chroot_full_usage \ |