]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
netapi: add skeleton for NetGroupEnum().
authorGünther Deschner <gd@samba.org>
Tue, 1 Jul 2008 18:11:02 +0000 (20:11 +0200)
committerGünther Deschner <gd@samba.org>
Thu, 17 Jul 2008 08:35:08 +0000 (10:35 +0200)
Guenther

source/lib/netapi/group.c
source/lib/netapi/libnetapi.c
source/lib/netapi/libnetapi.h

index 00e995dc839c10c02f1a109940eb5922f324c694..5807ad83c12609091ce6372583ff2a3225588080 100644 (file)
@@ -1013,3 +1013,21 @@ WERROR NetGroupDelUser_l(struct libnetapi_ctx *ctx,
 {
        return NetGroupDelUser_r(ctx, r);
 }
+
+/****************************************************************
+****************************************************************/
+
+WERROR NetGroupEnum_r(struct libnetapi_ctx *ctx,
+                     struct NetGroupEnum *r)
+{
+       return WERR_NOT_SUPPORTED;
+}
+
+/****************************************************************
+****************************************************************/
+
+WERROR NetGroupEnum_l(struct libnetapi_ctx *ctx,
+                     struct NetGroupEnum *r)
+{
+       return WERR_NOT_SUPPORTED;
+}
index 659c4c7e5f4766b7b878c6e59ad0e6c20b74f1d9..0953de6058cb0197e38977efc9125f0503a0972b 100644 (file)
@@ -771,6 +771,59 @@ NET_API_STATUS NetGroupDel(const char * server_name /* [in] */,
        return r.out.result;
 }
 
+/****************************************************************
+ NetGroupEnum
+****************************************************************/
+
+NET_API_STATUS NetGroupEnum(const char * server_name /* [in] */,
+                           uint32_t level /* [in] */,
+                           uint8_t **buffer /* [out] [ref] */,
+                           uint32_t prefmaxlen /* [in] */,
+                           uint32_t *entries_read /* [out] [ref] */,
+                           uint32_t *total_entries /* [out] [ref] */,
+                           uint32_t *resume_handle /* [in,out] [ref] */)
+{
+       struct NetGroupEnum r;
+       struct libnetapi_ctx *ctx = NULL;
+       NET_API_STATUS status;
+       WERROR werr;
+
+       status = libnetapi_getctx(&ctx);
+       if (status != 0) {
+               return status;
+       }
+
+       /* In parameters */
+       r.in.server_name = server_name;
+       r.in.level = level;
+       r.in.prefmaxlen = prefmaxlen;
+       r.in.resume_handle = resume_handle;
+
+       /* Out parameters */
+       r.out.buffer = buffer;
+       r.out.entries_read = entries_read;
+       r.out.total_entries = total_entries;
+       r.out.resume_handle = resume_handle;
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(NetGroupEnum, &r);
+       }
+
+       if (LIBNETAPI_LOCAL_SERVER(server_name)) {
+               werr = NetGroupEnum_l(ctx, &r);
+       } else {
+               werr = NetGroupEnum_r(ctx, &r);
+       }
+
+       r.out.result = W_ERROR_V(werr);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(NetGroupEnum, &r);
+       }
+
+       return r.out.result;
+}
+
 /****************************************************************
  NetGroupSetInfo
 ****************************************************************/
index 1364a4c08fcbf3aef994ab0033a88c1c2bd3147c..a6c8e84b6bfd612dedb07f173e11d248a0b51aca 100644 (file)
@@ -133,6 +133,17 @@ WERROR NetGroupDel_r(struct libnetapi_ctx *ctx,
                     struct NetGroupDel *r);
 WERROR NetGroupDel_l(struct libnetapi_ctx *ctx,
                     struct NetGroupDel *r);
+NET_API_STATUS NetGroupEnum(const char * server_name /* [in] */,
+                           uint32_t level /* [in] */,
+                           uint8_t **buffer /* [out] [ref] */,
+                           uint32_t prefmaxlen /* [in] */,
+                           uint32_t *entries_read /* [out] [ref] */,
+                           uint32_t *total_entries /* [out] [ref] */,
+                           uint32_t *resume_handle /* [in,out] [ref] */);
+WERROR NetGroupEnum_r(struct libnetapi_ctx *ctx,
+                     struct NetGroupEnum *r);
+WERROR NetGroupEnum_l(struct libnetapi_ctx *ctx,
+                     struct NetGroupEnum *r);
 NET_API_STATUS NetGroupSetInfo(const char * server_name /* [in] */,
                               const char * group_name /* [in] */,
                               uint32_t level /* [in] */,