modul Process::Sys
Das Modul Process::Sys enthält UID und GID Funktionen, die direkte Bindungen zu den gleichnamigen Systemaufrufen bieten, anstelle der portableren Versionen derselben Funktionalität, die in den Modulen Process, Process::UID und Process::GID zu finden sind.
Öffentliche Klassenmethoden
Source
static VALUE
proc_getegid(VALUE obj)
{
rb_gid_t egid = getegid();
return GIDT2NUM(egid);
}
Gibt die effektive Gruppen-ID für den aktuellen Prozess zurück.
Process.egid # => 500
Nicht auf allen Plattformen verfügbar.
Source
static VALUE
proc_geteuid(VALUE obj)
{
rb_uid_t euid = geteuid();
return UIDT2NUM(euid);
}
Gibt die effektive Benutzer-ID für den aktuellen Prozess zurück.
Process.euid # => 501
Source
static VALUE
proc_getgid(VALUE obj)
{
rb_gid_t gid = getgid();
return GIDT2NUM(gid);
}
Gibt die (reale) Gruppen-ID für den aktuellen Prozess zurück.
Process.gid # => 1000
Source
static VALUE
proc_getuid(VALUE obj)
{
rb_uid_t uid = getuid();
return UIDT2NUM(uid);
}
Gibt die (reale) Benutzer-ID des aktuellen Prozesses zurück.
Process.uid # => 1000
Source
static VALUE
p_sys_issetugid(VALUE obj)
{
return RBOOL(issetugid());
}
Gibt true zurück, wenn der Prozess als Ergebnis eines execve(2) Systemaufrufs erstellt wurde, bei dem entweder das Setuid- oder Setgid-Bit gesetzt war (und dadurch zusätzliche Berechtigungen vergeben wurden), oder wenn er seit Beginn der Ausführung eine seiner realen, effektiven oder gespeicherten Benutzer- oder Gruppen-IDs geändert hat.
Source
static VALUE
p_sys_setegid(VALUE obj, VALUE id)
{
check_gid_switch();
if (setegid(OBJ2GID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die effektive Gruppen-ID des aufrufenden Prozesses auf group. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_seteuid(VALUE obj, VALUE id)
{
check_uid_switch();
if (seteuid(OBJ2UID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die effektive Benutzer-ID des aufrufenden Prozesses auf user. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setgid(VALUE obj, VALUE id)
{
check_gid_switch();
if (setgid(OBJ2GID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die Gruppen-ID des aktuellen Prozesses auf group. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setregid(VALUE obj, VALUE rid, VALUE eid)
{
rb_gid_t rgid, egid;
check_gid_switch();
rgid = OBJ2GID(rid);
egid = OBJ2GID(eid);
if (setregid(rgid, egid) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die realen und/oder effektiven Gruppen-IDs des aktuellen Prozesses auf rid bzw. eid. Ein Wert von -1 für einen der beiden bedeutet, dass die jeweilige ID unverändert bleibt. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setresgid(VALUE obj, VALUE rid, VALUE eid, VALUE sid)
{
rb_gid_t rgid, egid, sgid;
check_gid_switch();
rgid = OBJ2GID(rid);
egid = OBJ2GID(eid);
sgid = OBJ2GID(sid);
if (setresgid(rgid, egid, sgid) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die realen, effektiven und gespeicherten Gruppen-IDs des aktuellen Prozesses auf rid, eid bzw. sid. Ein Wert von -1 für einen beliebigen Wert bedeutet, dass die jeweilige ID unverändert bleibt. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setresuid(VALUE obj, VALUE rid, VALUE eid, VALUE sid)
{
rb_uid_t ruid, euid, suid;
PREPARE_GETPWNAM;
check_uid_switch();
ruid = OBJ2UID1(rid);
euid = OBJ2UID1(eid);
suid = OBJ2UID1(sid);
FINISH_GETPWNAM;
if (setresuid(ruid, euid, suid) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die realen, effektiven und gespeicherten Benutzer-IDs des aktuellen Prozesses auf rid, eid bzw. sid. Ein Wert von -1 für einen beliebigen Wert bedeutet, dass die jeweilige ID unverändert bleibt. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setreuid(VALUE obj, VALUE rid, VALUE eid)
{
rb_uid_t ruid, euid;
PREPARE_GETPWNAM;
check_uid_switch();
ruid = OBJ2UID1(rid);
euid = OBJ2UID1(eid);
FINISH_GETPWNAM;
if (setreuid(ruid, euid) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die realen und/oder effektiven Benutzer-IDs des aktuellen Prozesses auf rid bzw. eid. Ein Wert von -1 für einen der beiden bedeutet, dass die jeweilige ID unverändert bleibt. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setrgid(VALUE obj, VALUE id)
{
check_gid_switch();
if (setrgid(OBJ2GID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die reale Gruppen-ID des aufrufenden Prozesses auf group. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setruid(VALUE obj, VALUE id)
{
check_uid_switch();
if (setruid(OBJ2UID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die reale Benutzer-ID des aufrufenden Prozesses auf user. Nicht auf allen Plattformen verfügbar.
Source
static VALUE
p_sys_setuid(VALUE obj, VALUE id)
{
check_uid_switch();
if (setuid(OBJ2UID(id)) != 0) rb_sys_fail(0);
return Qnil;
}
Setzt die Benutzer-ID des aktuellen Prozesses auf user. Nicht auf allen Plattformen verfügbar.