Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 1 | /* vi: set sw=4 ts=4: */ |
| 2 | /* |
| 3 | * env implementation for busybox |
| 4 | * |
| 5 | * Copyright (c) 1988, 1993, 1994 |
Denys Vlasenko | e4dcba1 | 2010-10-28 18:57:19 +0200 | [diff] [blame] | 6 | * The Regents of the University of California. All rights reserved. |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 7 | * |
Denys Vlasenko | 0ef64bd | 2010-08-16 20:14:46 +0200 | [diff] [blame] | 8 | * Licensed under GPLv2 or later, see file LICENSE in this source tree. |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 9 | * |
| 10 | * Original copyright notice is retained at the end of this file. |
| 11 | * |
Eric Andersen | cb81e64 | 2003-07-14 21:21:08 +0000 | [diff] [blame] | 12 | * Modified for BusyBox by Erik Andersen <andersen@codepoet.org> |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 13 | */ |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 14 | /* Mar 16, 2003 Manuel Novoa III (mjn3@codepoet.org) |
| 15 | * |
| 16 | * Fixed bug involving exit return codes if execvp fails. Also added |
| 17 | * output error checking. |
| 18 | */ |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 19 | /* |
Eric Andersen | 7ff33f1 | 2004-04-16 15:02:10 +0000 | [diff] [blame] | 20 | * Modified by Vladimir Oleynik <dzo@simtreas.ru> (C) 2003 |
Eric Andersen | aff114c | 2004-04-14 17:51:38 +0000 | [diff] [blame] | 21 | * - correct "-" option usage |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 22 | * - multiple "-u unsetenv" support |
| 23 | * - GNU long option support |
Denis Vlasenko | 4092082 | 2006-10-03 20:28:06 +0000 | [diff] [blame] | 24 | * - use xfunc_error_retval |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 25 | */ |
Denys Vlasenko | af3f420 | 2016-11-23 14:46:56 +0100 | [diff] [blame] | 26 | //config:config ENV |
Denys Vlasenko | b097a84 | 2018-12-28 03:20:17 +0100 | [diff] [blame] | 27 | //config: bool "env (4 kb)" |
Denys Vlasenko | af3f420 | 2016-11-23 14:46:56 +0100 | [diff] [blame] | 28 | //config: default y |
| 29 | //config: help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 30 | //config: env is used to set an environment variable and run |
| 31 | //config: a command; without options it displays the current |
| 32 | //config: environment. |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 33 | |
Denys Vlasenko | af3f420 | 2016-11-23 14:46:56 +0100 | [diff] [blame] | 34 | //applet:IF_ENV(APPLET_NOEXEC(env, env, BB_DIR_USR_BIN, BB_SUID_DROP, env)) |
| 35 | |
| 36 | //kbuild:lib-$(CONFIG_ENV) += env.o |
| 37 | |
| 38 | /* BB_AUDIT SUSv3 compliant */ |
| 39 | /* http://www.opengroup.org/onlinepubs/007904975/utilities/env.html */ |
Denis Vlasenko | b730474 | 2008-10-20 08:15:51 +0000 | [diff] [blame] | 40 | |
Pere Orga | 3442538 | 2011-03-31 14:43:25 +0200 | [diff] [blame] | 41 | //usage:#define env_trivial_usage |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 42 | //usage: "[-i0] [-u NAME]... [-] [NAME=VALUE]... [PROG ARGS]" |
Denys Vlasenko | 6b6826f | 2021-06-13 01:08:48 +0200 | [diff] [blame] | 43 | // The "-" can occur only once (unlike, say, -i): it terminates option processing, |
| 44 | // so if it is followed by another "-" arg (or any option-looking arg), |
| 45 | // that arg will be taken as PROG (or even as NAME=VALUE, example: "-z=QWE"). |
Pere Orga | 3442538 | 2011-03-31 14:43:25 +0200 | [diff] [blame] | 46 | //usage:#define env_full_usage "\n\n" |
Denys Vlasenko | 6b6826f | 2021-06-13 01:08:48 +0200 | [diff] [blame] | 47 | //usage: "Print current environment or run PROG after setting up environment\n" |
| 48 | //usage: "\n -, -i Start with empty environment" |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 49 | //usage: "\n -0 NUL terminated output" |
Denys Vlasenko | 6b6826f | 2021-06-13 01:08:48 +0200 | [diff] [blame] | 50 | //usage: "\n -u NAME Remove variable from environment" |
Pere Orga | 3442538 | 2011-03-31 14:43:25 +0200 | [diff] [blame] | 51 | |
Denis Vlasenko | b6adbf1 | 2007-05-26 19:00:18 +0000 | [diff] [blame] | 52 | #include "libbb.h" |
| 53 | |
Denis Vlasenko | 9b49a5e | 2007-10-11 10:05:36 +0000 | [diff] [blame] | 54 | int env_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
Denis Vlasenko | a60f84e | 2008-07-05 09:18:54 +0000 | [diff] [blame] | 55 | int env_main(int argc UNUSED_PARAM, char **argv) |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 56 | { |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 57 | unsigned opts; |
Eric Andersen | 1b1942f | 2003-11-07 11:20:21 +0000 | [diff] [blame] | 58 | llist_t *unset_env = NULL; |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 59 | |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 60 | opts = getopt32long(argv, "+i0u:*", |
Denys Vlasenko | 036585a | 2017-08-08 16:38:18 +0200 | [diff] [blame] | 61 | "ignore-environment\0" No_argument "i" |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 62 | "null\0" No_argument "0" |
Denys Vlasenko | 036585a | 2017-08-08 16:38:18 +0200 | [diff] [blame] | 63 | "unset\0" Required_argument "u" |
| 64 | , &unset_env |
| 65 | ); |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 66 | argv += optind; |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 67 | if (argv[0] && LONE_DASH(argv[0])) { |
| 68 | opts |= 1; |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 69 | ++argv; |
Matt Kraai | 5b44f48 | 2001-05-11 14:26:29 +0000 | [diff] [blame] | 70 | } |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 71 | if (opts & 1) { |
Denis Vlasenko | f3c2d13 | 2008-11-11 21:32:39 +0000 | [diff] [blame] | 72 | clearenv(); |
| 73 | } |
| 74 | while (unset_env) { |
| 75 | char *var = llist_pop(&unset_env); |
| 76 | /* This does not handle -uVAR=VAL |
| 77 | * (coreutils _sets_ the variable in that case): */ |
| 78 | /*unsetenv(var);*/ |
| 79 | /* This does, but uses somewhan undocumented feature that |
| 80 | * putenv("name_without_equal_sign") unsets the variable: */ |
| 81 | putenv(var); |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 82 | } |
| 83 | |
Bernhard Reutner-Fischer | d591a36 | 2006-08-20 17:35:13 +0000 | [diff] [blame] | 84 | while (*argv && (strchr(*argv, '=') != NULL)) { |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 85 | if (putenv(*argv) < 0) { |
James Byrne | 6937487 | 2019-07-02 11:35:03 +0200 | [diff] [blame] | 86 | bb_simple_perror_msg_and_die("putenv"); |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 87 | } |
| 88 | ++argv; |
| 89 | } |
| 90 | |
Denys Vlasenko | 41ddd9f | 2010-06-25 01:46:53 +0200 | [diff] [blame] | 91 | if (argv[0]) { |
Pascal Bellard | 21e8e8d | 2010-07-04 00:57:03 +0200 | [diff] [blame] | 92 | BB_EXECVP_or_die(argv); |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 93 | } |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 94 | |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 95 | if (environ) { /* clearenv() may set environ == NULL! */ |
| 96 | char **ep; |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 97 | opts = (opts & 2) ? 0 : '\n'; |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 98 | for (ep = environ; *ep; ep++) { |
Denys Vlasenko | c113796 | 2021-06-17 13:39:05 +0200 | [diff] [blame] | 99 | printf("%s%c", *ep, opts); |
Denys Vlasenko | f4fee41 | 2009-11-12 14:52:47 +0100 | [diff] [blame] | 100 | } |
Manuel Novoa III | cad5364 | 2003-03-19 09:13:01 +0000 | [diff] [blame] | 101 | } |
| 102 | |
Bernhard Reutner-Fischer | 636a1f8 | 2008-05-19 09:29:47 +0000 | [diff] [blame] | 103 | fflush_stdout_and_exit(EXIT_SUCCESS); |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 104 | } |
| 105 | |
| 106 | /* |
| 107 | * Copyright (c) 1988, 1993, 1994 |
Eric Andersen | 05df91a | 2003-07-28 07:42:19 +0000 | [diff] [blame] | 108 | * The Regents of the University of California. All rights reserved. |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 109 | * |
| 110 | * Redistribution and use in source and binary forms, with or without |
| 111 | * modification, are permitted provided that the following conditions |
| 112 | * are met: |
| 113 | * 1. Redistributions of source code must retain the above copyright |
| 114 | * notice, this list of conditions and the following disclaimer. |
| 115 | * 2. Redistributions in binary form must reproduce the above copyright |
| 116 | * notice, this list of conditions and the following disclaimer in the |
| 117 | * documentation and/or other materials provided with the distribution. |
| 118 | * |
Denys Vlasenko | e4dcba1 | 2010-10-28 18:57:19 +0200 | [diff] [blame] | 119 | * 3. BSD Advertising Clause omitted per the July 22, 1999 licensing change |
| 120 | * ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 121 | * |
| 122 | * 4. Neither the name of the University nor the names of its contributors |
| 123 | * may be used to endorse or promote products derived from this software |
| 124 | * without specific prior written permission. |
| 125 | * |
Denys Vlasenko | 95f7953 | 2017-08-02 14:26:33 +0200 | [diff] [blame] | 126 | * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ''AS IS'' AND |
Eric Andersen | 84e229c | 2001-03-29 22:48:33 +0000 | [diff] [blame] | 127 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 128 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| 129 | * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE |
| 130 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| 131 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |
| 132 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
| 133 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
| 134 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
| 135 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
| 136 | * SUCH DAMAGE. |
| 137 | */ |