From: Andrew G. Morgan Date: Sun, 11 Nov 2001 07:25:37 +0000 (+0000) Subject: Relevant BUGIDs: 476990 X-Git-Tag: Linux-PAM-0-76~57 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=61a4ef28627e5b08a0857754ce62ab0d7325c6cf;p=linux-pam Relevant BUGIDs: 476990 Purpose of commit: new feature Commit summary: --------------- support -ve process priorities (and include superuser in this feature) --- diff --git a/CHANGELOG b/CHANGELOG index 1d268f92..fde46993 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -49,6 +49,9 @@ bug report - outstanding bugs are listed here: 0.76: please submit patches for this section with actual code/doc patches! +* pam_limits can handle negative priority limits now (which can apply + to the superuser too) - base on patch from Nalin. (Bug 476990 - + agmorgan) * db3 is now recognized as a libdb candidate (Bug 435764 - agmorgan) * more changes (extracted from redhat version) courtesy of Harald Welte (Bugs pam_limits=436061, pam_lastlog=436060, diff --git a/doc/modules/pam_limits.sgml b/doc/modules/pam_limits.sgml index 52b8771f..961f0b55 100644 --- a/doc/modules/pam_limits.sgml +++ b/doc/modules/pam_limits.sgml @@ -1,7 +1,7 @@ @@ -140,8 +140,11 @@ together.

diff --git a/modules/pam_limits/README b/modules/pam_limits/README index d2998b00..c0dba581 100644 --- a/modules/pam_limits/README +++ b/modules/pam_limits/README @@ -37,6 +37,7 @@ Where: - as - address space limit - maxlogins - max number of logins for this user - maxsyslogins - max number of logins on the system + - priority - lower the priority by given value (value can be -ve) - locks - max locked files (Linux 2.4 and higher) Note, if you specify a type of '-' but neglect to supply the item and diff --git a/modules/pam_limits/pam_limits.c b/modules/pam_limits/pam_limits.c index 99c45626..303ed661 100644 --- a/modules/pam_limits/pam_limits.c +++ b/modules/pam_limits/pam_limits.c @@ -135,8 +135,9 @@ static int _pam_parse(int argc, const char **argv, struct pam_limit_s *pl) # define LIMITS_FILE "/etc/security/limits.conf" #endif -#define LIMIT_ERR 1 /* error setting a limit */ -#define LOGIN_ERR 2 /* too many logins err */ +#define LIMITED_OK 0 /* limit setting appeared to work */ +#define LIMIT_ERR 1 /* error setting a limit */ +#define LOGIN_ERR 2 /* too many logins err */ /* checks if a user is on a list of members of the GID 0 group */ static int is_on_list(char * const *list, const char *member) @@ -341,6 +342,7 @@ static void process_limit(int source, const char *lim_type, */ limit_value = strtol(lim_value, endptr, 10); + /* special case value when limiting logins */ if (limit_value == 0 && value_orig == *endptr) { /* no chars read */ if (strcmp(lim_value,"-") != 0) { _pam_log(LOG_DEBUG,"wrong limit value '%s'", lim_value); @@ -390,10 +392,9 @@ static void process_limit(int source, const char *lim_type, } } } else { - if (limit_item == LIMIT_PRI) { - /* additional check */ - pl->priority = ((limit_value>0)?limit_value:0); - } else { + /* recent kernels support negative priority limits (=raise priority) */ + + if (limit_item != LIMIT_PRI) { if (pl->login_limit_def < source) { return; } else { @@ -503,34 +504,53 @@ static int parse_config_file(const char *uname, int ctrl, return PAM_SUCCESS; } -static int setup_limits(const char * uname, int ctrl, struct pam_limit_s *pl) +static int setup_limits(const char * uname, uid_t uid, int ctrl, + struct pam_limit_s *pl) { int i; - int retval = PAM_SUCCESS; - - for (i=0; ipriority > 0) { + if (ctrl & PAM_DEBUG_ARG) { + _pam_log(LOG_DEBUG, "user '%s' has UID 0 - no limits imposed", + uname); + } + pl->priority = 0; + } + } + + for (i=0, status=LIMITED_OK; ilimits[i].limit.rlim_cur > pl->limits[i].limit.rlim_max) pl->limits[i].limit.rlim_cur = pl->limits[i].limit.rlim_max; if (!pl->supported[i]) { /* skip it if its not known to the system */ continue; } - retval |= setrlimit(i, &pl->limits[i].limit); + status |= setrlimit(i, &pl->limits[i].limit); } - if (retval != PAM_SUCCESS) + if (status) { retval = LIMIT_ERR; + } - retval=setpriority(PRIO_PROCESS, 0, pl->priority); - - if (retval != PAM_SUCCESS) + status = setpriority(PRIO_PROCESS, 0, pl->priority); + if (status != 0) { retval = LIMIT_ERR; + } - if (pl->login_limit > 0) { - if (check_logins(uname, pl->login_limit, ctrl, pl) == LOGIN_ERR) + if (uid == 0) { + D(("skip login limit check for uid=0")); + } else if (pl->login_limit > 0) { + if (check_logins(uname, pl->login_limit, ctrl, pl) == LOGIN_ERR) { retval |= LOGIN_ERR; - } else if (pl->login_limit == 0) + } + } else if (pl->login_limit == 0) { retval |= LOGIN_ERR; + } + return retval; } @@ -563,14 +583,6 @@ PAM_EXTERN int pam_sm_open_session(pam_handle_t *pamh, int flags, return PAM_SESSION_ERR; } - /* do not impose limits on UID 0 accounts */ - if (!pwd->pw_uid) { - if (ctrl & PAM_DEBUG_ARG) - _pam_log(LOG_DEBUG, "user '%s' have UID 0 - no limits imposed", - user_name); - return PAM_SUCCESS; - } - retval = init_limits(&pl); if (retval != PAM_SUCCESS) { _pam_log(LOG_WARNING, "cannot initialize"); @@ -587,10 +599,11 @@ PAM_EXTERN int pam_sm_open_session(pam_handle_t *pamh, int flags, return PAM_IGNORE; } - if (ctrl & PAM_DO_SETREUID) + if (ctrl & PAM_DO_SETREUID) { setreuid(pwd->pw_uid, -1); - retval = setup_limits(pwd->pw_name, ctrl, &pl); - if (retval & LOGIN_ERR) { + } + retval = setup_limits(pwd->pw_name, pwd->pw_uid, ctrl, &pl); + if (retval != LIMITED_OK) { return PAM_PERM_DENIED; }