Zbigniew Jędrzejewski-Szmek 62fe94
From 23bf8dd7d5ce1e2a52f28d5d242109ddb668b3fb Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Tom Gundersen <teg@jklm.no>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Tue, 9 Sep 2014 23:12:14 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] libudev: drop util_lookup_{user,group}
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Use shared versions instead. Difference is with overwriting of repeated user/group
Zbigniew Jędrzejewski-Szmek 62fe94
name, and lack of logging.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libudev/libudev-private.h |  2 --
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libudev/libudev-util.c    | 64 -------------------------------------------
Zbigniew Jędrzejewski-Szmek 62fe94
 src/udev/udev-rules.c         | 46 +++++++++++++++++++++++++++----
Zbigniew Jędrzejewski-Szmek 62fe94
 3 files changed, 40 insertions(+), 72 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libudev/libudev-private.h b/src/libudev/libudev-private.h
Zbigniew Jędrzejewski-Szmek 62fe94
index 35ea7ba44c..1c060d95a3 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libudev/libudev-private.h
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libudev/libudev-private.h
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -168,8 +168,6 @@ uint64_t util_string_bloom64(const char *str);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 /* libudev-util-private.c */
Zbigniew Jędrzejewski-Szmek 62fe94
 int util_delete_path(struct udev *udev, const char *path);
Zbigniew Jędrzejewski-Szmek 62fe94
-uid_t util_lookup_user(struct udev *udev, const char *user);
Zbigniew Jędrzejewski-Szmek 62fe94
-gid_t util_lookup_group(struct udev *udev, const char *group);
Zbigniew Jędrzejewski-Szmek 62fe94
 int util_resolve_subsys_kernel(struct udev *udev, const char *string, char *result, size_t maxsize, int read_value);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 #endif
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libudev/libudev-util.c b/src/libudev/libudev-util.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 9e19e31407..3bc9c67f3b 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libudev/libudev-util.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libudev/libudev-util.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -77,70 +77,6 @@ int util_delete_path(struct udev *udev, const char *path)
Zbigniew Jędrzejewski-Szmek 62fe94
         return err;
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-uid_t util_lookup_user(struct udev *udev, const char *user)
Zbigniew Jędrzejewski-Szmek 62fe94
-{
Zbigniew Jędrzejewski-Szmek 62fe94
-        char *endptr;
Zbigniew Jędrzejewski-Szmek 62fe94
-        struct passwd pwbuf;
Zbigniew Jędrzejewski-Szmek 62fe94
-        struct passwd *pw;
Zbigniew Jędrzejewski-Szmek 62fe94
-        uid_t uid;
Zbigniew Jędrzejewski-Szmek 62fe94
-        size_t buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
Zbigniew Jędrzejewski-Szmek 62fe94
-        char *buf = alloca(buflen);
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (streq(user, "root"))
Zbigniew Jędrzejewski-Szmek 62fe94
-                return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
-        uid = strtoul(user, &endptr, 10);
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (endptr[0] == '\0')
Zbigniew Jędrzejewski-Szmek 62fe94
-                return uid;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        errno = getpwnam_r(user, &pwbuf, buf, buflen, &pw;;
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (pw != NULL)
Zbigniew Jędrzejewski-Szmek 62fe94
-                return pw->pw_uid;
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (errno == 0 || errno == ENOENT || errno == ESRCH)
Zbigniew Jędrzejewski-Szmek 62fe94
-                udev_err(udev, "specified user '%s' unknown\n", user);
Zbigniew Jędrzejewski-Szmek 62fe94
-        else
Zbigniew Jędrzejewski-Szmek 62fe94
-                udev_err(udev, "error resolving user '%s': %m\n", user);
Zbigniew Jędrzejewski-Szmek 62fe94
-        return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
-}
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-gid_t util_lookup_group(struct udev *udev, const char *group)
Zbigniew Jędrzejewski-Szmek 62fe94
-{
Zbigniew Jędrzejewski-Szmek 62fe94
-        char *endptr;
Zbigniew Jędrzejewski-Szmek 62fe94
-        struct group grbuf;
Zbigniew Jędrzejewski-Szmek 62fe94
-        struct group *gr;
Zbigniew Jędrzejewski-Szmek 62fe94
-        gid_t gid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
-        size_t buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
Zbigniew Jędrzejewski-Szmek 62fe94
-        char *buf = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (streq(group, "root"))
Zbigniew Jędrzejewski-Szmek 62fe94
-                return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
-        gid = strtoul(group, &endptr, 10);
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (endptr[0] == '\0')
Zbigniew Jędrzejewski-Szmek 62fe94
-                return gid;
Zbigniew Jędrzejewski-Szmek 62fe94
-        gid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
-        for (;;) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                char *newbuf;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-                newbuf = realloc(buf, buflen);
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (!newbuf)
Zbigniew Jędrzejewski-Szmek 62fe94
-                        break;
Zbigniew Jędrzejewski-Szmek 62fe94
-                buf = newbuf;
Zbigniew Jędrzejewski-Szmek 62fe94
-                errno = getgrnam_r(group, &grbuf, buf, buflen, &gr);
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (gr != NULL) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        gid = gr->gr_gid;
Zbigniew Jędrzejewski-Szmek 62fe94
-                } else if (errno == ERANGE) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        buflen *= 2;
Zbigniew Jędrzejewski-Szmek 62fe94
-                        continue;
Zbigniew Jędrzejewski-Szmek 62fe94
-                } else if (errno == 0 || errno == ENOENT || errno == ESRCH) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        udev_err(udev, "specified group '%s' unknown\n", group);
Zbigniew Jędrzejewski-Szmek 62fe94
-                } else {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        udev_err(udev, "error resolving group '%s': %m\n", group);
Zbigniew Jędrzejewski-Szmek 62fe94
-                }
Zbigniew Jędrzejewski-Szmek 62fe94
-                break;
Zbigniew Jędrzejewski-Szmek 62fe94
-        }
Zbigniew Jędrzejewski-Szmek 62fe94
-        free(buf);
Zbigniew Jędrzejewski-Szmek 62fe94
-        return gid;
Zbigniew Jędrzejewski-Szmek 62fe94
-}
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
 /* handle "[<SUBSYSTEM>/<KERNEL>]<attribute>" format */
