From: Volker Lendecke Date: Tue, 9 Jun 2009 13:23:33 +0000 (+0200) Subject: Make "net sam [add|del]mem" work for domain groups X-Git-Tag: tdb-1.1.5~152 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6545e9e2ac50fc9afeaccc1bf9965d12bb3121e6;p=thirdparty%2Fsamba.git Make "net sam [add|del]mem" work for domain groups --- diff --git a/source3/utils/net_sam.c b/source3/utils/net_sam.c index 1919b40605e..0d8b6ff4821 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],