user-util.h revision 71d35b6b5563817dfbe757ab9e3b9f018b2db491
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering This file is part of systemd.
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering Copyright 2010 Lennart Poettering
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering systemd is free software; you can redistribute it and/or modify it
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering under the terms of the GNU Lesser General Public License as published by
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering the Free Software Foundation; either version 2.1 of the License, or
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering (at your option) any later version.
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering systemd is distributed in the hope that it will be useful, but
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering WITHOUT ANY WARRANTY; without even the implied warranty of
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering Lesser General Public License for more details.
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering You should have received a copy of the GNU Lesser General Public License
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poettering along with systemd; If not, see <http://www.gnu.org/licenses/>.
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poetteringstatic inline bool gid_is_valid(gid_t gid) {
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poetteringint parse_uid(const char *s, uid_t* ret_uid);
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poetteringstatic inline int parse_gid(const char *s, gid_t *ret_gid) {
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poetteringint get_user_creds(const char **username, uid_t *uid, gid_t *gid, const char **home, const char **shell);
b1d4f8e154bf61b5de1b27461ef8e9c8c5e838a1Lennart Poetteringint get_group_creds(const char **groupname, gid_t *gid);
e929bee09ab8000e87b7e825ed3a78d73ecdd7f0Lennart Poetteringint take_etc_passwd_lock(const char *root);
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering/* The following macros add 1 when converting things, since UID 0 is a
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering * valid UID, while the pointer NULL is special */
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering#define PTR_TO_UID(p) ((uid_t) (((uintptr_t) (p))-1))
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering#define UID_TO_PTR(u) ((void*) (((uintptr_t) (u))+1))
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering#define PTR_TO_GID(p) ((gid_t) (((uintptr_t) (p))-1))
ee104e11e303499a637c5cd8157bd12ad5cc116dLennart Poettering#define GID_TO_PTR(u) ((void*) (((uintptr_t) (u))+1))