summaryrefslogtreecommitdiffstats
path: root/nsswitch
diff options
context:
space:
mode:
authorKai Blin <kai@samba.org>2008-12-26 11:04:01 +0100
committerKai Blin <kai@samba.org>2008-12-29 12:52:27 +0100
commit6958fac28d47b49402dd48778563ee612f6b6549 (patch)
treee677b7a09e3d4088013ddb4c4fd44f1955406f1d /nsswitch
parentd3a0a6f2b31e100b40d1050a38ffa5d2922f0794 (diff)
downloadsamba-6958fac28d47b49402dd48778563ee612f6b6549.tar.gz
samba-6958fac28d47b49402dd48778563ee612f6b6549.tar.xz
samba-6958fac28d47b49402dd48778563ee612f6b6549.zip
wbinfo4: Add --gid-info option
Diffstat (limited to 'nsswitch')
-rw-r--r--nsswitch/wbinfo4.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/nsswitch/wbinfo4.c b/nsswitch/wbinfo4.c
index 465c3f793cf..bb6d7a8cf9d 100644
--- a/nsswitch/wbinfo4.c
+++ b/nsswitch/wbinfo4.c
@@ -213,6 +213,34 @@ static bool wbinfo_get_groupinfo(char *group)
return true;
}
+/* pull grent for a given gid */
+static bool wbinfo_get_gidinfo(int gid)
+{
+ struct winbindd_request request;
+ struct winbindd_response response;
+ NSS_STATUS result;
+
+ ZERO_STRUCT(request);
+ ZERO_STRUCT(response);
+
+ /* Send request */
+
+ request.data.gid = gid;
+
+ result = winbindd_request_response(WINBINDD_GETGRGID, &request,
+ &response);
+
+ if ( result != NSS_STATUS_SUCCESS)
+ return false;
+
+ d_printf( "%s:%s:%d\n",
+ response.data.gr.gr_name,
+ response.data.gr.gr_passwd,
+ response.data.gr.gr_gid );
+
+ return true;
+}
+
/* List groups a user is a member of */
static bool wbinfo_get_usergroups(char *user)
@@ -1005,6 +1033,7 @@ enum {
OPT_LIST_OWN_DOMAIN,
OPT_UID_INFO,
OPT_GROUP_INFO,
+ OPT_GID_INFO,
};
int main(int argc, char **argv, char **envp)
@@ -1042,6 +1071,7 @@ int main(int argc, char **argv, char **envp)
{ "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" },
+ { "gid-info", 0, POPT_ARG_INT, &int_arg, OPT_GID_INFO, "Get group info from gid", "GID" },
{ "user-groups", 'r', POPT_ARG_STRING, &string_arg, 'r', "Get user groups", "USER" },
{ "user-domgroups", 0, POPT_ARG_STRING, &string_arg,
OPT_USERDOMGROUPS, "Get user domain groups", "SID" },
@@ -1192,6 +1222,13 @@ int main(int argc, char **argv, char **envp)
goto done;
}
break;
+ case OPT_GID_INFO:
+ if ( !wbinfo_get_gidinfo(int_arg)) {
+ d_fprintf(stderr, "Could not get info for gid "
+ "%d\n", int_arg);
+ goto done;
+ }
+ break;
case 'r':
if (!wbinfo_get_usergroups(string_arg)) {
d_fprintf(stderr, "Could not get groups for user %s\n",