This section describes the functions for altering the user ID (real and/or effective) of a process. To use these facilities, you must include the header files `sys/types.h' and `unistd.h'.
If the process is not privileged, then newuid must either be equal to the real user ID or the saved user ID (if the system supports the _POSIX_SAVED_IDS
feature). In this case, setuid
sets only the effective user ID and not the real user ID.
The setuid
function returns a value of 0
to indicate successful completion, and a value of -1
to indicate an error. The following errno
error conditions are defined for this function:
EINVAL
EPERM
-1
, it means not to change the real user ID; likewise if euid is -1
, it means not to change the effective user ID.
The setreuid
function exists for compatibility with 4.3 BSD Unix, which does not support saved IDs. You can use this function to swap the effective and real user IDs of the process. (Privileged processes are not limited to this particular usage.) If saved IDs are supported, you should use that feature instead of this function. See Enable/Disable Setuid.
The return value is 0
on success and -1
on failure. The following errno
error conditions are defined for this function:
EPERM