Available in

(2) (2)/de (2)/es (2)/fr (2)/ja (2)/pl (2)/pt

Contents

NOMBRE

setresuid, setresgid − establecen el UID o GID efectivo, real y salvado

SINOPSIS

#include <unistd.h>

int setresuid(uid_t ruid, uid_t euid, uid_t suid);
int setresgid(gid_t
rgid, gid_t egid, gid_t sgid);

DESCRIPCIÓN

setresuid establece el UID real, el UID efectivo y el SETUID salvado del proceso actual.

Los procesos de usuarios no privilegiados (esto es, procesos con cada uno de los UIDs real, efectivo y salvado distintos de cero) pueden cambiar el UID real, efectivo y salvado, cada uno a uno de: el UID actual, el UID efectivo actual o el UID salvado actual.

El súper-usuario puede establecer los UIDs real, efectivo y salvado a valores arbitrarios.

Si uno de los parámetros es igual a −1, el valor correspondiente no se cambia.

De forma completamente análoga, setresgid establece el GID real, efectivo y salvado del proceso en curso, con las mismas restricciones para procesos con cada uno de los UIDs real, efectivo y salvado distintos de cero.

VALOR DEVUELTO

En caso de éxito, se devuelve cero. En caso de error, se devuelve −1 y se pone en errno un valor adecuado.

ERRORES

EPERM

El proceso en curso no era privilegiado e intentó cambiar los IDs de una forma no permitida.

CONFORME A

Esta llamada no es estándar.

HISTORIA

Esta llamada al sistema fue introducida por primera vez en HP-UX. En Linux está disponible desde la versión 2.1.44. Aquellos días también se podía encontrar en FreeBSD (para emulación de los binarios de Linux).

OBSERVACIONES

Bajo HP-UX y FreeBSD el prototipo se encuentra en <unistd.h>. Bajo Linux no hay hasta ahora fichero de cabecera que incluya el prototipo - ésto es un fallo de glibc. Los programas que usen esta llamada al sistema deben añadir el prototipo ellos mismos.

VÉASE TAMBIÉN

getuid(2), setuid(2), getreuid(2), setreuid(2), getresuid(2)

COMMENTS

blog comments powered by Disqus