user_attr.h revision 12788:c71b0e8f856c
1/*
2 * CDDL HEADER START
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#ifndef	_USER_ATTR_H
26#define	_USER_ATTR_H
27
28#ifdef	__cplusplus
29extern "C" {
30#endif
31
32
33#include <sys/types.h>
34#include <secdb.h>
35
36
37struct __FILE;		/* structure tag for type FILE defined in stdio.h */
38
39/*
40 * Some macros used internally by the nsswitch code
41 */
42#define	USERATTR_FILENAME		"/etc/user_attr"
43#define	USERATTR_DB_NAME		"user_attr.org_dir"
44#define	USERATTR_DB_NCOL		5	/* total columns */
45#define	USERATTR_DB_NKEYCOL		2	/* total searchable columns */
46#define	USERATTR_DB_TBL			"user_attr_tbl"
47#define	USERATTR_NAME_DEFAULT_KW	"nobody"
48
49#define	USERATTR_COL0_KW		"name"
50#define	USERATTR_COL1_KW		"qualifier"
51#define	USERATTR_COL2_KW		"res1"
52#define	USERATTR_COL3_KW		"res2"
53#define	USERATTR_COL4_KW		"attr"
54
55#define	DEF_LIMITPRIV			"PRIV_LIMIT="
56#define	DEF_DFLTPRIV			"PRIV_DEFAULT="
57
58/*
59 * indices of searchable columns
60 */
61#define	USERATTR_KEYCOL0		0	/* name */
62#define	USERATTR_KEYCOL1		1	/* qualifier */
63
64/*
65 * Key words used in the user_attr database
66 */
67#define	USERATTR_LOCK_KW		"lock"
68#define	USERATTR_LOCK_LOCKED_KW		"locked"
69#define	USERATTR_LOCK_OPEN_KW		"open"
70#define	USERATTR_LOCK_FIXED_KW		"fixed"
71#define	USERATTR_GEN_KW			"gen"
72#define	USERATTR_GEN_AUTOMATIC_KW	"automatic"
73#define	USERATTR_GEN_MANUAL_KW		"manual"
74#define	USERATTR_GEN_SYSDEF_KW		"sysdef"
75#define	USERATTR_PROFILES_KW		"profiles"
76#define	USERATTR_PROFILES_NONE_KW	"none"
77#define	USERATTR_ROLES_KW		"roles"
78#define	USERATTR_ROLES_NONE_KW		"none"
79#define	USERATTR_DEFAULTPROJ_KW		"project"
80#define	USERATTR_IDLETIME_KW		"idletime"
81#define	USERATTR_IDLECMD_KW		"idlecmd"
82#define	USERATTR_IDLECMD_LOCK_KW	"lock"
83#define	USERATTR_IDLECMD_LOGOUT_KW	"logout"
84#define	USERATTR_TYPE_KW		"type"
85#define	USERATTR_TYPE_NORMAL_KW		"normal"
86#define	USERATTR_TYPE_ADMIN_KW		"admin"
87#define	USERATTR_TYPE_NONADMIN_KW	"role"
88#define	USERATTR_AUTHS_KW		"auths"
89#define	USERATTR_LIMPRIV_KW		"limitpriv"
90#define	USERATTR_DFLTPRIV_KW		"defaultpriv"
91#define	USERATTR_LOCK_AFTER_RETRIES_KW	"lock_after_retries"
92#define	USERATTR_CLEARANCE		"clearance"
93#define	USERATTR_LABELVIEW		"labelview"
94#define	USERATTR_LABELVIEW_EXTERNAL	"external"
95#define	USERATTR_LABELVIEW_HIDESL	"hidesl"
96#define	USERATTR_HIDESL			USERATTR_LABELVIEW_HIDESL
97#define	USERATTR_LABELVIEW_INTERNAL	"internal"
98#define	USERATTR_LABELVIEW_SHOWSL	"showsl"
99#define	USERATTR_LABELTRANS		"labeltrans"
100#define	USERATTR_LOCK_NO		"no"
101#define	USERATTR_LOCK_YES		"yes"
102#define	USERATTR_MINLABEL		"min_label"
103#define	USERATTR_PASSWD			"password"
104#define	USERATTR_PASSWD_AUTOMATIC	"automatic"
105#define	USERATTR_PASSWD_MANUAL		"manual"
106#define	USERATTR_TYPE_ROLE		USERATTR_TYPE_NONADMIN_KW
107#define	USERATTR_AUDIT_FLAGS_KW		"audit_flags"
108
109
110/*
111 * Nsswitch representation of user attributes.
112 */
113typedef struct userstr_s {
114	char   *name;		/* user name */
115	char   *qualifier;	/* reserved for future use */
116	char   *res1;		/* reserved for future use */
117	char   *res2;		/* reserved for future use */
118	char   *attr;		/* string of key-value pair attributes */
119} userstr_t;
120
121/*
122 * API representation of user attributes.
123 */
124typedef struct userattr_s {
125	char   *name;		/* user name */
126	char   *qualifier;	/* reserved for future use */
127	char   *res1;		/* reserved for future use */
128	char   *res2;		/* reserved for future use */
129	kva_t  *attr;		/* array of key-value pair attributes */
130} userattr_t;
131
132#ifdef	__STDC__
133extern userattr_t *getusernam(const char *);
134extern userattr_t *getuseruid(uid_t uid);
135extern userattr_t *getuserattr(void);
136extern userattr_t *fgetuserattr(struct __FILE *);
137extern void setuserattr(void);
138extern void enduserattr(void);
139extern void free_userattr(userattr_t *);
140
141#else				/* not __STDC__ */
142
143extern userattr_t *getusernam();
144extern userattr_t *getuseruid();
145extern userattr_t *getuserattr();
146extern userattr_t *fgetuserattr();
147extern void setuserattr();
148extern void enduserattr();
149extern void free_userattr();
150#endif
151
152#ifdef	__cplusplus
153}
154#endif
155
156#endif	/* _USER_ATTR_H */
157