3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21 /*
22 * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
23 */
24
25 #include <stdio.h>
26 #include <stdlib.h>
27 #include <strings.h>
28 #include <auth_attr.h>
29 #include <prof_attr.h>
30 #include <user_attr.h>
31 #include <project.h>
32 #include <secdb.h>
33 #include <pwd.h>
34 #include <unistd.h>
35 #include <priv.h>
36 #include <errno.h>
37 #include <ctype.h>
38 #include <nss.h>
39 #include <bsm/libbsm.h>
40 #include <tsol/label.h>
41 #include "funcs.h"
42 #include "messages.h"
163 len = strlen(key) + strlen(val) + 2;
164 arg = malloc(len);
165
166 (void) snprintf(arg, len, "%s=%s", key, val);
167 argv[(*index)++] = "-K";
168 argv[(*index)++] = arg;
169 }
170 }
171
172 /*
173 * Propose a default value for a key and get the actual value back.
174 * If the proposed default value is NULL, return the actual value set.
175 * The key argument is the user_attr key.
176 */
177 char *
178 getsetdefval(const char *key, char *dflt)
179 {
180 int i;
181
182 for (i = 0; i < NKEYS; i++)
183 if (strcmp(keys[i].key, key) == 0)
184 if (keys[i].newvalue != NULL)
185 return (keys[i].newvalue);
186 else
187 return (keys[i].newvalue = dflt);
188 return (NULL);
189 }
190
191 char *
192 getusertype(char *cmdname)
193 {
194 static char usertype[MAX_TYPE_LENGTH];
195 char *cmd;
196
197 if (cmd = strrchr(cmdname, '/'))
198 ++cmd;
199 else
200 cmd = cmdname;
201
202 /* get user type based on the program name */
203 if (strncmp(cmd, CMD_PREFIX_USER,
204 strlen(CMD_PREFIX_USER)) == 0)
205 strcpy(usertype, USERATTR_TYPE_NORMAL_KW);
206 else
207 strcpy(usertype, USERATTR_TYPE_NONADMIN_KW);
208
209 return (usertype);
210 }
211
212 int
213 is_role(char *usertype)
214 {
215 if (strcmp(usertype, USERATTR_TYPE_NONADMIN_KW) == 0)
216 return (1);
217 /* not a role */
|
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21 /*
22 * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
23 * Copyright (c) 2013 RackTop Systems.
24 */
25
26 #include <stdio.h>
27 #include <stdlib.h>
28 #include <strings.h>
29 #include <auth_attr.h>
30 #include <prof_attr.h>
31 #include <user_attr.h>
32 #include <project.h>
33 #include <secdb.h>
34 #include <pwd.h>
35 #include <unistd.h>
36 #include <priv.h>
37 #include <errno.h>
38 #include <ctype.h>
39 #include <nss.h>
40 #include <bsm/libbsm.h>
41 #include <tsol/label.h>
42 #include "funcs.h"
43 #include "messages.h"
164 len = strlen(key) + strlen(val) + 2;
165 arg = malloc(len);
166
167 (void) snprintf(arg, len, "%s=%s", key, val);
168 argv[(*index)++] = "-K";
169 argv[(*index)++] = arg;
170 }
171 }
172
173 /*
174 * Propose a default value for a key and get the actual value back.
175 * If the proposed default value is NULL, return the actual value set.
176 * The key argument is the user_attr key.
177 */
178 char *
179 getsetdefval(const char *key, char *dflt)
180 {
181 int i;
182
183 for (i = 0; i < NKEYS; i++)
184 if (strcmp(keys[i].key, key) == 0) {
185 if (keys[i].newvalue != NULL)
186 return (keys[i].newvalue);
187 else
188 return (keys[i].newvalue = dflt);
189 }
190 return (NULL);
191 }
192
193 char *
194 getusertype(char *cmdname)
195 {
196 static char usertype[MAX_TYPE_LENGTH];
197 char *cmd;
198
199 if ((cmd = strrchr(cmdname, '/')))
200 ++cmd;
201 else
202 cmd = cmdname;
203
204 /* get user type based on the program name */
205 if (strncmp(cmd, CMD_PREFIX_USER,
206 strlen(CMD_PREFIX_USER)) == 0)
207 strcpy(usertype, USERATTR_TYPE_NORMAL_KW);
208 else
209 strcpy(usertype, USERATTR_TYPE_NONADMIN_KW);
210
211 return (usertype);
212 }
213
214 int
215 is_role(char *usertype)
216 {
217 if (strcmp(usertype, USERATTR_TYPE_NONADMIN_KW) == 0)
218 return (1);
219 /* not a role */
|