GETUSERATTR(3SECDB) Security Attributes Database Library Functions

NAME


getuserattr, getusernam, getuseruid, free_userattr, setuserattr,
enduserattr, fgetuserattr - get user_attr entry

SYNOPSIS


cc [ flag... ] file... -lsecdb -lsocket -lnsl [ library... ]
#include <user_attr.h>

userattr_t *getuserattr(void);


userattr_t *getusernam(const char *name);


userattr_t *getuseruid(uid_t uid);


void free_userattr(userattr_t *userattr);


void setuserattr(void);


void enduserattr(void);


userattr_t *fgetuserattr(FILE *f);


DESCRIPTION


The getuserattr(), getusernam(), and getuseruid() functions each
return a user_attr(5) entry. Entries can come from any of the sources
specified in the nsswitch.conf(5) file. The getuserattr() function
enumerates user_attr entries. The getusernam() function searches for
a user_attr entry with a given user name name. The getuseruid()
function searches for a user_attr entry with a given user ID uid.
Successive calls to these functions return either successive
user_attr entries or NULL.


The fgetuserattr() function does not use nsswitch.conf but reads and
parses the next line from the stream f. This stream is assumed to
have the format of the user_attr files.


The free_userattr() function releases memory allocated by the
getusernam(), getuserattr(), and fgetuserattr() functions.


The internal representation of a user_attr entry is a userattr_t
structure defined in <user_attr.h> with the following members:

char *name; /* name of the user */
char *qualifier; /* reserved for future use */
char *res1; /* reserved for future use */
char *res2; /* reserved for future use */
kva_t *attr; /* list of attributes */


The setuserattr() function "rewinds" to the beginning of the
enumeration of user_attr entries. Calls to getusernam() may leave
the enumeration in an indeterminate state, so setuserattr() should be
called before the first call to getuserattr().


The enduserattr() function may be called to indicate that user_attr
processing is complete; the library may then close any open user_attr
file, deallocate any internal storage, and so forth.

RETURN VALUES


The getuserattr() function returns a pointer to a userattr_t if it
successfully enumerates an entry; otherwise it returns NULL,
indicating the end of the enumeration.


The getusernam() function returns a pointer to a userattr_t if it
successfully locates the requested entry; otherwise it returns NULL.

USAGE


The getuserattr() and getusernam() functions both allocate memory for
the pointers they return. This memory should be deallocated with the
free_userattr() function.


Individual attributes can be referenced in the attr structure by
calling the kva_match(3SECDB) function.

WARNINGS


Because the list of legal keys is likely to expand, code must be
written to ignore unknown key-value pairs without error.

FILES


/etc/user_attr
extended user attributes


/etc/nsswitch.conf
configuration file lookup information for the
name service switch


ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+---------------+-----------------+
|ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+---------------+-----------------+
|MT-Level | MT-Safe |
+---------------+-----------------+

SEE ALSO


getauthattr(3SECDB), getexecattr(3SECDB), getprofattr(3SECDB),
kva_match(3SECDB), user_attr(5), attributes(7)

August 13, 2018 GETUSERATTR(3SECDB)

tribblix@gmail.com :: GitHub :: Privacy