mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-02-09 09:57:26 +03:00
uid-range: replace uid_range_contains() by more generalized uid_range_covers()
The former checks if one UID is inside the uid range set. The latter checks if a full UID range is inside the uid range set. The former is hence a special case of the latter.
This commit is contained in:
parent
0a5c6a57c6
commit
556560495e
@ -179,12 +179,17 @@ int uid_range_next_lower(const UidRange *p, size_t n, uid_t *uid) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
bool uid_range_contains(const UidRange *p, size_t n, uid_t uid) {
|
||||
assert(p);
|
||||
assert(uid);
|
||||
bool uid_range_covers(const UidRange *p, size_t n, uid_t start, uid_t nr) {
|
||||
assert(p || n == 0);
|
||||
|
||||
if (nr == 0) /* empty range? always covered... */
|
||||
return true;
|
||||
|
||||
if (start > UINT32_MAX - nr) /* range overflows? definitely not covered... */
|
||||
return false;
|
||||
|
||||
for (size_t i = 0; i < n; i++)
|
||||
if (uid >= p[i].start && uid < p[i].start + p[i].nr)
|
||||
if (start >= p[i].start && start + nr <= p[i].start + p[i].nr)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
|
@ -12,6 +12,10 @@ int uid_range_add(UidRange **p, size_t *n, uid_t start, uid_t nr);
|
||||
int uid_range_add_str(UidRange **p, size_t *n, const char *s);
|
||||
|
||||
int uid_range_next_lower(const UidRange *p, size_t n, uid_t *uid);
|
||||
bool uid_range_contains(const UidRange *p, size_t n, uid_t uid);
|
||||
bool uid_range_covers(const UidRange *p, size_t n, uid_t start, uid_t nr);
|
||||
|
||||
static inline bool uid_range_contains(const UidRange *p, size_t n, uid_t uid) {
|
||||
return uid_range_covers(p, n, uid, 1);
|
||||
}
|
||||
|
||||
int uid_range_load_userns(UidRange **p, size_t *n, const char *path);
|
||||
|
@ -19,6 +19,10 @@ TEST(uid_range) {
|
||||
size_t n = 0;
|
||||
uid_t search;
|
||||
|
||||
assert_se(uid_range_covers(p, n, 0, 0));
|
||||
assert_se(!uid_range_covers(p, n, 0, 1));
|
||||
assert_se(!uid_range_covers(p, n, 100, UINT32_MAX));
|
||||
|
||||
assert_se(uid_range_add_str(&p, &n, "500-999") >= 0);
|
||||
assert_se(n == 1);
|
||||
assert_se(p[0].start == 500);
|
||||
@ -29,6 +33,17 @@ TEST(uid_range) {
|
||||
assert_se(uid_range_contains(p, n, 999));
|
||||
assert_se(!uid_range_contains(p, n, 1000));
|
||||
|
||||
assert_se(!uid_range_covers(p, n, 100, 150));
|
||||
assert_se(!uid_range_covers(p, n, 400, 200));
|
||||
assert_se(!uid_range_covers(p, n, 499, 1));
|
||||
assert_se(uid_range_covers(p, n, 500, 1));
|
||||
assert_se(uid_range_covers(p, n, 501, 10));
|
||||
assert_se(uid_range_covers(p, n, 999, 1));
|
||||
assert_se(!uid_range_covers(p, n, 999, 2));
|
||||
assert_se(!uid_range_covers(p, n, 1000, 1));
|
||||
assert_se(!uid_range_covers(p, n, 1000, 100));
|
||||
assert_se(!uid_range_covers(p, n, 1001, 100));
|
||||
|
||||
search = UID_INVALID;
|
||||
assert_se(uid_range_next_lower(p, n, &search));
|
||||
assert_se(search == 999);
|
||||
@ -97,6 +112,8 @@ TEST(load_userns) {
|
||||
assert_se(n == 1);
|
||||
assert_se(p[0].start == 0);
|
||||
assert_se(p[0].nr == UINT32_MAX);
|
||||
|
||||
assert_se(uid_range_covers(p, n, 0, UINT32_MAX));
|
||||
}
|
||||
|
||||
assert_se(fopen_temporary(NULL, &f, &fn) >= 0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user