summaryrefslogtreecommitdiff
path: root/source3/lib
diff options
context:
space:
mode:
authorGünther Deschner <gd@samba.org>2008-08-11 19:42:42 +0200
committerGünther Deschner <gd@samba.org>2008-08-11 19:47:53 +0200
commitb65fcbc1f52a6a737d62241721bfe8a97dd79c62 (patch)
tree1dc73a255eafc06689d7194a56a88bdf28e9a218 /source3/lib
parent14364acd085bf8c8eb962fdca100199c573b5333 (diff)
downloadsamba-b65fcbc1f52a6a737d62241721bfe8a97dd79c62.tar.gz
samba-b65fcbc1f52a6a737d62241721bfe8a97dd79c62.tar.bz2
samba-b65fcbc1f52a6a737d62241721bfe8a97dd79c62.zip
netapi: implement NetLocalGroupDelMembers_r().
Guenther (This used to be commit bd31d8f9ec9a24ca68e1d5441c0cafd98132060f)
Diffstat (limited to 'source3/lib')
-rw-r--r--source3/lib/netapi/localgroup.c41
1 files changed, 36 insertions, 5 deletions
diff --git a/source3/lib/netapi/localgroup.c b/source3/lib/netapi/localgroup.c
index aeaa96a84c..f9a0506e7c 100644
--- a/source3/lib/netapi/localgroup.c
+++ b/source3/lib/netapi/localgroup.c
@@ -1015,7 +1015,8 @@ static NTSTATUS libnetapi_lsa_lookup_names3(TALLOC_CTX *mem_ctx,
****************************************************************/
static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
- struct NetLocalGroupAddMembers *add)
+ struct NetLocalGroupAddMembers *add,
+ struct NetLocalGroupDelMembers *del)
{
struct NetLocalGroupAddMembers *r = NULL;
@@ -1034,9 +1035,11 @@ static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
struct LOCALGROUP_MEMBERS_INFO_3 *info3 = NULL;
struct dom_sid *add_sids = NULL;
+ struct dom_sid *del_sids = NULL;
size_t num_add_sids = 0;
+ size_t num_del_sids = 0;
- if (!add) {
+ if ((!add && !del) || (add && del)) {
return WERR_INVALID_PARAM;
}
@@ -1044,6 +1047,10 @@ static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
r = add;
}
+ if (del) {
+ r = (struct NetLocalGroupAddMembers *)del;
+ }
+
if (!r->in.group_name) {
return WERR_INVALID_PARAM;
}
@@ -1183,6 +1190,18 @@ static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
}
}
+ if (del) {
+ for (i=0; i < r->in.total_entries; i++) {
+ status = add_sid_to_array_unique(ctx, &member_sids[i],
+ &del_sids,
+ &num_del_sids);
+ if (!NT_STATUS_IS_OK(status)) {
+ werr = ntstatus_to_werror(status);
+ goto done;
+ }
+ }
+ }
+
/* add list */
for (i=0; i < num_add_sids; i++) {
@@ -1195,6 +1214,18 @@ static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
}
}
+ /* del list */
+
+ for (i=0; i < num_del_sids; i++) {
+ status = rpccli_samr_DeleteAliasMember(pipe_cli, ctx,
+ &alias_handle,
+ &del_sids[i]);
+ if (!NT_STATUS_IS_OK(status)) {
+ werr = ntstatus_to_werror(status);
+ goto done;
+ }
+ }
+
werr = WERR_OK;
done:
@@ -1221,7 +1252,7 @@ static WERROR NetLocalGroupModifyMembers_r(struct libnetapi_ctx *ctx,
WERROR NetLocalGroupAddMembers_r(struct libnetapi_ctx *ctx,
struct NetLocalGroupAddMembers *r)
{
- return NetLocalGroupModifyMembers_r(ctx, r);
+ return NetLocalGroupModifyMembers_r(ctx, r, NULL);
}
/****************************************************************
@@ -1239,7 +1270,7 @@ WERROR NetLocalGroupAddMembers_l(struct libnetapi_ctx *ctx,
WERROR NetLocalGroupDelMembers_r(struct libnetapi_ctx *ctx,
struct NetLocalGroupDelMembers *r)
{
- return WERR_NOT_SUPPORTED;
+ return NetLocalGroupModifyMembers_r(ctx, NULL, r);
}
/****************************************************************
@@ -1248,7 +1279,7 @@ WERROR NetLocalGroupDelMembers_r(struct libnetapi_ctx *ctx,
WERROR NetLocalGroupDelMembers_l(struct libnetapi_ctx *ctx,
struct NetLocalGroupDelMembers *r)
{
- return WERR_NOT_SUPPORTED;
+ return NetLocalGroupDelMembers_r(ctx, r);
}
/****************************************************************