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.
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.
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]
22 * Copyright 2014 Garrett D'Amore <garrett@damore.org>
23 * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
34 #include <sys/types.h>
38 struct __FILE
; /* structure tag for type FILE defined in stdio.h */
41 * Some macros used internally by the nsswitch code
43 #define USERATTR_FILENAME "/etc/user_attr"
44 #define USERATTR_DB_NAME "user_attr.org_dir"
45 #define USERATTR_DB_NCOL 5 /* total columns */
46 #define USERATTR_DB_NKEYCOL 2 /* total searchable columns */
47 #define USERATTR_DB_TBL "user_attr_tbl"
48 #define USERATTR_NAME_DEFAULT_KW "nobody"
50 #define USERATTR_COL0_KW "name"
51 #define USERATTR_COL1_KW "qualifier"
52 #define USERATTR_COL2_KW "res1"
53 #define USERATTR_COL3_KW "res2"
54 #define USERATTR_COL4_KW "attr"
56 #define DEF_LIMITPRIV "PRIV_LIMIT="
57 #define DEF_DFLTPRIV "PRIV_DEFAULT="
60 * indices of searchable columns
62 #define USERATTR_KEYCOL0 0 /* name */
63 #define USERATTR_KEYCOL1 1 /* qualifier */
66 * Key words used in the user_attr database
68 #define USERATTR_LOCK_KW "lock"
69 #define USERATTR_LOCK_LOCKED_KW "locked"
70 #define USERATTR_LOCK_OPEN_KW "open"
71 #define USERATTR_LOCK_FIXED_KW "fixed"
72 #define USERATTR_GEN_KW "gen"
73 #define USERATTR_GEN_AUTOMATIC_KW "automatic"
74 #define USERATTR_GEN_MANUAL_KW "manual"
75 #define USERATTR_GEN_SYSDEF_KW "sysdef"
76 #define USERATTR_PROFILES_KW "profiles"
77 #define USERATTR_PROFILES_NONE_KW "none"
78 #define USERATTR_ROLES_KW "roles"
79 #define USERATTR_ROLES_NONE_KW "none"
80 #define USERATTR_DEFAULTPROJ_KW "project"
81 #define USERATTR_IDLETIME_KW "idletime"
82 #define USERATTR_IDLECMD_KW "idlecmd"
83 #define USERATTR_IDLECMD_LOCK_KW "lock"
84 #define USERATTR_IDLECMD_LOGOUT_KW "logout"
85 #define USERATTR_TYPE_KW "type"
86 #define USERATTR_TYPE_NORMAL_KW "normal"
87 #define USERATTR_TYPE_ADMIN_KW "admin"
88 #define USERATTR_TYPE_NONADMIN_KW "role"
89 #define USERATTR_AUTHS_KW "auths"
90 #define USERATTR_LIMPRIV_KW "limitpriv"
91 #define USERATTR_DFLTPRIV_KW "defaultpriv"
92 #define USERATTR_LOCK_AFTER_RETRIES_KW "lock_after_retries"
93 #define USERATTR_CLEARANCE "clearance"
94 #define USERATTR_LABELVIEW "labelview"
95 #define USERATTR_LABELVIEW_EXTERNAL "external"
96 #define USERATTR_LABELVIEW_HIDESL "hidesl"
97 #define USERATTR_HIDESL USERATTR_LABELVIEW_HIDESL
98 #define USERATTR_LABELVIEW_INTERNAL "internal"
99 #define USERATTR_LABELVIEW_SHOWSL "showsl"
100 #define USERATTR_LABELTRANS "labeltrans"
101 #define USERATTR_LOCK_NO "no"
102 #define USERATTR_LOCK_YES "yes"
103 #define USERATTR_MINLABEL "min_label"
104 #define USERATTR_PASSWD "password"
105 #define USERATTR_PASSWD_AUTOMATIC "automatic"
106 #define USERATTR_PASSWD_MANUAL "manual"
107 #define USERATTR_TYPE_ROLE USERATTR_TYPE_NONADMIN_KW
108 #define USERATTR_AUDIT_FLAGS_KW "audit_flags"
112 * Nsswitch representation of user attributes.
114 typedef struct userstr_s
{
115 char *name
; /* user name */
116 char *qualifier
; /* reserved for future use */
117 char *res1
; /* reserved for future use */
118 char *res2
; /* reserved for future use */
119 char *attr
; /* string of key-value pair attributes */
123 * API representation of user attributes.
125 typedef struct userattr_s
{
126 char *name
; /* user name */
127 char *qualifier
; /* reserved for future use */
128 char *res1
; /* reserved for future use */
129 char *res2
; /* reserved for future use */
130 kva_t
*attr
; /* array of key-value pair attributes */
133 extern userattr_t
*getusernam(const char *);
134 extern userattr_t
*getuseruid(uid_t uid
);
135 extern userattr_t
*getuserattr(void);
136 extern userattr_t
*fgetuserattr(struct __FILE
*);
137 extern void setuserattr(void);
138 extern void enduserattr(void);
139 extern void free_userattr(userattr_t
*);
145 #endif /* _USER_ATTR_H */