290946ce80
- The kernel stores the group IDs in the team structure. They are correctly inherited on fork() and load_image_etc(). - Implemented getgroups() for real, i.e. it retrieves the groups associated with the process. - Implemented setgroups(), initgroups() and (the BSDish) getgrouplist(). The latter two read the group information from the "group database" /etc/group (if existing). - Change the BIND port config, since we do have getgrouplist() now. * The set-uid feature was broken when the path to the executable was relative, since we used stat(), which, in the kernel, uses the kernel IO context. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@24669 a95241bf-73f2-0310-859d-f6bbb57e9c96
41 lines
897 B
C
41 lines
897 B
C
/*
|
|
* Copyright 2008, Ingo Weinhold, ingo_weinhold@gmx.de.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
#ifndef _KERNEL_USERGROUP_H
|
|
#define _KERNEL_USERGROUP_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <SupportDefs.h>
|
|
|
|
|
|
struct team;
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
// kernel private functions
|
|
|
|
void inherit_parent_user_and_group(struct team* team,
|
|
struct team* parent);
|
|
status_t update_set_id_user_and_group(struct team* team, const char* file);
|
|
|
|
// syscalls
|
|
|
|
gid_t _user_getgid(bool effective);
|
|
uid_t _user_getuid(bool effective);
|
|
status_t _user_setregid(gid_t rgid, gid_t egid, bool setAllIfPrivileged);
|
|
status_t _user_setreuid(uid_t ruid, uid_t euid, bool setAllIfPrivileged);
|
|
ssize_t _user_getgroups(int groupCount, gid_t* groupList);
|
|
ssize_t _user_setgroups(int groupCount, const gid_t* groupList);
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|
|
|
|
|
|
#endif // _KERNEL_USERGROUP_H
|