diff options
author | David Woodhouse <David.Woodhouse@intel.com> | 2010-12-11 23:39:54 +0000 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2010-12-12 02:51:44 +0000 |
commit | cd25e41d2d044556e024f0292a17c5ec3cc7987b (patch) | |
tree | c0476b19bde961f483ceac1039d883708ec43872 /src | |
parent | e2f5dc151e2e79058e93924e6d35510557f0535d (diff) |
Remove ALT_CONFIG_ROOT_ONLY build option, effectively making it always true.
We *never* want the Exim user to be able to specify arbitrary configuration
files. Don't let them build it that way.
(Bug 1044, CVE-2010-4345)
Diffstat (limited to 'src')
-rw-r--r-- | src/src/EDITME | 32 | ||||
-rw-r--r-- | src/src/config.h.defaults | 1 | ||||
-rw-r--r-- | src/src/exim.c | 39 |
3 files changed, 21 insertions, 51 deletions
diff --git a/src/src/EDITME b/src/src/EDITME index 285e5b656..f8ba7cfe3 100644 --- a/src/src/EDITME +++ b/src/src/EDITME @@ -458,35 +458,21 @@ FIXED_NEVER_USERS=root #------------------------------------------------------------------------------ # The -C option allows Exim to be run with an alternate runtime configuration -# file. When this is used by root or the Exim user, root privilege is retained -# by the binary (for any other caller, it is dropped). You can restrict the -# location of alternate configurations by defining a prefix below. Any file -# used with -C must then start with this prefix (except that /dev/null is also -# permitted if the caller is root, because that is used in the install script). -# If the prefix specifies a directory that is owned by root, a compromise of -# the Exim account does not permit arbitrary alternate configurations to be -# used. The prefix can be more restrictive than just a directory (the second -# example). +# file. When this is used by root, root privilege is retained by the binary +# (for any other caller including the Exim user, it is dropped). You can +# restrict the location of alternate configurations by defining a prefix below. +# Any file used with -C must then start with this prefix (except that /dev/null +# is also permitted if the caller is root, because that is used in the install +# script). If the prefix specifies a directory that is owned by root, a +# compromise of the Exim account does not permit arbitrary alternate +# configurations to be used. The prefix can be more restrictive than just a +# directory (the second example). # ALT_CONFIG_PREFIX=/some/directory/ # ALT_CONFIG_PREFIX=/some/directory/exim.conf- #------------------------------------------------------------------------------ -# If you uncomment the following line, only root may use the -C or -D options -# without losing root privilege. The -C option specifies an alternate runtime -# configuration file, and the -D option changes macro values in the runtime -# configuration. Uncommenting this line restricts what can be done with these -# options. A call to receive a message (either one-off or via a daemon) cannot -# successfully continue to deliver it, because the re-exec of Exim to regain -# root privilege will fail, owing to the use of -C or -D by the Exim user. -# However, you can still use -C for testing (as root) if you do separate Exim -# calls for receiving a message and subsequently delivering it. - -# ALT_CONFIG_ROOT_ONLY=yes - - -#------------------------------------------------------------------------------ # Uncommenting this option disables the use of the -D command line option, # which changes the values of macros in the runtime configuration file. # This is another protection against somebody breaking into the Exim account. diff --git a/src/src/config.h.defaults b/src/src/config.h.defaults index 9f0eba0fe..9e4556e8c 100644 --- a/src/src/config.h.defaults +++ b/src/src/config.h.defaults @@ -13,7 +13,6 @@ in config.h unless some value is defined in Local/Makefile. If there is data, it's a default value. */ #define ALT_CONFIG_PREFIX -#define ALT_CONFIG_ROOT_ONLY #define APPENDFILE_MODE 0600 #define APPENDFILE_DIRECTORY_MODE 0700 diff --git a/src/src/exim.c b/src/src/exim.c index 0d8f24492..0d9378d46 100644 --- a/src/src/exim.c +++ b/src/src/exim.c @@ -3031,11 +3031,11 @@ if (setgroups(0, NULL) != 0) /* If the configuration file name has been altered by an argument on the command line (either a new file name or a macro definition) and the caller is -not root or the exim user, or if this is a filter testing run, remove any -setuid privilege the program has, and run as the underlying user. +not root, or if this is a filter testing run, remove any setuid privilege the +program has and run as the underlying user. -If ALT_CONFIG_ROOT_ONLY is defined, the exim user is locked out of this, which -severely restricts the use of -C for some purposes. +The exim user is locked out of this, which severely restricts the use of -C +for some purposes. Otherwise, set the real ids to the effective values (should be root unless run from inetd, which it can either be root or the exim uid, if one is configured). @@ -3049,9 +3049,6 @@ configuration file changes and macro definitions haven't happened. */ if (( /* EITHER */ (!trusted_config || macros != NULL) && /* Config changed, and */ real_uid != root_uid && /* Not root, and */ - #ifndef ALT_CONFIG_ROOT_ONLY /* (when not locked out) */ - real_uid != exim_uid && /* Not exim, and */ - #endif !running_in_test_harness /* Not fudged */ ) || /* OR */ expansion_test /* expansion testing */ @@ -3239,15 +3236,12 @@ else } /* Handle the case when we have removed the setuid privilege because of -C or --D. This means that the caller of Exim was not root, and, provided that -ALT_CONFIG_ROOT_ONLY is not defined, was not the Exim user that is built into -the binary. +-D. This means that the caller of Exim was not root. -If ALT_CONFIG_ROOT_ONLY is not defined, there is a problem if it turns out we -were running as the exim user defined in the configuration file (different to -the one in the binary). The sysadmin may expect this case to retain privilege -because "the binary was called by the Exim user", but it hasn't, because of the -order in which it handles this stuff. There are two possibilities: +There is a problem if we were running as the Exim user. The sysadmin may +expect this case to retain privilege because "the binary was called by the +Exim user", but it hasn't, because either the -D option set macros, or the +-C option set a non-default configuration file. There are two possibilities: (1) If deliver_drop_privilege is set, Exim is not going to re-exec in order to do message deliveries. Thus, the fact that it is running as a @@ -3259,27 +3253,18 @@ order in which it handles this stuff. There are two possibilities: (2) If deliver_drop_privilege is not set, the configuration won't work as apparently intended, and so we log a panic message. In order to retain - root for -C or -D, the caller must either be root or the Exim user - defined in the binary (when deliver_drop_ privilege is false). - -If ALT_CONFIG_ROOT_ONLY is defined, we don't know whether we were called by the -built-in exim user or one defined in the configuration. In either event, -re-enable log processing, assuming the sysadmin knows what they are doing. */ + root for -C or -D, the caller must be root (when deliver_drop_privilege + is false). */ if (removed_privilege && (!trusted_config || macros != NULL) && real_uid == exim_uid) { - #ifdef ALT_CONFIG_ROOT_ONLY - really_exim = TRUE; /* let logging work normally */ - #else - if (deliver_drop_privilege) really_exim = TRUE; /* let logging work normally */ else log_write(0, LOG_MAIN|LOG_PANIC, - "exim user (uid=%d) is defined only at runtime; privilege lost for %s", + "exim user lost privilege for using %s option", (int)exim_uid, trusted_config? "-D" : "-C"); - #endif } /* Start up Perl interpreter if Perl support is configured and there is a |