r24353: Add a getpwuid lookup to wbinfo.
authorKai Blin <kai@samba.org>
Sun, 12 Aug 2007 17:36:42 +0000 (17:36 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 17:29:32 +0000 (12:29 -0500)
Merged from my Samba4 GSoC branch.
Volker, can you check if that's done the way you thought?
(This used to be commit f8560ea66ce522ff11d16f0e36e10853fe2639d7)

source3/nsswitch/wbinfo.c

index 0f218f70f48d63c481ecbb1092d415c35adbbdd0..e0bda948ed13c270e99ad064b5313e3c91ec68cf 100644 (file)
@@ -150,6 +150,35 @@ static BOOL wbinfo_get_userinfo(char *user)
        return True;
 }
 
        return True;
 }
 
+/* pull pwent info for a given uid */
+static BOOL wbinfo_get_uidinfo(int uid)
+{
+       struct winbindd_request request;
+       struct winbindd_response response;
+       NSS_STATUS result;
+
+       ZERO_STRUCT(request);
+       ZERO_STRUCT(response);
+
+       request.data.uid = uid;
+
+       result = winbindd_request_response(WINBINDD_GETPWUID, &request, &response);
+
+       if (result != NSS_STATUS_SUCCESS)
+               return False;
+
+       d_printf( "%s:%s:%d:%d:%s:%s:%s\n",
+               response.data.pw.pw_name,
+               response.data.pw.pw_passwd,
+               response.data.pw.pw_uid,
+               response.data.pw.pw_gid,
+               response.data.pw.pw_gecos,
+               response.data.pw.pw_dir,
+               response.data.pw.pw_shell );
+
+       return True;
+}
+
 /* pull grent for a given group */
 static BOOL wbinfo_get_groupinfo(char *group)
 {
 /* pull grent for a given group */
 static BOOL wbinfo_get_groupinfo(char *group)
 {
@@ -1196,6 +1225,7 @@ enum {
        OPT_SEPARATOR,
        OPT_LIST_ALL_DOMAINS,
        OPT_LIST_OWN_DOMAIN,
        OPT_SEPARATOR,
        OPT_LIST_ALL_DOMAINS,
        OPT_LIST_OWN_DOMAIN,
+       OPT_UID_INFO,
        OPT_GROUP_INFO,
 };
 
        OPT_GROUP_INFO,
 };
 
@@ -1237,6 +1267,7 @@ int main(int argc, char **argv, char **envp)
                { "sequence", 0, POPT_ARG_NONE, 0, OPT_SEQUENCE, "Show sequence numbers of all domains" },
                { "domain-info", 'D', POPT_ARG_STRING, &string_arg, 'D', "Show most of the info we have about the domain" },
                { "user-info", 'i', POPT_ARG_STRING, &string_arg, 'i', "Get user info", "USER" },
                { "sequence", 0, POPT_ARG_NONE, 0, OPT_SEQUENCE, "Show sequence numbers of all domains" },
                { "domain-info", 'D', POPT_ARG_STRING, &string_arg, 'D', "Show most of the info we have about the domain" },
                { "user-info", 'i', POPT_ARG_STRING, &string_arg, 'i', "Get user info", "USER" },
+               { "uid-info", 0, POPT_ARG_INT, &int_arg, OPT_UID_INFO, "Get user info from uid", "UID" },
                { "group-info", 0, POPT_ARG_STRING, &string_arg, OPT_GROUP_INFO, "Get group info", "GROUP" },
                { "user-groups", 'r', POPT_ARG_STRING, &string_arg, 'r', "Get user groups", "USER" },
                { "user-domgroups", 0, POPT_ARG_STRING, &string_arg,
                { "group-info", 0, POPT_ARG_STRING, &string_arg, OPT_GROUP_INFO, "Get group info", "GROUP" },
                { "user-groups", 'r', POPT_ARG_STRING, &string_arg, 'r', "Get user groups", "USER" },
                { "user-domgroups", 0, POPT_ARG_STRING, &string_arg,
@@ -1410,6 +1441,13 @@ int main(int argc, char **argv, char **envp)
                                goto done;
                        }
                        break;
                                goto done;
                        }
                        break;
+               case OPT_UID_INFO:
+                       if ( !wbinfo_get_uidinfo(int_arg)) {
+                               d_fprintf(stderr, "Could not get info for uid "
+                                               "%d\n", int_arg);
+                               goto done;
+                       }
+                       break;
                case OPT_GROUP_INFO:
                        if ( !wbinfo_get_groupinfo(string_arg)) {
                                d_fprintf(stderr, "Could not get info for "
                case OPT_GROUP_INFO:
                        if ( !wbinfo_get_groupinfo(string_arg)) {
                                d_fprintf(stderr, "Could not get info for "