]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/basic/user-util.h
Merge pull request #7551 from poettering/resolved-unknown-scope
[thirdparty/systemd.git] / src / basic / user-util.h
CommitLineData
53e1b683 1/* SPDX-License-Identifier: LGPL-2.1+ */
b1d4f8e1
LP
2#pragma once
3
4/***
5 This file is part of systemd.
6
7 Copyright 2010 Lennart Poettering
8
9 systemd is free software; you can redistribute it and/or modify it
10 under the terms of the GNU Lesser General Public License as published by
11 the Free Software Foundation; either version 2.1 of the License, or
12 (at your option) any later version.
13
14 systemd is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 Lesser General Public License for more details.
18
19 You should have received a copy of the GNU Lesser General Public License
20 along with systemd; If not, see <http://www.gnu.org/licenses/>.
21***/
22
b1d4f8e1 23#include <stdbool.h>
61755fda 24#include <stdint.h>
71d35b6b 25#include <sys/types.h>
ccabee0d 26#include <unistd.h>
b1d4f8e1
LP
27
28bool uid_is_valid(uid_t uid);
29
30static inline bool gid_is_valid(gid_t gid) {
31 return uid_is_valid((uid_t) gid);
32}
33
34int parse_uid(const char *s, uid_t* ret_uid);
35
36static inline int parse_gid(const char *s, gid_t *ret_gid) {
37 return parse_uid(s, (uid_t*) ret_gid);
38}
39
b1d4f8e1
LP
40char* getlogname_malloc(void);
41char* getusername_malloc(void);
42
43int get_user_creds(const char **username, uid_t *uid, gid_t *gid, const char **home, const char **shell);
be39ccf3 44int get_user_creds_clean(const char **username, uid_t *uid, gid_t *gid, const char **home, const char **shell);
b1d4f8e1
LP
45int get_group_creds(const char **groupname, gid_t *gid);
46
47char* uid_to_name(uid_t uid);
48char* gid_to_name(gid_t gid);
49
50int in_gid(gid_t gid);
51int in_group(const char *name);
52
53int get_home_dir(char **ret);
54int get_shell(char **_ret);
55
56int reset_uid_gid(void);
e929bee0
LP
57
58int take_etc_passwd_lock(const char *root);
ee104e11
LP
59
60#define UID_INVALID ((uid_t) -1)
61#define GID_INVALID ((gid_t) -1)
62
3a664727
LP
63#define UID_NOBODY ((uid_t) 65534U)
64#define GID_NOBODY ((gid_t) 65534U)
65
61755fda
ZJS
66static inline bool uid_is_dynamic(uid_t uid) {
67 return DYNAMIC_UID_MIN <= uid && uid <= DYNAMIC_UID_MAX;
68}
69
83438277
LP
70static inline bool gid_is_dynamic(gid_t gid) {
71 return uid_is_dynamic((uid_t) gid);
72}
73
ece877d4
LP
74static inline bool uid_is_system(uid_t uid) {
75 return uid <= SYSTEM_UID_MAX;
76}
77
78static inline bool gid_is_system(gid_t gid) {
79 return gid <= SYSTEM_GID_MAX;
80}
81
61755fda
ZJS
82/* The following macros add 1 when converting things, since UID 0 is a valid UID, while the pointer
83 * NULL is special */
ee104e11
LP
84#define PTR_TO_UID(p) ((uid_t) (((uintptr_t) (p))-1))
85#define UID_TO_PTR(u) ((void*) (((uintptr_t) (u))+1))
86
87#define PTR_TO_GID(p) ((gid_t) (((uintptr_t) (p))-1))
88#define GID_TO_PTR(u) ((void*) (((uintptr_t) (u))+1))
ccabee0d
LP
89
90static inline bool userns_supported(void) {
91 return access("/proc/self/uid_map", F_OK) >= 0;
92}
e4631b48
LP
93
94bool valid_user_group_name(const char *u);
95bool valid_user_group_name_or_id(const char *u);
96bool valid_gecos(const char *d);
97bool valid_home(const char *p);
36d85478
GS
98
99int maybe_setgroups(size_t size, const gid_t *list);