mirror of
https://github.com/systemd/systemd.git
synced 2024-11-05 06:52:22 +03:00
Revert "libudev: use get_*_creds from shared rather than util_lookup_*"
This reverts commit a56ba6158b
.
The commit was pushed in error.
This commit is contained in:
parent
7b4c2ee75f
commit
ac9c87dbc4
@ -168,6 +168,8 @@ uint64_t util_string_bloom64(const char *str);
|
|||||||
|
|
||||||
/* libudev-util-private.c */
|
/* libudev-util-private.c */
|
||||||
int util_delete_path(struct udev *udev, const char *path);
|
int util_delete_path(struct udev *udev, const char *path);
|
||||||
|
uid_t util_lookup_user(struct udev *udev, const char *user);
|
||||||
|
gid_t util_lookup_group(struct udev *udev, const char *group);
|
||||||
int util_resolve_subsys_kernel(struct udev *udev, const char *string, char *result, size_t maxsize, int read_value);
|
int util_resolve_subsys_kernel(struct udev *udev, const char *string, char *result, size_t maxsize, int read_value);
|
||||||
ssize_t print_kmsg(const char *fmt, ...) _printf_(1, 2);
|
ssize_t print_kmsg(const char *fmt, ...) _printf_(1, 2);
|
||||||
|
|
||||||
|
@ -77,6 +77,70 @@ int util_delete_path(struct udev *udev, const char *path)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uid_t util_lookup_user(struct udev *udev, const char *user)
|
||||||
|
{
|
||||||
|
char *endptr;
|
||||||
|
struct passwd pwbuf;
|
||||||
|
struct passwd *pw;
|
||||||
|
uid_t uid;
|
||||||
|
size_t buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
|
||||||
|
char *buf = alloca(buflen);
|
||||||
|
|
||||||
|
if (streq(user, "root"))
|
||||||
|
return 0;
|
||||||
|
uid = strtoul(user, &endptr, 10);
|
||||||
|
if (endptr[0] == '\0')
|
||||||
|
return uid;
|
||||||
|
|
||||||
|
errno = getpwnam_r(user, &pwbuf, buf, buflen, &pw);
|
||||||
|
if (pw != NULL)
|
||||||
|
return pw->pw_uid;
|
||||||
|
if (errno == 0 || errno == ENOENT || errno == ESRCH)
|
||||||
|
udev_err(udev, "specified user '%s' unknown\n", user);
|
||||||
|
else
|
||||||
|
udev_err(udev, "error resolving user '%s': %m\n", user);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
gid_t util_lookup_group(struct udev *udev, const char *group)
|
||||||
|
{
|
||||||
|
char *endptr;
|
||||||
|
struct group grbuf;
|
||||||
|
struct group *gr;
|
||||||
|
gid_t gid = 0;
|
||||||
|
size_t buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
|
||||||
|
char *buf = NULL;
|
||||||
|
|
||||||
|
if (streq(group, "root"))
|
||||||
|
return 0;
|
||||||
|
gid = strtoul(group, &endptr, 10);
|
||||||
|
if (endptr[0] == '\0')
|
||||||
|
return gid;
|
||||||
|
gid = 0;
|
||||||
|
for (;;) {
|
||||||
|
char *newbuf;
|
||||||
|
|
||||||
|
newbuf = realloc(buf, buflen);
|
||||||
|
if (!newbuf)
|
||||||
|
break;
|
||||||
|
buf = newbuf;
|
||||||
|
errno = getgrnam_r(group, &grbuf, buf, buflen, &gr);
|
||||||
|
if (gr != NULL) {
|
||||||
|
gid = gr->gr_gid;
|
||||||
|
} else if (errno == ERANGE) {
|
||||||
|
buflen *= 2;
|
||||||
|
continue;
|
||||||
|
} else if (errno == 0 || errno == ENOENT || errno == ESRCH) {
|
||||||
|
udev_err(udev, "specified group '%s' unknown\n", group);
|
||||||
|
} else {
|
||||||
|
udev_err(udev, "error resolving group '%s': %m\n", group);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
free(buf);
|
||||||
|
return gid;
|
||||||
|
}
|
||||||
|
|
||||||
/* handle "[<SUBSYSTEM>/<KERNEL>]<attribute>" format */
|
/* handle "[<SUBSYSTEM>/<KERNEL>]<attribute>" format */
|
||||||
int util_resolve_subsys_kernel(struct udev *udev, const char *string,
|
int util_resolve_subsys_kernel(struct udev *udev, const char *string,
|
||||||
char *result, size_t maxsize, int read_value)
|
char *result, size_t maxsize, int read_value)
|
||||||
|
@ -459,7 +459,6 @@ static uid_t add_uid(struct udev_rules *rules, const char *owner) {
|
|||||||
unsigned int i;
|
unsigned int i;
|
||||||
uid_t uid;
|
uid_t uid;
|
||||||
unsigned int off;
|
unsigned int off;
|
||||||
int r;
|
|
||||||
|
|
||||||
/* lookup, if we know it already */
|
/* lookup, if we know it already */
|
||||||
for (i = 0; i < rules->uids_cur; i++) {
|
for (i = 0; i < rules->uids_cur; i++) {
|
||||||
@ -469,9 +468,7 @@ static uid_t add_uid(struct udev_rules *rules, const char *owner) {
|
|||||||
return uid;
|
return uid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
r = get_user_creds(&owner, &uid, NULL, NULL, NULL);
|
uid = util_lookup_user(rules->udev, owner);
|
||||||
if (r < 0)
|
|
||||||
uid = 0;
|
|
||||||
|
|
||||||
/* grow buffer if needed */
|
/* grow buffer if needed */
|
||||||
if (rules->uids_cur+1 >= rules->uids_max) {
|
if (rules->uids_cur+1 >= rules->uids_max) {
|
||||||
@ -502,7 +499,6 @@ static gid_t add_gid(struct udev_rules *rules, const char *group) {
|
|||||||
unsigned int i;
|
unsigned int i;
|
||||||
gid_t gid;
|
gid_t gid;
|
||||||
unsigned int off;
|
unsigned int off;
|
||||||
int r;
|
|
||||||
|
|
||||||
/* lookup, if we know it already */
|
/* lookup, if we know it already */
|
||||||
for (i = 0; i < rules->gids_cur; i++) {
|
for (i = 0; i < rules->gids_cur; i++) {
|
||||||
@ -512,9 +508,7 @@ static gid_t add_gid(struct udev_rules *rules, const char *group) {
|
|||||||
return gid;
|
return gid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
r = get_group_creds(&group, &gid);
|
gid = util_lookup_group(rules->udev, group);
|
||||||
if (r < 0)
|
|
||||||
gid = 0;
|
|
||||||
|
|
||||||
/* grow buffer if needed */
|
/* grow buffer if needed */
|
||||||
if (rules->gids_cur+1 >= rules->gids_max) {
|
if (rules->gids_cur+1 >= rules->gids_max) {
|
||||||
@ -2176,7 +2170,6 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
|
|||||||
break;
|
break;
|
||||||
case TK_A_OWNER: {
|
case TK_A_OWNER: {
|
||||||
char owner[UTIL_NAME_SIZE];
|
char owner[UTIL_NAME_SIZE];
|
||||||
int r;
|
|
||||||
|
|
||||||
if (event->owner_final)
|
if (event->owner_final)
|
||||||
break;
|
break;
|
||||||
@ -2184,9 +2177,7 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
|
|||||||
event->owner_final = true;
|
event->owner_final = true;
|
||||||
udev_event_apply_format(event, rules_str(rules, cur->key.value_off), owner, sizeof(owner));
|
udev_event_apply_format(event, rules_str(rules, cur->key.value_off), owner, sizeof(owner));
|
||||||
event->owner_set = true;
|
event->owner_set = true;
|
||||||
r = get_user_creds(&owner, &event->uid, NULL, NULL, NULL);
|
event->uid = util_lookup_user(event->udev, owner);
|
||||||
if (r < 0)
|
|
||||||
event->uid = 0;
|
|
||||||
log_debug("OWNER %u %s:%u",
|
log_debug("OWNER %u %s:%u",
|
||||||
event->uid,
|
event->uid,
|
||||||
rules_str(rules, rule->rule.filename_off),
|
rules_str(rules, rule->rule.filename_off),
|
||||||
@ -2195,7 +2186,6 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
|
|||||||
}
|
}
|
||||||
case TK_A_GROUP: {
|
case TK_A_GROUP: {
|
||||||
char group[UTIL_NAME_SIZE];
|
char group[UTIL_NAME_SIZE];
|
||||||
int r;
|
|
||||||
|
|
||||||
if (event->group_final)
|
if (event->group_final)
|
||||||
break;
|
break;
|
||||||
@ -2203,9 +2193,7 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
|
|||||||
event->group_final = true;
|
event->group_final = true;
|
||||||
udev_event_apply_format(event, rules_str(rules, cur->key.value_off), group, sizeof(group));
|
udev_event_apply_format(event, rules_str(rules, cur->key.value_off), group, sizeof(group));
|
||||||
event->group_set = true;
|
event->group_set = true;
|
||||||
r = get_group_creds(&group, &event->gid);
|
event->gid = util_lookup_group(event->udev, group);
|
||||||
if (r < 0)
|
|
||||||
event->gid = 0;
|
|
||||||
log_debug("GROUP %u %s:%u",
|
log_debug("GROUP %u %s:%u",
|
||||||
event->gid,
|
event->gid,
|
||||||
rules_str(rules, rule->rule.filename_off),
|
rules_str(rules, rule->rule.filename_off),
|
||||||
|
Loading…
Reference in New Issue
Block a user