2
* Copyright (c) 2008, 2010 Todd C. Miller <Todd.Miller@courtesan.com>
4
* Permission to use, copy, modify, and distribute this software for any
5
* purpose with or without fee is hereby granted, provided that the above
6
* copyright notice and this permission notice appear in all copies.
8
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19
#include <sys/types.h>
20
#include <sys/resource.h>
30
#endif /* STDC_HEADERS */
38
#ifdef HAVE_GETUSERATTR
40
#ifndef HAVE_SETRLIMIT64
41
# define setrlimit64(a, b) setrlimit(a, b)
42
# define rlimit64 rlimit
43
# define rlim64_t rlim_t
44
# define RLIM64_INFINITY RLIM_INFINITY
45
#endif /* HAVE_SETRLIMIT64 */
47
#ifndef RLIM_SAVED_MAX
48
# define RLIM_SAVED_MAX RLIM64_INFINITY
58
static struct aix_limit aix_limits[] = {
59
{ RLIMIT_FSIZE, S_UFSIZE, S_UFSIZE_HARD, 512 },
60
{ RLIMIT_CPU, S_UCPU, S_UCPU_HARD, 1 },
61
{ RLIMIT_DATA, S_UDATA, S_UDATA_HARD, 512 },
62
{ RLIMIT_STACK, S_USTACK, S_USTACK_HARD, 512 },
63
{ RLIMIT_RSS, S_URSS, S_URSS_HARD, 512 },
64
{ RLIMIT_CORE, S_UCORE, S_UCORE_HARD, 512 },
65
{ RLIMIT_NOFILE, S_UNOFILE, S_UNOFILE_HARD, 1 }
69
aix_getlimit(user, lim, valp)
76
if (getuserattr(user, lim, &val, SEC_INT) != 0 &&
77
getuserattr("default", lim, &val, SEC_INT) != 0) {
92
if (setuserdb(S_READ) != 0)
93
error(1, "unable to open userdb");
96
* For each resource limit, get the soft/hard values for the user
97
* and set those values via setrlimit64(). Must be run as euid 0.
99
for (n = 0; n < sizeof(aix_limits) / sizeof(aix_limits[0]); n++) {
101
* We have two strategies, depending on whether or not the
102
* hard limit has been defined.
104
if (aix_getlimit(user, aix_limits[n].hard, &val) == 0) {
105
rlim.rlim_max = val == -1 ? RLIM64_INFINITY : val * aix_limits[n].factor;
106
if (aix_getlimit(user, aix_limits[n].soft, &val) == 0)
107
rlim.rlim_cur = val == -1 ? RLIM64_INFINITY : val * aix_limits[n].factor;
109
rlim.rlim_cur = rlim.rlim_max; /* soft not specd, use hard */
111
/* No hard limit set, try soft limit. */
112
if (aix_getlimit(user, aix_limits[n].soft, &val) == 0)
113
rlim.rlim_cur = val == -1 ? RLIM64_INFINITY : val * aix_limits[n].factor;
115
/* Set hard limit per AIX /etc/security/limits documentation. */
116
switch (aix_limits[n].resource) {
119
rlim.rlim_max = rlim.rlim_cur;
122
rlim.rlim_max = RLIM_SAVED_MAX;
125
rlim.rlim_max = RLIM64_INFINITY;
129
(void)setrlimit64(aix_limits[n].resource, &rlim);
134
#ifdef HAVE_SETAUTHDB
136
* Look up administrative domain for user (SYSTEM in /etc/security/user) and
137
* set it as the default for the process. This ensures that password and
138
* group lookups are made against the correct source (files, NIS, LDAP, etc).
147
if (setuserdb(S_READ) != 0)
148
error(1, "unable to open userdb");
149
if (getuserattr(user, S_REGISTRY, ®istry, SEC_CHAR) == 0) {
150
if (setauthdb(registry, NULL) != 0)
151
error(1, "unable to switch to registry \"%s\" for %s",
159
* Restore the saved administrative domain, if any.
164
if (setauthdb(NULL, NULL) != 0)
165
error(1, "unable to restore registry");
170
aix_prep_user(user, tty)
177
/* set usrinfo, like login(1) does */
178
len = easprintf(&info, "NAME=%s%cLOGIN=%s%cLOGNAME=%s%cTTY=%s%c",
179
user, '\0', user, '\0', user, '\0', tty ? tty : "", '\0');
180
(void)usrinfo(SETUINFO, info, len);
183
#ifdef HAVE_SETAUTHDB
184
/* set administrative domain */
188
/* set resource limits */
191
#endif /* HAVE_GETUSERATTR */