From 6545e9e2ac50fc9afeaccc1bf9965d12bb3121e6 Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Tue, 9 Jun 2009 15:23:33 +0200 Subject: Make "net sam [add|del]mem" work for domain groups --- source3/utils/net_sam.c | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'source3/utils/net_sam.c') diff --git a/source3/utils/net_sam.c b/source3/utils/net_sam.c index 1919b40605..0d8b6ff482 100644 --- a/source3/utils/net_sam.c +++ b/source3/utils/net_sam.c @@ -1178,6 +1178,18 @@ static int net_sam_addmem(struct net_context *c, int argc, const char **argv) "with %s\n", nt_errstr(status)); return -1; } + } else if (grouptype == SID_NAME_DOM_GRP) { + uint32_t grouprid, memberrid; + + sid_peek_rid(&group, &grouprid); + sid_peek_rid(&member, &memberrid); + + status = pdb_add_groupmem(talloc_tos(), grouprid, memberrid); + if (!NT_STATUS_IS_OK(status)) { + d_fprintf(stderr, "Adding domain group member failed " + "with %s\n", nt_errstr(status)); + return -1; + } } else { d_fprintf(stderr, "Can only add members to local groups so " "far, %s is a %s\n", argv[0], @@ -1233,6 +1245,18 @@ static int net_sam_delmem(struct net_context *c, int argc, const char **argv) "with %s\n", nt_errstr(status)); return -1; } + } else if (grouptype == SID_NAME_DOM_GRP) { + uint32_t grouprid, memberrid; + + sid_peek_rid(&group, &grouprid); + sid_peek_rid(&member, &memberrid); + + status = pdb_del_groupmem(talloc_tos(), grouprid, memberrid); + if (!NT_STATUS_IS_OK(status)) { + d_fprintf(stderr, "Deleting domain group member " + "failed with %s\n", nt_errstr(status)); + return -1; + } } else { d_fprintf(stderr, "Can only delete members from local groups " "so far, %s is a %s\n", argv[0], -- cgit