1
1

Merge branch '1789_remove_setuid_getuid_checks'

* 1789_remove_setuid_getuid_checks:
  Ticket #1789: Removed obsolete checks for setuid(), getuid(), etc
Этот коммит содержится в:
Ilia Maslakov 2009-12-15 18:15:58 +03:00
родитель 72c30eda5f d579bb7877
Коммит a45d0ba6c2
4 изменённых файлов: 1 добавлений и 28 удалений

Просмотреть файл

@ -161,11 +161,10 @@ dnl
AC_CHECK_FUNCS([\ AC_CHECK_FUNCS([\
atoll \ atoll \
cfgetospeed \ cfgetospeed \
getegid geteuid getgid getsid getuid \
initgroups isascii \ initgroups isascii \
memcpy memset \ memcpy memset \
putenv \ putenv \
setreuid setuid statfs strerror sysconf \ setreuid statfs strerror sysconf \
tcgetattr tcsetattr truncate \ tcgetattr tcsetattr truncate \
]) ])

Просмотреть файл

@ -64,19 +64,6 @@
# define __attribute__(x) # define __attribute__(x)
#endif #endif
#ifndef HAVE_GETUID
# define getuid() 0
#endif
#ifndef HAVE_GETGID
# define getgid() 0
#endif
#ifndef HAVE_GETEUID
# define geteuid() getuid()
#endif
#ifndef HAVE_GETEGID
# define getegid() getgid()
#endif
#ifdef ENABLE_NLS #ifdef ENABLE_NLS
# include <libintl.h> # include <libintl.h>
# define _(String) gettext (String) # define _(String) gettext (String)

Просмотреть файл

@ -198,9 +198,7 @@ static void
init_subshell_child (const char *pty_name) init_subshell_child (const char *pty_name)
{ {
const char *init_file = NULL; const char *init_file = NULL;
#ifdef HAVE_GETSID
pid_t mc_sid; pid_t mc_sid;
#endif /* HAVE_GETSID */
(void) pty_name; (void) pty_name;
setsid (); /* Get a fresh terminal session */ setsid (); /* Get a fresh terminal session */
@ -235,7 +233,6 @@ init_subshell_child (const char *pty_name)
/* and the user's startup file may do a `cd' command anyway */ /* and the user's startup file may do a `cd' command anyway */
chdir (home_dir); /* FIXME? What about when we re-run the subshell? */ chdir (home_dir); /* FIXME? What about when we re-run the subshell? */
#ifdef HAVE_GETSID
/* Set MC_SID to prevent running one mc from another */ /* Set MC_SID to prevent running one mc from another */
mc_sid = getsid (0); mc_sid = getsid (0);
if (mc_sid != -1) { if (mc_sid != -1) {
@ -244,7 +241,6 @@ init_subshell_child (const char *pty_name)
(long) mc_sid); (long) mc_sid);
putenv (g_strdup (sid_str)); putenv (g_strdup (sid_str));
} }
#endif /* HAVE_GETSID */
switch (subshell_type) { switch (subshell_type) {
case BASH: case BASH:
@ -320,7 +316,6 @@ init_subshell_child (const char *pty_name)
} }
#ifdef HAVE_GETSID
/* /*
* Check MC_SID to prevent running one mc from another. * Check MC_SID to prevent running one mc from another.
* Return: * Return:
@ -362,7 +357,6 @@ check_sid (void)
return 1; return 1;
} }
#endif /* HAVE_GETSID */
/* /*
@ -381,7 +375,6 @@ init_subshell (void)
static char pty_name[BUF_SMALL]; static char pty_name[BUF_SMALL];
char precmd[BUF_SMALL]; char precmd[BUF_SMALL];
#ifdef HAVE_GETSID
switch (check_sid ()) { switch (check_sid ()) {
case 1: case 1:
use_subshell = FALSE; use_subshell = FALSE;
@ -391,7 +384,6 @@ init_subshell (void)
midnight_shutdown = 1; midnight_shutdown = 1;
return; return;
} }
#endif /* HAVE_GETSID */
/* Take the current (hopefully pristine) tty mode and make */ /* Take the current (hopefully pristine) tty mode and make */
/* a raw mode based on it now, before we do anything else with it */ /* a raw mode based on it now, before we do anything else with it */

Просмотреть файл

@ -1007,13 +1007,8 @@ do_auth (const char *username, const char *password)
#endif #endif
#endif #endif
#if defined (HAVE_SETUID)
if (setuid (this->pw_uid)) if (setuid (this->pw_uid))
return 0; return 0;
#elif defined (HAVE_SETREUID)
if (setreuid (this->pw_uid, this->pw_uid))
return 0;
#endif
/* If the setuid call failed, then deny access */ /* If the setuid call failed, then deny access */
/* This should fix the problem on those machines with strange setups */ /* This should fix the problem on those machines with strange setups */