Zbigniew Jędrzejewski-Szmek 62fe94
 int util_resolve_subsys_kernel(struct udev *udev, const char *string,
Zbigniew Jędrzejewski-Szmek 62fe94
                                char *result, size_t maxsize, int read_value)
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/udev/udev-rules.c b/src/udev/udev-rules.c
Zbigniew Jędrzejewski-Szmek 62fe94
index db95442fda..ce4d173ee9 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/udev/udev-rules.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/udev/udev-rules.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -459,8 +459,9 @@ static int add_token(struct udev_rules *rules, struct token *token) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 static uid_t add_uid(struct udev_rules *rules, const char *owner) {
Zbigniew Jędrzejewski-Szmek 62fe94
         unsigned int i;
Zbigniew Jędrzejewski-Szmek 62fe94
-        uid_t uid;
Zbigniew Jędrzejewski-Szmek 62fe94
+        uid_t uid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
         unsigned int off;
Zbigniew Jędrzejewski-Szmek 62fe94
+        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* lookup, if we know it already */
Zbigniew Jędrzejewski-Szmek 62fe94
         for (i = 0; i < rules->uids_cur; i++) {
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -470,7 +471,13 @@ static uid_t add_uid(struct udev_rules *rules, const char *owner) {
Zbigniew Jędrzejewski-Szmek 62fe94
                         return uid;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
-        uid = util_lookup_user(rules->udev, owner);
Zbigniew Jędrzejewski-Szmek 62fe94
+        r = get_user_creds(&owner, &uid, NULL, NULL, NULL);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (r == -ENOENT || r == -ESRCH)
Zbigniew Jędrzejewski-Szmek 62fe94
+                        udev_err(rules->udev, "specified user '%s' unknown\n", owner);
Zbigniew Jędrzejewski-Szmek 62fe94
+                else
Zbigniew Jędrzejewski-Szmek 62fe94
+                        udev_err(rules->udev, "error resolving user '%s': %s\n", owner, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* grow buffer if needed */
Zbigniew Jędrzejewski-Szmek 62fe94
         if (rules->uids_cur+1 >= rules->uids_max) {
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -499,8 +506,9 @@ static uid_t add_uid(struct udev_rules *rules, const char *owner) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 static gid_t add_gid(struct udev_rules *rules, const char *group) {
Zbigniew Jędrzejewski-Szmek 62fe94
         unsigned int i;
Zbigniew Jędrzejewski-Szmek 62fe94
-        gid_t gid;
Zbigniew Jędrzejewski-Szmek 62fe94
+        gid_t gid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
         unsigned int off;
Zbigniew Jędrzejewski-Szmek 62fe94
+        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* lookup, if we know it already */
Zbigniew Jędrzejewski-Szmek 62fe94
         for (i = 0; i < rules->gids_cur; i++) {
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -510,7 +518,13 @@ static gid_t add_gid(struct udev_rules *rules, const char *group) {
Zbigniew Jędrzejewski-Szmek 62fe94
                         return gid;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
-        gid = util_lookup_group(rules->udev, group);
Zbigniew Jędrzejewski-Szmek 62fe94
+        r = get_group_creds(&group, &gid;;
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (r == -ENOENT || r == -ESRCH)
Zbigniew Jędrzejewski-Szmek 62fe94
+                        udev_err(rules->udev, "specified group '%s' unknown\n", group);
Zbigniew Jędrzejewski-Szmek 62fe94
+                else
Zbigniew Jędrzejewski-Szmek 62fe94
+                        udev_err(rules->udev, "error resolving group '%s': %s\n", group, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* grow buffer if needed */
Zbigniew Jędrzejewski-Szmek 62fe94
         if (rules->gids_cur+1 >= rules->gids_max) {
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -2241,6 +2255,8 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
Zbigniew Jędrzejewski-Szmek 62fe94
                         break;
Zbigniew Jędrzejewski-Szmek 62fe94
                 case TK_A_OWNER: {
Zbigniew Jędrzejewski-Szmek 62fe94
                         char owner[UTIL_NAME_SIZE];
Zbigniew Jędrzejewski-Szmek 62fe94
+                        const char *ow = owner;
Zbigniew Jędrzejewski-Szmek 62fe94
+                        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                         if (event->owner_final)
Zbigniew Jędrzejewski-Szmek 62fe94
                                 break;
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -2248,7 +2264,15 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
Zbigniew Jędrzejewski-Szmek 62fe94
                                 event->owner_final = true;
Zbigniew Jędrzejewski-Szmek 62fe94
                         udev_event_apply_format(event, rules_str(rules, cur->key.value_off), owner, sizeof(owner));
Zbigniew Jędrzejewski-Szmek 62fe94
                         event->owner_set = true;
Zbigniew Jędrzejewski-Szmek 62fe94
-                        event->uid = util_lookup_user(event->udev, owner);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        r = get_user_creds(&ow, &event->uid, NULL, NULL, NULL);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                                if (r == -ENOENT || r == -ESRCH)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                        udev_err(event->udev, "specified user '%s' unknown\n", owner);
Zbigniew Jędrzejewski-Szmek 62fe94
+                                else
Zbigniew Jędrzejewski-Szmek 62fe94
+                                        udev_err(event->udev, "error resolving user '%s': %s\n", owner, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                                event->uid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+                        }
Zbigniew Jędrzejewski-Szmek 62fe94
                         log_debug("OWNER %u %s:%u",
Zbigniew Jędrzejewski-Szmek 62fe94
                                   event->uid,
Zbigniew Jędrzejewski-Szmek 62fe94
                                   rules_str(rules, rule->rule.filename_off),
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -2257,6 +2281,8 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
                 case TK_A_GROUP: {
Zbigniew Jędrzejewski-Szmek 62fe94
                         char group[UTIL_NAME_SIZE];
Zbigniew Jędrzejewski-Szmek 62fe94
+                        const char *gr = group;
Zbigniew Jędrzejewski-Szmek 62fe94
+                        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                         if (event->group_final)
Zbigniew Jędrzejewski-Szmek 62fe94
                                 break;
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -2264,7 +2290,15 @@ int udev_rules_apply_to_event(struct udev_rules *rules,
Zbigniew Jędrzejewski-Szmek 62fe94
                                 event->group_final = true;
Zbigniew Jędrzejewski-Szmek 62fe94
                         udev_event_apply_format(event, rules_str(rules, cur->key.value_off), group, sizeof(group));
Zbigniew Jędrzejewski-Szmek 62fe94
                         event->group_set = true;
Zbigniew Jędrzejewski-Szmek 62fe94
-                        event->gid = util_lookup_group(event->udev, group);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        r = get_group_creds(&gr, &event->gid);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                                if (r == -ENOENT || r == -ESRCH)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                        udev_err(event->udev, "specified group '%s' unknown\n", group);
Zbigniew Jędrzejewski-Szmek 62fe94
+                                else
Zbigniew Jędrzejewski-Szmek 62fe94
+                                        udev_err(event->udev, "error resolving group '%s': %s\n", group, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                                event->gid = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+                        }
Zbigniew Jędrzejewski-Szmek 62fe94
                         log_debug("GROUP %u %s:%u",
Zbigniew Jędrzejewski-Szmek 62fe94
                                   event->gid,
Zbigniew Jędrzejewski-Szmek 62fe94
                                   rules_str(rules, rule->rule.filename_off),