we can now do a level1 NetDfsEnum()
authorAndrew Tridgell <tridge@samba.org>
Fri, 14 Nov 2003 07:20:46 +0000 (07:20 +0000)
committerAndrew Tridgell <tridge@samba.org>
Fri, 14 Nov 2003 07:20:46 +0000 (07:20 +0000)
(This used to be commit f32641f73f7ff12b797378b3b533603ff1d526b5)

12 files changed:
source4/librpc/idl/dfs.idl
source4/librpc/idl/echo.idl
source4/librpc/ndr/ndr.c
source4/librpc/ndr/ndr_basic.c
source4/librpc/ndr/ndr_dfs.c
source4/librpc/ndr/ndr_dfs.h
source4/librpc/ndr/ndr_echo.c
source4/librpc/ndr/ndr_echo.h
source4/librpc/ndr/ndr_lsa.c
source4/librpc/rpc/dcerpc.c
source4/torture/rpc/dfs.c
source4/torture/rpc/echo.c

index 110dc3563d87dfa8a7b3faefb7cd799eaeb90ffd..19781568a3454ef7c1942804d1ddbaf448808b6b 100644 (file)
@@ -39,7 +39,7 @@
        /******************/
        /* Function: 0x04 */
        NTSTATUS dfs_Info (
-               [in,ref] unistr *path,
+               [in,ref] unistr_noterm *path,
                [in]     unistr *server,
                [in]     unistr *share,
                [in]     uint16 level
        /******************/
        /* Function: 0x05 */
 
+       typedef struct {
+               unistr *str;
+       } dfs_String;
+
+       typedef struct {
+               uint32 count;
+               [size_is(count)] dfs_String *s;
+       } dfs_Enum1;
+
+       typedef union {
+               case(1) dfs_Enum1 *enum1;
+       } dfs_EnumInfo;
+
+       typedef struct {
+               uint32 level;
+               [switch_is(level)] dfs_EnumInfo e;
+       } dfs_EnumStruct;
+
        NTSTATUS dfs_Enum (
-               [in] unistr *name,
                [in] uint32 level,
-               [in] uint32 buffer_size
+               [in] uint32 bufsize,
+               [in,out] dfs_EnumStruct *info,
+               [in]     uint32 *unknown,
+               [in,out] uint32 *total
                );
 }
index af6cb567d7ef6442c82e7f631708b110c515eed9..f7c65485f85b229debcd0274e9fa545f0bd63a3b 100644 (file)
@@ -25,16 +25,27 @@ interface rpcecho
                [out,ref,size_is(len)] uint8 *data
        );
 
-#define long uint32
+#define int uint32
 
        typedef struct {
-               long bar;
-               long count;
-               long foo;
-               [size_is(count)] long s[*];
+               int *count;
+       } echo_Enum1;
+
+       typedef struct {
+               int *count;
+       } echo_Enum3;
+
+       typedef union {
+               [case(1)] echo_Enum1 enum1;
+               [case(3)] echo_Enum3 enum3;
+       } echo_EnumInfo;
+
+       typedef struct {
+               int level;
+               [switch_is(level)] echo_EnumInfo e;
        } Struct1;
        
        void TestCall (
-               [out]        Struct1 **s1
+               [out]        Struct1 *s1
                );
 }
index 307f5988f8432c7cb86b2c860da21de9c2c420c6..3c2ed6e55b2ba4166f7354f06a168160a889efaa 100644 (file)
@@ -337,3 +337,22 @@ NTSTATUS ndr_pull_error(struct ndr_pull *ndr, enum ndr_err_code err, const char
        /* we should map to different status codes */
        return NT_STATUS_INVALID_PARAMETER;
 }
+
+/*
+  return and possibly log an NDR error
+*/
+NTSTATUS ndr_push_error(struct ndr_push *ndr, enum ndr_err_code err, const char *format, ...)
+{
+       char *s=NULL;
+       va_list ap;
+
+       va_start(ap, format);
+       vasprintf(&s, format, ap);
+       va_end(ap);
+
+       DEBUG(3,("ndr_push_error(%u): %s\n", err, s));
+
+       free(s);
+       /* we should map to different status codes */
+       return NT_STATUS_INVALID_PARAMETER;
+}
index a643f658c06b328d1eafe3df63ea49fdc86af022..6208943d94c1b1087e4074c8401fa7326c7fb8a7 100644 (file)
@@ -238,6 +238,18 @@ NTSTATUS ndr_push_array_uint8(struct ndr_push *ndr, const char *data, uint32 n)
        return ndr_push_bytes(ndr, data, n);
 }
 
+/*
+  push an array of uint32
+*/
+NTSTATUS ndr_push_array_uint32(struct ndr_push *ndr, const uint32 *data, uint32 n)
+{
+       int i;
+       for (i=0;i<n;i++) {
+               NDR_CHECK(ndr_push_uint32(ndr, data[i]));
+       }
+       return NT_STATUS_OK;
+}
+
 /*
   save the current position
  */
index e561bdadcac03b52f882bb9cf930ea2cdae8eacb..57872d03df6742d5616ffc91e90ae0188e2b4697 100644 (file)
@@ -8,13 +8,6 @@ NTSTATUS ndr_push_dfs_Exist(struct ndr_push *ndr, struct dfs_Exist *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_dfs_Exist(struct ndr_pull *ndr, struct dfs_Exist *r)
-{
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.exist_flag));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_push_dfs_Add(struct ndr_push *ndr, struct dfs_Add *r)
 {
        NDR_CHECK(ndr_push_ptr(ndr, r->in.path));
@@ -38,16 +31,30 @@ NTSTATUS ndr_push_dfs_Add(struct ndr_push *ndr, struct dfs_Add *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_dfs_Add(struct ndr_pull *ndr, struct dfs_Add *r)
+NTSTATUS ndr_push_dfs_Remove(struct ndr_push *ndr, struct dfs_Remove *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       NDR_CHECK(ndr_push_unistr(ndr, r->in.path));
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.server));
+       if (r->in.server) {
+               NDR_CHECK(ndr_push_unistr(ndr, r->in.server));
+       }
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.share));
+       if (r->in.share) {
+               NDR_CHECK(ndr_push_unistr(ndr, r->in.share));
+       }
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_dfs_Remove(struct ndr_push *ndr, struct dfs_Remove *r)
+NTSTATUS ndr_push_dfs_UNKNOWN3(struct ndr_push *ndr, struct dfs_UNKNOWN3 *r)
 {
-       NDR_CHECK(ndr_push_unistr(ndr, r->in.path));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_push_dfs_Info(struct ndr_push *ndr, struct dfs_Info *r)
+{
+       NDR_CHECK(ndr_push_unistr_noterm(ndr, r->in.path));
        NDR_CHECK(ndr_push_ptr(ndr, r->in.server));
        if (r->in.server) {
                NDR_CHECK(ndr_push_unistr(ndr, r->in.server));
@@ -56,19 +63,119 @@ NTSTATUS ndr_push_dfs_Remove(struct ndr_push *ndr, struct dfs_Remove *r)
        if (r->in.share) {
                NDR_CHECK(ndr_push_unistr(ndr, r->in.share));
        }
+       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_dfs_Remove(struct ndr_pull *ndr, struct dfs_Remove *r)
+static NTSTATUS ndr_push_dfs_String(struct ndr_push *ndr, int ndr_flags, struct dfs_String *r)
+{
+       NDR_CHECK(ndr_push_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_push_ptr(ndr, r->str));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->str) {
+               NDR_CHECK(ndr_push_unistr(ndr, r->str));
+       }
+done:
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_push_dfs_Enum1(struct ndr_push *ndr, int ndr_flags, struct dfs_Enum1 *r)
+{
+       NDR_CHECK(ndr_push_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_push_uint32(ndr, r->count));
+       NDR_CHECK(ndr_push_ptr(ndr, r->s));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->s) {
+               NDR_CHECK(ndr_push_uint32(ndr, r->count));
+               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->s, sizeof(r->s[0]), r->count, (ndr_push_flags_fn_t)ndr_push_dfs_String));
+       }
+done:
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_push_dfs_EnumInfo(struct ndr_push *ndr, int ndr_flags, uint16 level, union dfs_EnumInfo *r)
+{
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_push_uint16(ndr, level));
+       switch (level) {
+       case 1:
+       NDR_CHECK(ndr_push_ptr(ndr, r->enum1));
+       break;
+
+       default:
+               return ndr_push_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", level);
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       switch (level) {
+       case 1:
+       if (r->enum1) {
+               NDR_CHECK(ndr_push_dfs_Enum1(ndr, ndr_flags, r->enum1));
+       }
+       break;
+
+       default:
+               return ndr_push_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", level);
+       }
+done:
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_push_dfs_EnumStruct(struct ndr_push *ndr, int ndr_flags, struct dfs_EnumStruct *r)
+{
+       NDR_CHECK(ndr_push_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_push_uint32(ndr, r->level));
+       NDR_CHECK(ndr_push_dfs_EnumInfo(ndr, NDR_SCALARS, r->level, &r->e));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       NDR_CHECK(ndr_push_dfs_EnumInfo(ndr, NDR_BUFFERS, r->level, &r->e));
+done:
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_push_dfs_Enum(struct ndr_push *ndr, struct dfs_Enum *r)
+{
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.level));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.bufsize));
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.info));
+       if (r->in.info) {
+               NDR_CHECK(ndr_push_dfs_EnumStruct(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.info));
+       }
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.unknown));
+       if (r->in.unknown) {
+               NDR_CHECK(ndr_push_uint32(ndr, *r->in.unknown));
+       }
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.total));
+       if (r->in.total) {
+               NDR_CHECK(ndr_push_uint32(ndr, *r->in.total));
+       }
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_dfs_Exist(struct ndr_pull *ndr, struct dfs_Exist *r)
+{
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.exist_flag));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_dfs_Add(struct ndr_pull *ndr, struct dfs_Add *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_dfs_UNKNOWN3(struct ndr_push *ndr, struct dfs_UNKNOWN3 *r)
+NTSTATUS ndr_pull_dfs_Remove(struct ndr_pull *ndr, struct dfs_Remove *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
@@ -80,47 +187,193 @@ NTSTATUS ndr_pull_dfs_UNKNOWN3(struct ndr_pull *ndr, struct dfs_UNKNOWN3 *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_dfs_Info(struct ndr_push *ndr, struct dfs_Info *r)
+NTSTATUS ndr_pull_dfs_Info(struct ndr_pull *ndr, struct dfs_Info *r)
 {
-       NDR_CHECK(ndr_push_unistr(ndr, r->in.path));
-       NDR_CHECK(ndr_push_ptr(ndr, r->in.server));
-       if (r->in.server) {
-               NDR_CHECK(ndr_push_unistr(ndr, r->in.server));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_pull_dfs_String(struct ndr_pull *ndr, int ndr_flags, struct dfs_String *r)
+{
+       uint32 _ptr_str;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_str));
+       if (_ptr_str) {
+               NDR_ALLOC(ndr, r->str);
+       } else {
+               r->str = NULL;
        }
-       NDR_CHECK(ndr_push_ptr(ndr, r->in.share));
-       if (r->in.share) {
-               NDR_CHECK(ndr_push_unistr(ndr, r->in.share));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->str) {
+               NDR_CHECK(ndr_pull_unistr(ndr, &r->str));
        }
-       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
+done:
+       return NT_STATUS_OK;
+}
 
+static NTSTATUS ndr_pull_dfs_Enum1(struct ndr_pull *ndr, int ndr_flags, struct dfs_Enum1 *r)
+{
+       uint32 _ptr_s;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_s));
+       if (_ptr_s) {
+               NDR_ALLOC(ndr, r->s);
+       } else {
+               r->s = NULL;
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->s) {
+       {
+               uint32 _array_size;
+               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
+               if (r->count > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
+               }
+       }
+               NDR_ALLOC_N_SIZE(ndr, r->s, r->count, sizeof(r->s[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->s, sizeof(r->s[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_dfs_String));
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_dfs_Info(struct ndr_pull *ndr, struct dfs_Info *r)
+static NTSTATUS ndr_pull_dfs_EnumInfo(struct ndr_pull *ndr, int ndr_flags, uint16 *level, union dfs_EnumInfo *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint16(ndr, level));
+       switch (*level) {
+       case 1: {
+               uint32 _ptr_enum1;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_enum1));
+       if (_ptr_enum1) {
+               NDR_ALLOC(ndr, r->enum1);
+       } else {
+               r->enum1 = NULL;
+       }
+       break; }
+
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       switch (*level) {
+       case 1:
+       if (r->enum1) {
+               NDR_CHECK(ndr_pull_dfs_Enum1(ndr, NDR_SCALARS|NDR_BUFFERS, r->enum1));
+       }
+       break;
 
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_dfs_Enum(struct ndr_push *ndr, struct dfs_Enum *r)
+static NTSTATUS ndr_pull_dfs_EnumStruct(struct ndr_pull *ndr, int ndr_flags, struct dfs_EnumStruct *r)
 {
-       NDR_CHECK(ndr_push_ptr(ndr, r->in.name));
-       if (r->in.name) {
-               NDR_CHECK(ndr_push_unistr(ndr, r->in.name));
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->level));
+       { uint16 _level;
+       NDR_CHECK(ndr_pull_dfs_EnumInfo(ndr, NDR_SCALARS, &_level, &r->e));
+       if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in e");
        }
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.level));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.buffer_size));
-       NDR_CHECK(ndr_push_uint32(ndr, *r->in.resume_handle));
-
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       { uint16 _level;
+       NDR_CHECK(ndr_pull_dfs_EnumInfo(ndr, NDR_BUFFERS, &_level, &r->e));
+       if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in e");
+       }
+done:
        return NT_STATUS_OK;
 }
 
 NTSTATUS ndr_pull_dfs_Enum(struct ndr_pull *ndr, struct dfs_Enum *r)
 {
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
+       uint32 _ptr_info;
+       uint32 _ptr_total;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_info));
+       if (_ptr_info) {
+               NDR_ALLOC(ndr, r->out.info);
+       } else {
+               r->out.info = NULL;
+       }
+       if (r->out.info) {
+               NDR_CHECK(ndr_pull_dfs_EnumStruct(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.info));
+       }
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_total));
+       if (_ptr_total) {
+               NDR_ALLOC(ndr, r->out.total);
+       } else {
+               r->out.total = NULL;
+       }
+       if (r->out.total) {
+               NDR_CHECK(ndr_pull_uint32(ndr, r->out.total));
+       }
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
+void ndr_print_dfs_String(struct ndr_print *ndr, const char *name, struct dfs_String *r)
+{
+       ndr_print_struct(ndr, name, "dfs_String");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "str", r->str);
+       ndr->depth++;
+       if (r->str) {
+               ndr_print_unistr(ndr, "str", r->str);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_dfs_Enum1(struct ndr_print *ndr, const char *name, struct dfs_Enum1 *r)
+{
+       ndr_print_struct(ndr, name, "dfs_Enum1");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "s", r->s);
+       ndr->depth++;
+       if (r->s) {
+               ndr_print_array(ndr, "s", r->s, sizeof(r->s[0]), r->count, (ndr_print_fn_t)ndr_print_dfs_String);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_dfs_EnumInfo(struct ndr_print *ndr, const char *name, uint16 level, union dfs_EnumInfo *r)
+{
+       ndr_print_union(ndr, name, level, "dfs_EnumInfo");
+       switch (level) {
+       case 1:
+       ndr_print_ptr(ndr, "enum1", r->enum1);
+       ndr->depth++;
+       if (r->enum1) {
+               ndr_print_dfs_Enum1(ndr, "enum1", r->enum1);
+       }
+       ndr->depth--;
+       break;
+
+       default:
+               ndr_print_bad_level(ndr, name, level);
+       }
+}
+
+void ndr_print_dfs_EnumStruct(struct ndr_print *ndr, const char *name, struct dfs_EnumStruct *r)
+{
+       ndr_print_struct(ndr, name, "dfs_EnumStruct");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "level", r->level);
+       ndr_print_dfs_EnumInfo(ndr, "e", r->level, &r->e);
+       ndr->depth--;
+}
+
index a1e0c2ef17207a7415a4dc583353264d4a51c212..ea8868f4503ce943675e0bc60d8ad2ddecebc61e 100644 (file)
@@ -62,16 +62,36 @@ struct dfs_Info {
 
 };
 
+struct dfs_String {
+       const char *str;
+};
+
+struct dfs_Enum1 {
+       uint32 count;
+       struct dfs_String *s;
+};
+
+union dfs_EnumInfo {
+/* [case(1)] */ struct dfs_Enum1 *enum1;
+};
+
+struct dfs_EnumStruct {
+       uint32 level;
+       union dfs_EnumInfo e;
+};
+
 struct dfs_Enum {
        struct {
-               const char *name;
                uint32 level;
-               uint32 buffer_size;
-               uint32 *resume_handle;
+               uint32 bufsize;
+               struct dfs_EnumStruct *info;
+               uint32 *unknown;
+               uint32 *total;
        } in;
 
        struct {
-               uint32 *resume_handle;
+               struct dfs_EnumStruct *info;
+               uint32 *total;
                NTSTATUS result;
        } out;
 
index fb186e1ce9d6135fbd265fdb0a29bc425e19d1f1..49f93dcdea5fb9be3377dce18500ee1457f331de 100644 (file)
@@ -9,24 +9,48 @@ NTSTATUS ndr_push_echo_AddOne(struct ndr_push *ndr, struct echo_AddOne *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_echo_AddOne(struct ndr_pull *ndr, struct echo_AddOne *r)
+NTSTATUS ndr_push_echo_EchoData(struct ndr_push *ndr, struct echo_EchoData *r)
 {
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.v));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
+       if (r->in.in_data) {
+               NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
+               NDR_CHECK(ndr_push_array_uint8(ndr, r->in.in_data, r->in.len));
+       }
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_echo_EchoData(struct ndr_push *ndr, struct echo_EchoData *r)
+NTSTATUS ndr_push_echo_SinkData(struct ndr_push *ndr, struct echo_SinkData *r)
 {
        NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
-       if (r->in.in_data) {
+       if (r->in.data) {
                NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
-               NDR_CHECK(ndr_push_array_uint8(ndr, r->in.in_data, r->in.len));
+               NDR_CHECK(ndr_push_array_uint8(ndr, r->in.data, r->in.len));
        }
 
        return NT_STATUS_OK;
 }
 
+NTSTATUS ndr_push_echo_SourceData(struct ndr_push *ndr, struct echo_SourceData *r)
+{
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_push_TestCall(struct ndr_push *ndr, struct TestCall *r)
+{
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_echo_AddOne(struct ndr_pull *ndr, struct echo_AddOne *r)
+{
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.v));
+
+       return NT_STATUS_OK;
+}
+
 NTSTATUS ndr_pull_echo_EchoData(struct ndr_pull *ndr, struct echo_EchoData *r)
 {
        if (r->out.out_data) {
@@ -44,30 +68,12 @@ NTSTATUS ndr_pull_echo_EchoData(struct ndr_pull *ndr, struct echo_EchoData *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_echo_SinkData(struct ndr_push *ndr, struct echo_SinkData *r)
-{
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
-       if (r->in.data) {
-               NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
-               NDR_CHECK(ndr_push_array_uint8(ndr, r->in.data, r->in.len));
-       }
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_echo_SinkData(struct ndr_pull *ndr, struct echo_SinkData *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_echo_SourceData(struct ndr_push *ndr, struct echo_SourceData *r)
-{
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.len));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_echo_SourceData(struct ndr_pull *ndr, struct echo_SourceData *r)
 {
        if (r->out.data) {
@@ -84,43 +90,96 @@ NTSTATUS ndr_pull_echo_SourceData(struct ndr_pull *ndr, struct echo_SourceData *
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_Struct1(struct ndr_pull *ndr, int ndr_flags, struct Struct1 *r)
+static NTSTATUS ndr_pull_echo_Enum1(struct ndr_pull *ndr, int ndr_flags, struct echo_Enum1 *r)
 {
-       uint32 _conformant_size;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_conformant_size));
+       uint32 _ptr_count;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->bar));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->foo));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_count));
+       if (_ptr_count) {
+               NDR_ALLOC(ndr, r->count);
+       } else {
+               r->count = NULL;
+       }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->count > _conformant_size) {
-               return ndr_pull_error(ndr, NDR_ERR_CONFORMANT_SIZE, "Bad conformant size %u should be %u", _conformant_size, r->count);
+       if (r->count) {
+               NDR_CHECK(ndr_pull_uint32(ndr, r->count));
        }
-               NDR_ALLOC_N_SIZE(ndr, r->s, _conformant_size, sizeof(r->s[0]));
-               NDR_CHECK(ndr_pull_array_uint32(ndr, r->s, r->count));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_Struct1(struct ndr_print *ndr, const char *name, struct Struct1 *r)
+static NTSTATUS ndr_pull_echo_Enum3(struct ndr_pull *ndr, int ndr_flags, struct echo_Enum3 *r)
 {
-       ndr_print_struct(ndr, name, "Struct1");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "bar", r->bar);
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_uint32(ndr, "foo", r->foo);
-       ndr_print_ptr(ndr, "s", r->s);
-       ndr->depth++;
-               ndr_print_array_uint32(ndr, "s", r->s, r->count);
-       ndr->depth--;
-       ndr->depth--;
+       uint32 _ptr_count;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_count));
+       if (_ptr_count) {
+               NDR_ALLOC(ndr, r->count);
+       } else {
+               r->count = NULL;
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->count) {
+               NDR_CHECK(ndr_pull_uint32(ndr, r->count));
+       }
+done:
+       return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_TestCall(struct ndr_push *ndr, struct TestCall *r)
+static NTSTATUS ndr_pull_echo_EnumInfo(struct ndr_pull *ndr, int ndr_flags, uint16 *level, union echo_EnumInfo *r)
 {
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint16(ndr, level));
+       switch (*level) {
+       case 1: {
+       NDR_CHECK(ndr_pull_echo_Enum1(ndr, NDR_SCALARS, &r->enum1));
+       break; }
+
+       case 3: {
+       NDR_CHECK(ndr_pull_echo_Enum3(ndr, NDR_SCALARS, &r->enum3));
+       break; }
+
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       switch (*level) {
+       case 1:
+               NDR_CHECK(ndr_pull_echo_Enum1(ndr, NDR_BUFFERS, &r->enum1));
+       break;
+
+       case 3:
+               NDR_CHECK(ndr_pull_echo_Enum3(ndr, NDR_BUFFERS, &r->enum3));
+       break;
+
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
+       }
+done:
+       return NT_STATUS_OK;
+}
 
+static NTSTATUS ndr_pull_Struct1(struct ndr_pull *ndr, int ndr_flags, struct Struct1 *r)
+{
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->level));
+       { uint16 _level;
+       NDR_CHECK(ndr_pull_echo_EnumInfo(ndr, NDR_SCALARS, &_level, &r->e));
+       if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in e");
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       { uint16 _level;
+       NDR_CHECK(ndr_pull_echo_EnumInfo(ndr, NDR_BUFFERS, &_level, &r->e));
+       if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in e");
+       }
+done:
        return NT_STATUS_OK;
 }
 
@@ -140,3 +199,55 @@ NTSTATUS ndr_pull_TestCall(struct ndr_pull *ndr, struct TestCall *r)
        return NT_STATUS_OK;
 }
 
+void ndr_print_echo_Enum1(struct ndr_print *ndr, const char *name, struct echo_Enum1 *r)
+{
+       ndr_print_struct(ndr, name, "echo_Enum1");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "count", r->count);
+       ndr->depth++;
+       if (r->count) {
+               ndr_print_uint32(ndr, "count", *r->count);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_echo_Enum3(struct ndr_print *ndr, const char *name, struct echo_Enum3 *r)
+{
+       ndr_print_struct(ndr, name, "echo_Enum3");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "count", r->count);
+       ndr->depth++;
+       if (r->count) {
+               ndr_print_uint32(ndr, "count", *r->count);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_echo_EnumInfo(struct ndr_print *ndr, const char *name, uint16 level, union echo_EnumInfo *r)
+{
+       ndr_print_union(ndr, name, level, "echo_EnumInfo");
+       switch (level) {
+       case 1:
+       ndr_print_echo_Enum1(ndr, "enum1", &r->enum1);
+       break;
+
+       case 3:
+       ndr_print_echo_Enum3(ndr, "enum3", &r->enum3);
+       break;
+
+       default:
+               ndr_print_bad_level(ndr, name, level);
+       }
+}
+
+void ndr_print_Struct1(struct ndr_print *ndr, const char *name, struct Struct1 *r)
+{
+       ndr_print_struct(ndr, name, "Struct1");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "level", r->level);
+       ndr_print_echo_EnumInfo(ndr, "e", r->level, &r->e);
+       ndr->depth--;
+}
+
index b2c6774c09d850f599414a5a4728d105680937ba..5edc4241a6c48325d72aedcbd660e3bec331cda8 100644 (file)
@@ -45,11 +45,22 @@ struct echo_SourceData {
 
 };
 
+struct echo_Enum1 {
+       uint32 *count;
+};
+
+struct echo_Enum3 {
+       uint32 *count;
+};
+
+union echo_EnumInfo {
+/* [case(1)] */ struct echo_Enum1 enum1;
+/* [case(3)] */ struct echo_Enum3 enum3;
+};
+
 struct Struct1 {
-       uint32 bar;
-       uint32 count;
-       uint32 foo;
-       uint32 *s;
+       uint32 level;
+       union echo_EnumInfo e;
 };
 
 struct TestCall {
@@ -57,7 +68,7 @@ struct TestCall {
        } in;
 
        struct {
-               struct Struct1 **s1;
+               struct Struct1 *s1;
        } out;
 
 };
index a1f01e0278dd0f083b5d078056415fba2ae1072b..571014a5d192c329c66a2d9cdc724334d3b7af5e 100644 (file)
@@ -9,14 +9,6 @@ NTSTATUS ndr_push_lsa_Close(struct ndr_push *ndr, struct lsa_Close *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_Close(struct ndr_pull *ndr, struct lsa_Close *r)
-{
-       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_push_lsa_Delete(struct ndr_push *ndr, struct lsa_Delete *r)
 {
        NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
@@ -24,13 +16,6 @@ NTSTATUS ndr_push_lsa_Delete(struct ndr_push *ndr, struct lsa_Delete *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_Delete(struct ndr_pull *ndr, struct lsa_Delete *r)
-{
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 static NTSTATUS ndr_push_lsa_Name(struct ndr_push *ndr, int ndr_flags, struct lsa_Name *r)
 {
        NDR_CHECK(ndr_push_align(ndr, 4));
@@ -47,110 +32,6 @@ done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_Name(struct ndr_pull *ndr, int ndr_flags, struct lsa_Name *r)
-{
-       uint32 _ptr_name;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint16(ndr, &r->name_len));
-       NDR_CHECK(ndr_pull_uint16(ndr, &r->name_size));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_name));
-       if (_ptr_name) {
-               NDR_ALLOC(ndr, r->name);
-       } else {
-               r->name = NULL;
-       }
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->name) {
-               NDR_CHECK(ndr_pull_unistr_noterm(ndr, &r->name));
-       }
-done:
-       return NT_STATUS_OK;
-}
-
-void ndr_print_lsa_Name(struct ndr_print *ndr, const char *name, struct lsa_Name *r)
-{
-       ndr_print_struct(ndr, name, "lsa_Name");
-       ndr->depth++;
-       ndr_print_uint16(ndr, "name_len", r->name_len);
-       ndr_print_uint16(ndr, "name_size", r->name_size);
-       ndr_print_ptr(ndr, "name", r->name);
-       ndr->depth++;
-       if (r->name) {
-               ndr_print_unistr_noterm(ndr, "name", r->name);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_PrivEntry(struct ndr_pull *ndr, int ndr_flags, struct lsa_PrivEntry *r)
-{
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->luid_low));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->luid_high));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
-done:
-       return NT_STATUS_OK;
-}
-
-void ndr_print_lsa_PrivEntry(struct ndr_print *ndr, const char *name, struct lsa_PrivEntry *r)
-{
-       ndr_print_struct(ndr, name, "lsa_PrivEntry");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_uint32(ndr, "luid_low", r->luid_low);
-       ndr_print_uint32(ndr, "luid_high", r->luid_high);
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_PrivArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_PrivArray *r)
-{
-       uint32 _ptr_privs;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_privs));
-       if (_ptr_privs) {
-               NDR_ALLOC(ndr, r->privs);
-       } else {
-               r->privs = NULL;
-       }
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->privs) {
-       {
-               uint32 _array_size;
-               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
-               if (r->count > _array_size) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
-               }
-       }
-               NDR_ALLOC_N_SIZE(ndr, r->privs, r->count, sizeof(r->privs[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->privs, sizeof(r->privs[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_PrivEntry));
-       }
-done:
-       return NT_STATUS_OK;
-}
-
-void ndr_print_lsa_PrivArray(struct ndr_print *ndr, const char *name, struct lsa_PrivArray *r)
-{
-       ndr_print_struct(ndr, name, "lsa_PrivArray");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "privs", r->privs);
-       ndr->depth++;
-       if (r->privs) {
-               ndr_print_array(ndr, "privs", r->privs, sizeof(r->privs[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_PrivEntry);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
 NTSTATUS ndr_push_lsa_EnumPrivs(struct ndr_push *ndr, struct lsa_EnumPrivs *r)
 {
        NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
@@ -160,54 +41,24 @@ NTSTATUS ndr_push_lsa_EnumPrivs(struct ndr_push *ndr, struct lsa_EnumPrivs *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_EnumPrivs(struct ndr_pull *ndr, struct lsa_EnumPrivs *r)
-{
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
-       NDR_CHECK(ndr_pull_lsa_PrivArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.privs));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_push_lsa_QuerySecObj(struct ndr_push *ndr, struct lsa_QuerySecObj *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_QuerySecObj(struct ndr_pull *ndr, struct lsa_QuerySecObj *r)
-{
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_push_lsa_SetSecObj(struct ndr_push *ndr, struct lsa_SetSecObj *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_SetSecObj(struct ndr_pull *ndr, struct lsa_SetSecObj *r)
-{
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_push_lsa_ChangePassword(struct ndr_push *ndr, struct lsa_ChangePassword *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_ChangePassword(struct ndr_pull *ndr, struct lsa_ChangePassword *r)
-{
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
 static NTSTATUS ndr_push_lsa_QosInfo(struct ndr_push *ndr, int ndr_flags, struct lsa_QosInfo *r)
 {
        struct ndr_push_save _save1, _save2, _save3;
@@ -230,16 +81,6 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_QosInfo(struct ndr_print *ndr, const char *name, struct lsa_QosInfo *r)
-{
-       ndr_print_struct(ndr, name, "lsa_QosInfo");
-       ndr->depth++;
-       ndr_print_uint16(ndr, "impersonation_level", r->impersonation_level);
-       ndr_print_uint8(ndr, "context_mode", r->context_mode);
-       ndr_print_uint8(ndr, "effective_only", r->effective_only);
-       ndr->depth--;
-}
-
 static NTSTATUS ndr_push_lsa_ObjectAttribute(struct ndr_push *ndr, int ndr_flags, struct lsa_ObjectAttribute *r)
 {
        struct ndr_push_save _save1, _save2, _save3;
@@ -276,38 +117,6 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_ObjectAttribute(struct ndr_print *ndr, const char *name, struct lsa_ObjectAttribute *r)
-{
-       ndr_print_struct(ndr, name, "lsa_ObjectAttribute");
-       ndr->depth++;
-       ndr_print_ptr(ndr, "root_dir", r->root_dir);
-       ndr->depth++;
-       if (r->root_dir) {
-               ndr_print_uint8(ndr, "root_dir", *r->root_dir);
-       }
-       ndr->depth--;
-       ndr_print_ptr(ndr, "object_name", r->object_name);
-       ndr->depth++;
-       if (r->object_name) {
-               ndr_print_unistr(ndr, "object_name", r->object_name);
-       }
-       ndr->depth--;
-       ndr_print_uint32(ndr, "attributes", r->attributes);
-       ndr_print_ptr(ndr, "sec_desc", r->sec_desc);
-       ndr->depth++;
-       if (r->sec_desc) {
-               ndr_print_security_descriptor(ndr, "sec_desc", r->sec_desc);
-       }
-       ndr->depth--;
-       ndr_print_ptr(ndr, "sec_qos", r->sec_qos);
-       ndr->depth++;
-       if (r->sec_qos) {
-               ndr_print_lsa_QosInfo(ndr, "sec_qos", r->sec_qos);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
 NTSTATUS ndr_push_lsa_OpenPolicy(struct ndr_push *ndr, struct lsa_OpenPolicy *r)
 {
        NDR_CHECK(ndr_push_ptr(ndr, r->in.system_name));
@@ -320,916 +129,666 @@ NTSTATUS ndr_push_lsa_OpenPolicy(struct ndr_push *ndr, struct lsa_OpenPolicy *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_OpenPolicy(struct ndr_pull *ndr, struct lsa_OpenPolicy *r)
+NTSTATUS ndr_push_lsa_QueryInfoPolicy(struct ndr_push *ndr, struct lsa_QueryInfoPolicy *r)
 {
-       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
 
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_AuditLogInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditLogInfo *r)
+NTSTATUS ndr_push_lsa_SetInfoPolicy(struct ndr_push *ndr, struct lsa_SetInfoPolicy *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->percent_full));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->log_size));
-       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->retention_time));
-       NDR_CHECK(ndr_pull_uint8(ndr, &r->shutdown_in_progress));
-       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->time_to_shutdown));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->next_audit_record));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->unknown));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-done:
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_AuditLogInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditLogInfo *r)
+NTSTATUS ndr_push_lsa_ClearAuditLog(struct ndr_push *ndr, struct lsa_ClearAuditLog *r)
 {
-       ndr_print_struct(ndr, name, "lsa_AuditLogInfo");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "percent_full", r->percent_full);
-       ndr_print_uint32(ndr, "log_size", r->log_size);
-       ndr_print_NTTIME(ndr, "retention_time", r->retention_time);
-       ndr_print_uint8(ndr, "shutdown_in_progress", r->shutdown_in_progress);
-       ndr_print_NTTIME(ndr, "time_to_shutdown", r->time_to_shutdown);
-       ndr_print_uint32(ndr, "next_audit_record", r->next_audit_record);
-       ndr_print_uint32(ndr, "unknown", r->unknown);
-       ndr->depth--;
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_AuditSettings(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditSettings *r)
+NTSTATUS ndr_push_lsa_CreateAccount(struct ndr_push *ndr, struct lsa_CreateAccount *r)
 {
-       uint32 _conformant_size;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_conformant_size));
-       NDR_CHECK(ndr_pull_align(ndr, 4));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_push_lsa_SidPtr(struct ndr_push *ndr, int ndr_flags, struct lsa_SidPtr *r)
+{
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_push_ptr(ndr, r->sid));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->count > _conformant_size) {
-               return ndr_pull_error(ndr, NDR_ERR_CONFORMANT_SIZE, "Bad conformant size %u should be %u", _conformant_size, r->count);
+       if (r->sid) {
+               NDR_CHECK(ndr_push_dom_sid2(ndr, r->sid));
        }
-               NDR_ALLOC_N_SIZE(ndr, r->settings, _conformant_size, sizeof(r->settings[0]));
-               NDR_CHECK(ndr_pull_array_uint32(ndr, r->settings, r->count));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_AuditSettings(struct ndr_print *ndr, const char *name, struct lsa_AuditSettings *r)
+static NTSTATUS ndr_push_lsa_SidArray(struct ndr_push *ndr, int ndr_flags, struct lsa_SidArray *r)
 {
-       ndr_print_struct(ndr, name, "lsa_AuditSettings");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "settings", r->settings);
-       ndr->depth++;
-               ndr_print_array_uint32(ndr, "settings", r->settings, r->count);
-       ndr->depth--;
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_AuditEventsInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditEventsInfo *r)
-{
-       uint32 _ptr_settings;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->auditing_mode));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_settings));
-       if (_ptr_settings) {
-               NDR_ALLOC(ndr, r->settings);
-       } else {
-               r->settings = NULL;
-       }
+       NDR_CHECK(ndr_push_uint32(ndr, r->num_sids));
+       NDR_CHECK(ndr_push_ptr(ndr, r->sids));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->settings) {
-               NDR_CHECK(ndr_pull_lsa_AuditSettings(ndr, NDR_SCALARS|NDR_BUFFERS, r->settings));
+       if (r->sids) {
+               NDR_CHECK(ndr_push_uint32(ndr, r->num_sids));
+               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_push_flags_fn_t)ndr_push_lsa_SidPtr));
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_AuditEventsInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditEventsInfo *r)
+NTSTATUS ndr_push_lsa_EnumAccounts(struct ndr_push *ndr, struct lsa_EnumAccounts *r)
 {
-       ndr_print_struct(ndr, name, "lsa_AuditEventsInfo");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "auditing_mode", r->auditing_mode);
-       ndr_print_ptr(ndr, "settings", r->settings);
-       ndr->depth++;
-       if (r->settings) {
-               ndr_print_lsa_AuditSettings(ndr, "settings", r->settings);
-       }
-       ndr->depth--;
-       ndr->depth--;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_uint32(ndr, *r->in.resume_handle));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_entries));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_DomainInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainInfo *r)
+NTSTATUS ndr_push_lsa_CreateTrustDom(struct ndr_push *ndr, struct lsa_CreateTrustDom *r)
 {
-       uint32 _ptr_sid;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
-       if (_ptr_sid) {
-               NDR_ALLOC(ndr, r->sid);
-       } else {
-               r->sid = NULL;
-       }
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
-       if (r->sid) {
-               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
-       }
-done:
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_DomainInfo(struct ndr_print *ndr, const char *name, struct lsa_DomainInfo *r)
+NTSTATUS ndr_push_lsa_EnumTrustDom(struct ndr_push *ndr, struct lsa_EnumTrustDom *r)
 {
-       ndr_print_struct(ndr, name, "lsa_DomainInfo");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_ptr(ndr, "sid", r->sid);
-       ndr->depth++;
-       if (r->sid) {
-               ndr_print_dom_sid2(ndr, "sid", r->sid);
-       }
-       ndr->depth--;
-       ndr->depth--;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_uint32(ndr, *r->in.resume_handle));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_entries));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_PDAccountInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_PDAccountInfo *r)
+static NTSTATUS ndr_push_lsa_TranslatedSid(struct ndr_push *ndr, int ndr_flags, struct lsa_TranslatedSid *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_push_uint16(ndr, r->sid_type));
+       NDR_CHECK(ndr_push_uint32(ndr, r->rid));
+       NDR_CHECK(ndr_push_uint32(ndr, r->sid_index));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_PDAccountInfo(struct ndr_print *ndr, const char *name, struct lsa_PDAccountInfo *r)
-{
-       ndr_print_struct(ndr, name, "lsa_PDAccountInfo");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_ServerRole(struct ndr_pull *ndr, int ndr_flags, struct lsa_ServerRole *r)
+static NTSTATUS ndr_push_lsa_TransSidArray(struct ndr_push *ndr, int ndr_flags, struct lsa_TransSidArray *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint16(ndr, &r->role));
+       NDR_CHECK(ndr_push_uint32(ndr, r->count));
+       NDR_CHECK(ndr_push_ptr(ndr, r->sids));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->sids) {
+               NDR_CHECK(ndr_push_uint32(ndr, r->count));
+               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->sids, sizeof(r->sids[0]), r->count, (ndr_push_flags_fn_t)ndr_push_lsa_TranslatedSid));
+       }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_ServerRole(struct ndr_print *ndr, const char *name, struct lsa_ServerRole *r)
+NTSTATUS ndr_push_lsa_LookupNames(struct ndr_push *ndr, struct lsa_LookupNames *r)
 {
-       ndr_print_struct(ndr, name, "lsa_ServerRole");
-       ndr->depth++;
-       ndr_print_uint16(ndr, "role", r->role);
-       ndr->depth--;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_names));
+       if (r->in.names) {
+               int ndr_flags = NDR_SCALARS|NDR_BUFFERS;
+               NDR_CHECK(ndr_push_uint32(ndr, r->in.num_names));
+               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->in.names, sizeof(r->in.names[0]), r->in.num_names, (ndr_push_flags_fn_t)ndr_push_lsa_Name));
+       }
+       NDR_CHECK(ndr_push_lsa_TransSidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.sids));
+       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
+       NDR_CHECK(ndr_push_uint32(ndr, *r->in.count));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_ReplicaSourceInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_ReplicaSourceInfo *r)
+static NTSTATUS ndr_push_lsa_TranslatedName(struct ndr_push *ndr, int ndr_flags, struct lsa_TranslatedName *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->source));
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->account));
+       NDR_CHECK(ndr_push_uint16(ndr, r->sid_type));
+       NDR_CHECK(ndr_push_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_push_uint32(ndr, r->sid_index));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->source));
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->account));
+               NDR_CHECK(ndr_push_lsa_Name(ndr, ndr_flags, &r->name));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_ReplicaSourceInfo(struct ndr_print *ndr, const char *name, struct lsa_ReplicaSourceInfo *r)
-{
-       ndr_print_struct(ndr, name, "lsa_ReplicaSourceInfo");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "source", &r->source);
-       ndr_print_lsa_Name(ndr, "account", &r->account);
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_DefaultQuotaInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DefaultQuotaInfo *r)
+static NTSTATUS ndr_push_lsa_TransNameArray(struct ndr_push *ndr, int ndr_flags, struct lsa_TransNameArray *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 8));
+       NDR_CHECK(ndr_push_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->paged_pool));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->non_paged_pool));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->min_wss));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->max_wss));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->pagefile));
-       NDR_CHECK(ndr_pull_HYPER_T(ndr, &r->unknown));
+       NDR_CHECK(ndr_push_uint32(ndr, r->count));
+       NDR_CHECK(ndr_push_ptr(ndr, r->names));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->names) {
+               NDR_CHECK(ndr_push_uint32(ndr, r->count));
+               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->names, sizeof(r->names[0]), r->count, (ndr_push_flags_fn_t)ndr_push_lsa_TranslatedName));
+       }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_DefaultQuotaInfo(struct ndr_print *ndr, const char *name, struct lsa_DefaultQuotaInfo *r)
+NTSTATUS ndr_push_lsa_LookupSids(struct ndr_push *ndr, struct lsa_LookupSids *r)
 {
-       ndr_print_struct(ndr, name, "lsa_DefaultQuotaInfo");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "paged_pool", r->paged_pool);
-       ndr_print_uint32(ndr, "non_paged_pool", r->non_paged_pool);
-       ndr_print_uint32(ndr, "min_wss", r->min_wss);
-       ndr_print_uint32(ndr, "max_wss", r->max_wss);
-       ndr_print_uint32(ndr, "pagefile", r->pagefile);
-       ndr_print_HYPER_T(ndr, "unknown", r->unknown);
-       ndr->depth--;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_lsa_SidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.sids));
+       NDR_CHECK(ndr_push_lsa_TransNameArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.names));
+       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
+       NDR_CHECK(ndr_push_uint32(ndr, *r->in.count));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_ModificationInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_ModificationInfo *r)
+NTSTATUS ndr_push_CREATESECRET(struct ndr_push *ndr, struct CREATESECRET *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 8));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_HYPER_T(ndr, &r->modified_id));
-       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->db_create_time));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-done:
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_ModificationInfo(struct ndr_print *ndr, const char *name, struct lsa_ModificationInfo *r)
+NTSTATUS ndr_push_lsa_OpenAccount(struct ndr_push *ndr, struct lsa_OpenAccount *r)
 {
-       ndr_print_struct(ndr, name, "lsa_ModificationInfo");
-       ndr->depth++;
-       ndr_print_HYPER_T(ndr, "modified_id", r->modified_id);
-       ndr_print_NTTIME(ndr, "db_create_time", r->db_create_time);
-       ndr->depth--;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_dom_sid2(ndr, r->in.sid));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_AuditFullSetInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditFullSetInfo *r)
+NTSTATUS ndr_push_lsa_EnumPrivsAccount(struct ndr_push *ndr, struct lsa_EnumPrivsAccount *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->shutdown_on_full));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-done:
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_AuditFullSetInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditFullSetInfo *r)
+NTSTATUS ndr_push_ADDPRIVS(struct ndr_push *ndr, struct ADDPRIVS *r)
 {
-       ndr_print_struct(ndr, name, "lsa_AuditFullSetInfo");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "shutdown_on_full", r->shutdown_on_full);
-       ndr->depth--;
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_AuditFullQueryInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditFullQueryInfo *r)
+NTSTATUS ndr_push_REMOVEPRIVS(struct ndr_push *ndr, struct REMOVEPRIVS *r)
 {
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->shutdown_on_full));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->log_is_full));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-done:
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_AuditFullQueryInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditFullQueryInfo *r)
+NTSTATUS ndr_push_GETQUOTAS(struct ndr_push *ndr, struct GETQUOTAS *r)
 {
-       ndr_print_struct(ndr, name, "lsa_AuditFullQueryInfo");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "shutdown_on_full", r->shutdown_on_full);
-       ndr_print_uint32(ndr, "log_is_full", r->log_is_full);
-       ndr->depth--;
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_DnsDomainInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DnsDomainInfo *r)
+NTSTATUS ndr_push_SETQUOTAS(struct ndr_push *ndr, struct SETQUOTAS *r)
 {
-       uint32 _ptr_sid;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->dns_domain));
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->dns_forest));
-       NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_guid));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
-       if (_ptr_sid) {
-               NDR_ALLOC(ndr, r->sid);
-       } else {
-               r->sid = NULL;
-       }
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->dns_domain));
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->dns_forest));
-               NDR_CHECK(ndr_pull_GUID(ndr, ndr_flags, &r->domain_guid));
-       if (r->sid) {
-               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
-       }
-done:
+
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_DnsDomainInfo(struct ndr_print *ndr, const char *name, struct lsa_DnsDomainInfo *r)
+NTSTATUS ndr_push_GETSYSTEMACCOUNT(struct ndr_push *ndr, struct GETSYSTEMACCOUNT *r)
 {
-       ndr_print_struct(ndr, name, "lsa_DnsDomainInfo");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_lsa_Name(ndr, "dns_domain", &r->dns_domain);
-       ndr_print_lsa_Name(ndr, "dns_forest", &r->dns_forest);
-       ndr_print_GUID(ndr, "domain_guid", &r->domain_guid);
-       ndr_print_ptr(ndr, "sid", r->sid);
-       ndr->depth++;
-       if (r->sid) {
-               ndr_print_dom_sid2(ndr, "sid", r->sid);
-       }
-       ndr->depth--;
-       ndr->depth--;
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_PolicyInformation(struct ndr_pull *ndr, int ndr_flags, uint16 *level, union lsa_PolicyInformation *r)
+NTSTATUS ndr_push_SETSYSTEMACCOUNT(struct ndr_push *ndr, struct SETSYSTEMACCOUNT *r)
 {
-       NDR_CHECK(ndr_pull_uint16(ndr, level));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       switch (*level) {
-       case 1:
-       NDR_CHECK(ndr_pull_lsa_AuditLogInfo(ndr, NDR_SCALARS, &r->audit_log));
-       break;
-
-       case 2:
-       NDR_CHECK(ndr_pull_lsa_AuditEventsInfo(ndr, NDR_SCALARS, &r->audit_events));
-       break;
-
-       case 3:
-       NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_SCALARS, &r->domain));
-       break;
-
-       case 4:
-       NDR_CHECK(ndr_pull_lsa_PDAccountInfo(ndr, NDR_SCALARS, &r->pd));
-       break;
-
-       case 5:
-       NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_SCALARS, &r->account_domain));
-       break;
-
-       case 6:
-       NDR_CHECK(ndr_pull_lsa_ServerRole(ndr, NDR_SCALARS, &r->role));
-       break;
-
-       case 7:
-       NDR_CHECK(ndr_pull_lsa_ReplicaSourceInfo(ndr, NDR_SCALARS, &r->replica));
-       break;
-
-       case 8:
-       NDR_CHECK(ndr_pull_lsa_DefaultQuotaInfo(ndr, NDR_SCALARS, &r->quota));
-       break;
-
-       case 9:
-       NDR_CHECK(ndr_pull_lsa_ModificationInfo(ndr, NDR_SCALARS, &r->db));
-       break;
-
-       case 10:
-       NDR_CHECK(ndr_pull_lsa_AuditFullSetInfo(ndr, NDR_SCALARS, &r->auditfullset));
-       break;
 
-       case 11:
-       NDR_CHECK(ndr_pull_lsa_AuditFullQueryInfo(ndr, NDR_SCALARS, &r->auditfullquery));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 12:
-       NDR_CHECK(ndr_pull_lsa_DnsDomainInfo(ndr, NDR_SCALARS, &r->dns));
-       break;
+NTSTATUS ndr_push_OPENTRUSTDOM(struct ndr_push *ndr, struct OPENTRUSTDOM *r)
+{
 
-       default:
-               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in ", *level);
-       }
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       switch (*level) {
-       case 1:
-               NDR_CHECK(ndr_pull_lsa_AuditLogInfo(ndr, NDR_BUFFERS, &r->audit_log));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 2:
-               NDR_CHECK(ndr_pull_lsa_AuditEventsInfo(ndr, NDR_BUFFERS, &r->audit_events));
-       break;
+NTSTATUS ndr_push_QUERYTRUSTDOM(struct ndr_push *ndr, struct QUERYTRUSTDOM *r)
+{
 
-       case 3:
-               NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_BUFFERS, &r->domain));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 4:
-               NDR_CHECK(ndr_pull_lsa_PDAccountInfo(ndr, NDR_BUFFERS, &r->pd));
-       break;
+NTSTATUS ndr_push_SETINFOTRUSTDOM(struct ndr_push *ndr, struct SETINFOTRUSTDOM *r)
+{
 
-       case 5:
-               NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_BUFFERS, &r->account_domain));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 6:
-               NDR_CHECK(ndr_pull_lsa_ServerRole(ndr, NDR_BUFFERS, &r->role));
-       break;
+NTSTATUS ndr_push_OPENSECRET(struct ndr_push *ndr, struct OPENSECRET *r)
+{
 
-       case 7:
-               NDR_CHECK(ndr_pull_lsa_ReplicaSourceInfo(ndr, NDR_BUFFERS, &r->replica));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 8:
-               NDR_CHECK(ndr_pull_lsa_DefaultQuotaInfo(ndr, NDR_BUFFERS, &r->quota));
-       break;
+NTSTATUS ndr_push_SETSECRET(struct ndr_push *ndr, struct SETSECRET *r)
+{
 
-       case 9:
-               NDR_CHECK(ndr_pull_lsa_ModificationInfo(ndr, NDR_BUFFERS, &r->db));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 10:
-               NDR_CHECK(ndr_pull_lsa_AuditFullSetInfo(ndr, NDR_BUFFERS, &r->auditfullset));
-       break;
+NTSTATUS ndr_push_QUERYSECRET(struct ndr_push *ndr, struct QUERYSECRET *r)
+{
 
-       case 11:
-               NDR_CHECK(ndr_pull_lsa_AuditFullQueryInfo(ndr, NDR_BUFFERS, &r->auditfullquery));
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 12:
-               NDR_CHECK(ndr_pull_lsa_DnsDomainInfo(ndr, NDR_BUFFERS, &r->dns));
-       break;
+NTSTATUS ndr_push_LOOKUPPRIVVALUE(struct ndr_push *ndr, struct LOOKUPPRIVVALUE *r)
+{
 
-       default:
-               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in ", *level);
-       }
-done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_PolicyInformation(struct ndr_print *ndr, const char *name, uint16 level, union lsa_PolicyInformation *r)
+NTSTATUS ndr_push_lsa_LookupPrivName(struct ndr_push *ndr, struct lsa_LookupPrivName *r)
 {
-       ndr_print_union(ndr, name, level, "lsa_PolicyInformation");
-       switch (level) {
-       case 1:
-       ndr_print_lsa_AuditLogInfo(ndr, "audit_log", &r->audit_log);
-       break;
-
-       case 2:
-       ndr_print_lsa_AuditEventsInfo(ndr, "audit_events", &r->audit_events);
-       break;
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.luid_high));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.luid_low));
 
-       case 3:
-       ndr_print_lsa_DomainInfo(ndr, "domain", &r->domain);
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 4:
-       ndr_print_lsa_PDAccountInfo(ndr, "pd", &r->pd);
-       break;
+NTSTATUS ndr_push_PRIV_GET_DISPNAME(struct ndr_push *ndr, struct PRIV_GET_DISPNAME *r)
+{
 
-       case 5:
-       ndr_print_lsa_DomainInfo(ndr, "account_domain", &r->account_domain);
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 6:
-       ndr_print_lsa_ServerRole(ndr, "role", &r->role);
-       break;
+NTSTATUS ndr_push_DELETEOBJECT(struct ndr_push *ndr, struct DELETEOBJECT *r)
+{
 
-       case 7:
-       ndr_print_lsa_ReplicaSourceInfo(ndr, "replica", &r->replica);
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 8:
-       ndr_print_lsa_DefaultQuotaInfo(ndr, "quota", &r->quota);
-       break;
+NTSTATUS ndr_push_ENUMACCTWITHRIGHT(struct ndr_push *ndr, struct ENUMACCTWITHRIGHT *r)
+{
 
-       case 9:
-       ndr_print_lsa_ModificationInfo(ndr, "db", &r->db);
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 10:
-       ndr_print_lsa_AuditFullSetInfo(ndr, "auditfullset", &r->auditfullset);
-       break;
+NTSTATUS ndr_push_lsa_EnumAccountRights(struct ndr_push *ndr, struct lsa_EnumAccountRights *r)
+{
+       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
+       NDR_CHECK(ndr_push_dom_sid2(ndr, r->in.sid));
 
-       case 11:
-       ndr_print_lsa_AuditFullQueryInfo(ndr, "auditfullquery", &r->auditfullquery);
-       break;
+       return NT_STATUS_OK;
+}
 
-       case 12:
-       ndr_print_lsa_DnsDomainInfo(ndr, "dns", &r->dns);
-       break;
+NTSTATUS ndr_push_ADDACCTRIGHTS(struct ndr_push *ndr, struct ADDACCTRIGHTS *r)
+{
 
-       default:
-               ndr_print_bad_level(ndr, name, level);
-       }
+       return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_QueryInfoPolicy(struct ndr_push *ndr, struct lsa_QueryInfoPolicy *r)
+NTSTATUS ndr_push_REMOVEACCTRIGHTS(struct ndr_push *ndr, struct REMOVEACCTRIGHTS *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_QueryInfoPolicy(struct ndr_pull *ndr, struct lsa_QueryInfoPolicy *r)
+NTSTATUS ndr_push_QUERYTRUSTDOMINFO(struct ndr_push *ndr, struct QUERYTRUSTDOMINFO *r)
 {
-       uint32 _ptr_info;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_info));
-       if (_ptr_info) {
-               NDR_ALLOC(ndr, r->out.info);
-       } else {
-               r->out.info = NULL;
-       }
-       if (r->out.info) {
-       { uint16 _level;
-       NDR_CHECK(ndr_pull_lsa_PolicyInformation(ndr, NDR_SCALARS|NDR_BUFFERS, &_level, r->out.info));
-       if (_level != r->in.level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in info");
-       }
-       }
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_SetInfoPolicy(struct ndr_push *ndr, struct lsa_SetInfoPolicy *r)
+NTSTATUS ndr_push_SETTRUSTDOMINFO(struct ndr_push *ndr, struct SETTRUSTDOMINFO *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_SetInfoPolicy(struct ndr_pull *ndr, struct lsa_SetInfoPolicy *r)
+NTSTATUS ndr_push_DELETETRUSTDOM(struct ndr_push *ndr, struct DELETETRUSTDOM *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_ClearAuditLog(struct ndr_push *ndr, struct lsa_ClearAuditLog *r)
+NTSTATUS ndr_push_STOREPRIVDATA(struct ndr_push *ndr, struct STOREPRIVDATA *r)
 {
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_ClearAuditLog(struct ndr_pull *ndr, struct lsa_ClearAuditLog *r)
+NTSTATUS ndr_push_RETRPRIVDATA(struct ndr_push *ndr, struct RETRPRIVDATA *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_CreateAccount(struct ndr_push *ndr, struct lsa_CreateAccount *r)
+NTSTATUS ndr_push_lsa_OpenPolicy2(struct ndr_push *ndr, struct lsa_OpenPolicy2 *r)
 {
+       NDR_CHECK(ndr_push_ptr(ndr, r->in.system_name));
+       if (r->in.system_name) {
+               NDR_CHECK(ndr_push_unistr(ndr, r->in.system_name));
+       }
+       NDR_CHECK(ndr_push_lsa_ObjectAttribute(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.attr));
+       NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_CreateAccount(struct ndr_pull *ndr, struct lsa_CreateAccount *r)
+NTSTATUS ndr_push_UNK_GET_CONNUSER(struct ndr_push *ndr, struct UNK_GET_CONNUSER *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_push_lsa_SidPtr(struct ndr_push *ndr, int ndr_flags, struct lsa_SidPtr *r)
+NTSTATUS ndr_push_QUERYINFO2(struct ndr_push *ndr, struct QUERYINFO2 *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
-       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_ptr(ndr, r->sid));
-buffers:
-       if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sid) {
-               NDR_CHECK(ndr_push_dom_sid2(ndr, r->sid));
-       }
-done:
+
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_SidPtr(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidPtr *r)
+NTSTATUS ndr_pull_lsa_Close(struct ndr_pull *ndr, struct lsa_Close *r)
 {
-       uint32 _ptr_sid;
+       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_lsa_Delete(struct ndr_pull *ndr, struct lsa_Delete *r)
+{
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_pull_lsa_Name(struct ndr_pull *ndr, int ndr_flags, struct lsa_Name *r)
+{
+       uint32 _ptr_name;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
-       if (_ptr_sid) {
-               NDR_ALLOC(ndr, r->sid);
+       NDR_CHECK(ndr_pull_uint16(ndr, &r->name_len));
+       NDR_CHECK(ndr_pull_uint16(ndr, &r->name_size));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_name));
+       if (_ptr_name) {
+               NDR_ALLOC(ndr, r->name);
        } else {
-               r->sid = NULL;
+               r->name = NULL;
        }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sid) {
-               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
+       if (r->name) {
+               NDR_CHECK(ndr_pull_unistr_noterm(ndr, &r->name));
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_SidPtr(struct ndr_print *ndr, const char *name, struct lsa_SidPtr *r)
-{
-       ndr_print_struct(ndr, name, "lsa_SidPtr");
-       ndr->depth++;
-       ndr_print_ptr(ndr, "sid", r->sid);
-       ndr->depth++;
-       if (r->sid) {
-               ndr_print_dom_sid2(ndr, "sid", r->sid);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_push_lsa_SidArray(struct ndr_push *ndr, int ndr_flags, struct lsa_SidArray *r)
+static NTSTATUS ndr_pull_lsa_PrivEntry(struct ndr_pull *ndr, int ndr_flags, struct lsa_PrivEntry *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
+       NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_uint32(ndr, r->num_sids));
-       NDR_CHECK(ndr_push_ptr(ndr, r->sids));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->luid_low));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->luid_high));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sids) {
-               NDR_CHECK(ndr_push_uint32(ndr, r->num_sids));
-               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_push_flags_fn_t)ndr_push_lsa_SidPtr));
-       }
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
 done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_SidArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidArray *r)
+static NTSTATUS ndr_pull_lsa_PrivArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_PrivArray *r)
 {
-       uint32 _ptr_sids;
+       uint32 _ptr_privs;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->num_sids));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sids));
-       if (_ptr_sids) {
-               NDR_ALLOC(ndr, r->sids);
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_privs));
+       if (_ptr_privs) {
+               NDR_ALLOC(ndr, r->privs);
        } else {
-               r->sids = NULL;
+               r->privs = NULL;
        }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sids) {
+       if (r->privs) {
        {
                uint32 _array_size;
                NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
-               if (r->num_sids > _array_size) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->num_sids);
+               if (r->count > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
                }
        }
-               NDR_ALLOC_N_SIZE(ndr, r->sids, r->num_sids, sizeof(r->sids[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_pull_flags_fn_t)ndr_pull_lsa_SidPtr));
+               NDR_ALLOC_N_SIZE(ndr, r->privs, r->count, sizeof(r->privs[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->privs, sizeof(r->privs[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_PrivEntry));
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_SidArray(struct ndr_print *ndr, const char *name, struct lsa_SidArray *r)
+NTSTATUS ndr_pull_lsa_EnumPrivs(struct ndr_pull *ndr, struct lsa_EnumPrivs *r)
 {
-       ndr_print_struct(ndr, name, "lsa_SidArray");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "num_sids", r->num_sids);
-       ndr_print_ptr(ndr, "sids", r->sids);
-       ndr->depth++;
-       if (r->sids) {
-               ndr_print_array(ndr, "sids", r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_print_fn_t)ndr_print_lsa_SidPtr);
-       }
-       ndr->depth--;
-       ndr->depth--;
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
+       NDR_CHECK(ndr_pull_lsa_PrivArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.privs));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_EnumAccounts(struct ndr_push *ndr, struct lsa_EnumAccounts *r)
+NTSTATUS ndr_pull_lsa_QuerySecObj(struct ndr_pull *ndr, struct lsa_QuerySecObj *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_uint32(ndr, *r->in.resume_handle));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_entries));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_EnumAccounts(struct ndr_pull *ndr, struct lsa_EnumAccounts *r)
+NTSTATUS ndr_pull_lsa_SetSecObj(struct ndr_pull *ndr, struct lsa_SetSecObj *r)
 {
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
-       NDR_CHECK(ndr_pull_lsa_SidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.sids));
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_CreateTrustDom(struct ndr_push *ndr, struct lsa_CreateTrustDom *r)
+NTSTATUS ndr_pull_lsa_ChangePassword(struct ndr_pull *ndr, struct lsa_ChangePassword *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_CreateTrustDom(struct ndr_pull *ndr, struct lsa_CreateTrustDom *r)
+NTSTATUS ndr_pull_lsa_OpenPolicy(struct ndr_pull *ndr, struct lsa_OpenPolicy *r)
 {
+       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_DomainInformation(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainInformation *r)
+static NTSTATUS ndr_pull_lsa_AuditLogInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditLogInfo *r)
 {
-       uint32 _ptr_sid;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
-       if (_ptr_sid) {
-               NDR_ALLOC(ndr, r->sid);
-       } else {
-               r->sid = NULL;
-       }
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->percent_full));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->log_size));
+       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->retention_time));
+       NDR_CHECK(ndr_pull_uint8(ndr, &r->shutdown_in_progress));
+       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->time_to_shutdown));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->next_audit_record));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->unknown));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
-       if (r->sid) {
-               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
-       }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_DomainInformation(struct ndr_print *ndr, const char *name, struct lsa_DomainInformation *r)
+static NTSTATUS ndr_pull_lsa_AuditSettings(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditSettings *r)
 {
-       ndr_print_struct(ndr, name, "lsa_DomainInformation");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_ptr(ndr, "sid", r->sid);
-       ndr->depth++;
-       if (r->sid) {
-               ndr_print_dom_sid2(ndr, "sid", r->sid);
+       uint32 _conformant_size;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_conformant_size));
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->count > _conformant_size) {
+               return ndr_pull_error(ndr, NDR_ERR_CONFORMANT_SIZE, "Bad conformant size %u should be %u", _conformant_size, r->count);
        }
-       ndr->depth--;
-       ndr->depth--;
+               NDR_ALLOC_N_SIZE(ndr, r->settings, _conformant_size, sizeof(r->settings[0]));
+               NDR_CHECK(ndr_pull_array_uint32(ndr, r->settings, r->count));
+done:
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_DomainList(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainList *r)
+static NTSTATUS ndr_pull_lsa_AuditEventsInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditEventsInfo *r)
 {
-       uint32 _ptr_domains;
+       uint32 _ptr_settings;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
-       if (_ptr_domains) {
-               NDR_ALLOC(ndr, r->domains);
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->auditing_mode));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_settings));
+       if (_ptr_settings) {
+               NDR_ALLOC(ndr, r->settings);
        } else {
-               r->domains = NULL;
+               r->settings = NULL;
        }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->domains) {
-       {
-               uint32 _array_size;
-               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
-               if (r->count > _array_size) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
-               }
-       }
-               NDR_ALLOC_N_SIZE(ndr, r->domains, r->count, sizeof(r->domains[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->domains, sizeof(r->domains[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_DomainInformation));
+       if (r->settings) {
+               NDR_CHECK(ndr_pull_lsa_AuditSettings(ndr, NDR_SCALARS|NDR_BUFFERS, r->settings));
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_DomainList(struct ndr_print *ndr, const char *name, struct lsa_DomainList *r)
+static NTSTATUS ndr_pull_lsa_DomainInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainInfo *r)
 {
-       ndr_print_struct(ndr, name, "lsa_DomainList");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "domains", r->domains);
-       ndr->depth++;
-       if (r->domains) {
-               ndr_print_array(ndr, "domains", r->domains, sizeof(r->domains[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_DomainInformation);
+       uint32 _ptr_sid;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
+       if (_ptr_sid) {
+               NDR_ALLOC(ndr, r->sid);
+       } else {
+               r->sid = NULL;
        }
-       ndr->depth--;
-       ndr->depth--;
-}
-
-NTSTATUS ndr_push_lsa_EnumTrustDom(struct ndr_push *ndr, struct lsa_EnumTrustDom *r)
-{
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_uint32(ndr, *r->in.resume_handle));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_entries));
-
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+       if (r->sid) {
+               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_EnumTrustDom(struct ndr_pull *ndr, struct lsa_EnumTrustDom *r)
+static NTSTATUS ndr_pull_lsa_PDAccountInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_PDAccountInfo *r)
 {
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
-       NDR_CHECK(ndr_pull_lsa_DomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_push_lsa_TranslatedSid(struct ndr_push *ndr, int ndr_flags, struct lsa_TranslatedSid *r)
+static NTSTATUS ndr_pull_lsa_ServerRole(struct ndr_pull *ndr, int ndr_flags, struct lsa_ServerRole *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
+       NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_uint16(ndr, r->sid_type));
-       NDR_CHECK(ndr_push_uint32(ndr, r->rid));
-       NDR_CHECK(ndr_push_uint32(ndr, r->sid_index));
+       NDR_CHECK(ndr_pull_uint16(ndr, &r->role));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
 done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_TranslatedSid(struct ndr_pull *ndr, int ndr_flags, struct lsa_TranslatedSid *r)
+static NTSTATUS ndr_pull_lsa_ReplicaSourceInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_ReplicaSourceInfo *r)
 {
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint16(ndr, &r->sid_type));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->rid));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->sid_index));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->source));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->account));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->source));
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->account));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_TranslatedSid(struct ndr_print *ndr, const char *name, struct lsa_TranslatedSid *r)
+static NTSTATUS ndr_pull_lsa_DefaultQuotaInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DefaultQuotaInfo *r)
 {
-       ndr_print_struct(ndr, name, "lsa_TranslatedSid");
-       ndr->depth++;
-       ndr_print_uint16(ndr, "sid_type", r->sid_type);
-       ndr_print_uint32(ndr, "rid", r->rid);
-       ndr_print_uint32(ndr, "sid_index", r->sid_index);
-       ndr->depth--;
+       NDR_CHECK(ndr_pull_align(ndr, 8));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->paged_pool));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->non_paged_pool));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->min_wss));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->max_wss));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->pagefile));
+       NDR_CHECK(ndr_pull_HYPER_T(ndr, &r->unknown));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+done:
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_push_lsa_TransSidArray(struct ndr_push *ndr, int ndr_flags, struct lsa_TransSidArray *r)
+static NTSTATUS ndr_pull_lsa_ModificationInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_ModificationInfo *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
+       NDR_CHECK(ndr_pull_align(ndr, 8));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_uint32(ndr, r->count));
-       NDR_CHECK(ndr_push_ptr(ndr, r->sids));
+       NDR_CHECK(ndr_pull_HYPER_T(ndr, &r->modified_id));
+       NDR_CHECK(ndr_pull_NTTIME(ndr, &r->db_create_time));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sids) {
-               NDR_CHECK(ndr_push_uint32(ndr, r->count));
-               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->sids, sizeof(r->sids[0]), r->count, (ndr_push_flags_fn_t)ndr_push_lsa_TranslatedSid));
-       }
 done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_TransSidArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_TransSidArray *r)
+static NTSTATUS ndr_pull_lsa_AuditFullSetInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditFullSetInfo *r)
 {
-       uint32 _ptr_sids;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sids));
-       if (_ptr_sids) {
-               NDR_ALLOC(ndr, r->sids);
-       } else {
-               r->sids = NULL;
-       }
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->shutdown_on_full));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->sids) {
-       {
-               uint32 _array_size;
-               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
-               if (r->count > _array_size) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
-               }
-       }
-               NDR_ALLOC_N_SIZE(ndr, r->sids, r->count, sizeof(r->sids[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->sids, sizeof(r->sids[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TranslatedSid));
-       }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_TransSidArray(struct ndr_print *ndr, const char *name, struct lsa_TransSidArray *r)
+static NTSTATUS ndr_pull_lsa_AuditFullQueryInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_AuditFullQueryInfo *r)
 {
-       ndr_print_struct(ndr, name, "lsa_TransSidArray");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "sids", r->sids);
-       ndr->depth++;
-       if (r->sids) {
-               ndr_print_array(ndr, "sids", r->sids, sizeof(r->sids[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TranslatedSid);
-       }
-       ndr->depth--;
-       ndr->depth--;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->shutdown_on_full));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->log_is_full));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+done:
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_TrustInformation(struct ndr_pull *ndr, int ndr_flags, struct lsa_TrustInformation *r)
+static NTSTATUS ndr_pull_lsa_DnsDomainInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_DnsDomainInfo *r)
 {
        uint32 _ptr_sid;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
        NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->dns_domain));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->dns_forest));
+       NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_guid));
        NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
        if (_ptr_sid) {
                NDR_ALLOC(ndr, r->sid);
@@ -1239,6 +798,9 @@ static NTSTATUS ndr_pull_lsa_TrustInformation(struct ndr_pull *ndr, int ndr_flag
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
                NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->dns_domain));
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->dns_forest));
+               NDR_CHECK(ndr_pull_GUID(ndr, ndr_flags, &r->domain_guid));
        if (r->sid) {
                NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
        }
@@ -1246,169 +808,263 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_TrustInformation(struct ndr_print *ndr, const char *name, struct lsa_TrustInformation *r)
-{
-       ndr_print_struct(ndr, name, "lsa_TrustInformation");
-       ndr->depth++;
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_ptr(ndr, "sid", r->sid);
-       ndr->depth++;
-       if (r->sid) {
-               ndr_print_dom_sid2(ndr, "sid", r->sid);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
-static NTSTATUS ndr_pull_lsa_RefDomainList(struct ndr_pull *ndr, int ndr_flags, struct lsa_RefDomainList *r)
+static NTSTATUS ndr_pull_lsa_PolicyInformation(struct ndr_pull *ndr, int ndr_flags, uint16 *level, union lsa_PolicyInformation *r)
 {
-       uint32 _ptr_domains;
-       NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
-       if (_ptr_domains) {
-               NDR_ALLOC(ndr, r->domains);
-       } else {
-               r->domains = NULL;
+       NDR_CHECK(ndr_pull_uint16(ndr, level));
+       switch (*level) {
+       case 1: {
+       NDR_CHECK(ndr_pull_lsa_AuditLogInfo(ndr, NDR_SCALARS, &r->audit_log));
+       break; }
+
+       case 2: {
+       NDR_CHECK(ndr_pull_lsa_AuditEventsInfo(ndr, NDR_SCALARS, &r->audit_events));
+       break; }
+
+       case 3: {
+       NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_SCALARS, &r->domain));
+       break; }
+
+       case 4: {
+       NDR_CHECK(ndr_pull_lsa_PDAccountInfo(ndr, NDR_SCALARS, &r->pd));
+       break; }
+
+       case 5: {
+       NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_SCALARS, &r->account_domain));
+       break; }
+
+       case 6: {
+       NDR_CHECK(ndr_pull_lsa_ServerRole(ndr, NDR_SCALARS, &r->role));
+       break; }
+
+       case 7: {
+       NDR_CHECK(ndr_pull_lsa_ReplicaSourceInfo(ndr, NDR_SCALARS, &r->replica));
+       break; }
+
+       case 8: {
+       NDR_CHECK(ndr_pull_lsa_DefaultQuotaInfo(ndr, NDR_SCALARS, &r->quota));
+       break; }
+
+       case 9: {
+       NDR_CHECK(ndr_pull_lsa_ModificationInfo(ndr, NDR_SCALARS, &r->db));
+       break; }
+
+       case 10: {
+       NDR_CHECK(ndr_pull_lsa_AuditFullSetInfo(ndr, NDR_SCALARS, &r->auditfullset));
+       break; }
+
+       case 11: {
+       NDR_CHECK(ndr_pull_lsa_AuditFullQueryInfo(ndr, NDR_SCALARS, &r->auditfullquery));
+       break; }
+
+       case 12: {
+       NDR_CHECK(ndr_pull_lsa_DnsDomainInfo(ndr, NDR_SCALARS, &r->dns));
+       break; }
+
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
        }
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->max_count));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->domains) {
-       {
-               uint32 _array_size;
-               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
-               if (r->count > _array_size) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
-               }
-       }
-               NDR_ALLOC_N_SIZE(ndr, r->domains, r->count, sizeof(r->domains[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->domains, sizeof(r->domains[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TrustInformation));
+       switch (*level) {
+       case 1:
+               NDR_CHECK(ndr_pull_lsa_AuditLogInfo(ndr, NDR_BUFFERS, &r->audit_log));
+       break;
+
+       case 2:
+               NDR_CHECK(ndr_pull_lsa_AuditEventsInfo(ndr, NDR_BUFFERS, &r->audit_events));
+       break;
+
+       case 3:
+               NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_BUFFERS, &r->domain));
+       break;
+
+       case 4:
+               NDR_CHECK(ndr_pull_lsa_PDAccountInfo(ndr, NDR_BUFFERS, &r->pd));
+       break;
+
+       case 5:
+               NDR_CHECK(ndr_pull_lsa_DomainInfo(ndr, NDR_BUFFERS, &r->account_domain));
+       break;
+
+       case 6:
+               NDR_CHECK(ndr_pull_lsa_ServerRole(ndr, NDR_BUFFERS, &r->role));
+       break;
+
+       case 7:
+               NDR_CHECK(ndr_pull_lsa_ReplicaSourceInfo(ndr, NDR_BUFFERS, &r->replica));
+       break;
+
+       case 8:
+               NDR_CHECK(ndr_pull_lsa_DefaultQuotaInfo(ndr, NDR_BUFFERS, &r->quota));
+       break;
+
+       case 9:
+               NDR_CHECK(ndr_pull_lsa_ModificationInfo(ndr, NDR_BUFFERS, &r->db));
+       break;
+
+       case 10:
+               NDR_CHECK(ndr_pull_lsa_AuditFullSetInfo(ndr, NDR_BUFFERS, &r->auditfullset));
+       break;
+
+       case 11:
+               NDR_CHECK(ndr_pull_lsa_AuditFullQueryInfo(ndr, NDR_BUFFERS, &r->auditfullquery));
+       break;
+
+       case 12:
+               NDR_CHECK(ndr_pull_lsa_DnsDomainInfo(ndr, NDR_BUFFERS, &r->dns));
+       break;
+
+       default:
+               return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u", *level);
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_RefDomainList(struct ndr_print *ndr, const char *name, struct lsa_RefDomainList *r)
+NTSTATUS ndr_pull_lsa_QueryInfoPolicy(struct ndr_pull *ndr, struct lsa_QueryInfoPolicy *r)
 {
-       ndr_print_struct(ndr, name, "lsa_RefDomainList");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "domains", r->domains);
-       ndr->depth++;
-       if (r->domains) {
-               ndr_print_array(ndr, "domains", r->domains, sizeof(r->domains[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TrustInformation);
+       uint32 _ptr_info;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_info));
+       if (_ptr_info) {
+               NDR_ALLOC(ndr, r->out.info);
+       } else {
+               r->out.info = NULL;
        }
-       ndr->depth--;
-       ndr_print_uint32(ndr, "max_count", r->max_count);
-       ndr->depth--;
+       if (r->out.info) {
+       { uint16 _level;
+       NDR_CHECK(ndr_pull_lsa_PolicyInformation(ndr, NDR_SCALARS|NDR_BUFFERS, &_level, r->out.info));
+       if (_level != r->in.level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in info");
+       }
+       }
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_LookupNames(struct ndr_push *ndr, struct lsa_LookupNames *r)
+NTSTATUS ndr_pull_lsa_SetInfoPolicy(struct ndr_pull *ndr, struct lsa_SetInfoPolicy *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.num_names));
-       if (r->in.names) {
-               int ndr_flags = NDR_SCALARS|NDR_BUFFERS;
-               NDR_CHECK(ndr_push_uint32(ndr, r->in.num_names));
-               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->in.names, sizeof(r->in.names[0]), r->in.num_names, (ndr_push_flags_fn_t)ndr_push_lsa_Name));
-       }
-       NDR_CHECK(ndr_push_lsa_TransSidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.sids));
-       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
-       NDR_CHECK(ndr_push_uint32(ndr, *r->in.count));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_LookupNames(struct ndr_pull *ndr, struct lsa_LookupNames *r)
+NTSTATUS ndr_pull_lsa_ClearAuditLog(struct ndr_pull *ndr, struct lsa_ClearAuditLog *r)
 {
-       uint32 _ptr_domains;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
-       if (_ptr_domains) {
-               NDR_ALLOC(ndr, r->out.domains);
-       } else {
-               r->out.domains = NULL;
-       }
-       if (r->out.domains) {
-               NDR_CHECK(ndr_pull_lsa_RefDomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
-       }
-       NDR_CHECK(ndr_pull_lsa_TransSidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.sids));
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.count));
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_push_lsa_TranslatedName(struct ndr_push *ndr, int ndr_flags, struct lsa_TranslatedName *r)
+NTSTATUS ndr_pull_lsa_CreateAccount(struct ndr_pull *ndr, struct lsa_CreateAccount *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_pull_lsa_SidPtr(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidPtr *r)
+{
+       uint32 _ptr_sid;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_uint16(ndr, r->sid_type));
-       NDR_CHECK(ndr_push_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_push_uint32(ndr, r->sid_index));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
+       if (_ptr_sid) {
+               NDR_ALLOC(ndr, r->sid);
+       } else {
+               r->sid = NULL;
+       }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_push_lsa_Name(ndr, ndr_flags, &r->name));
+       if (r->sid) {
+               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
+       }
 done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_TranslatedName(struct ndr_pull *ndr, int ndr_flags, struct lsa_TranslatedName *r)
+static NTSTATUS ndr_pull_lsa_SidArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidArray *r)
 {
+       uint32 _ptr_sids;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint16(ndr, &r->sid_type));
-       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->sid_index));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->num_sids));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sids));
+       if (_ptr_sids) {
+               NDR_ALLOC(ndr, r->sids);
+       } else {
+               r->sids = NULL;
+       }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+       if (r->sids) {
+       {
+               uint32 _array_size;
+               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
+               if (r->num_sids > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->num_sids);
+               }
+       }
+               NDR_ALLOC_N_SIZE(ndr, r->sids, r->num_sids, sizeof(r->sids[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_pull_flags_fn_t)ndr_pull_lsa_SidPtr));
+       }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_TranslatedName(struct ndr_print *ndr, const char *name, struct lsa_TranslatedName *r)
+NTSTATUS ndr_pull_lsa_EnumAccounts(struct ndr_pull *ndr, struct lsa_EnumAccounts *r)
 {
-       ndr_print_struct(ndr, name, "lsa_TranslatedName");
-       ndr->depth++;
-       ndr_print_uint16(ndr, "sid_type", r->sid_type);
-       ndr_print_lsa_Name(ndr, "name", &r->name);
-       ndr_print_uint32(ndr, "sid_index", r->sid_index);
-       ndr->depth--;
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
+       NDR_CHECK(ndr_pull_lsa_SidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.sids));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_push_lsa_TransNameArray(struct ndr_push *ndr, int ndr_flags, struct lsa_TransNameArray *r)
+NTSTATUS ndr_pull_lsa_CreateTrustDom(struct ndr_pull *ndr, struct lsa_CreateTrustDom *r)
 {
-       NDR_CHECK(ndr_push_align(ndr, 4));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_pull_lsa_DomainInformation(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainInformation *r)
+{
+       uint32 _ptr_sid;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_push_uint32(ndr, r->count));
-       NDR_CHECK(ndr_push_ptr(ndr, r->names));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
+       if (_ptr_sid) {
+               NDR_ALLOC(ndr, r->sid);
+       } else {
+               r->sid = NULL;
+       }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->names) {
-               NDR_CHECK(ndr_push_uint32(ndr, r->count));
-               NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->names, sizeof(r->names[0]), r->count, (ndr_push_flags_fn_t)ndr_push_lsa_TranslatedName));
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+       if (r->sid) {
+               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
        }
 done:
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_TransNameArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_TransNameArray *r)
+static NTSTATUS ndr_pull_lsa_DomainList(struct ndr_pull *ndr, int ndr_flags, struct lsa_DomainList *r)
 {
-       uint32 _ptr_names;
+       uint32 _ptr_domains;
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
        NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_names));
-       if (_ptr_names) {
-               NDR_ALLOC(ndr, r->names);
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
+       if (_ptr_domains) {
+               NDR_ALLOC(ndr, r->domains);
        } else {
-               r->names = NULL;
+               r->domains = NULL;
        }
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
-       if (r->names) {
+       if (r->domains) {
        {
                uint32 _array_size;
                NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
@@ -1416,106 +1072,222 @@ buffers:
                        return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
                }
        }
-               NDR_ALLOC_N_SIZE(ndr, r->names, r->count, sizeof(r->names[0]));
-               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->names, sizeof(r->names[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TranslatedName));
+               NDR_ALLOC_N_SIZE(ndr, r->domains, r->count, sizeof(r->domains[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->domains, sizeof(r->domains[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_DomainInformation));
        }
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_TransNameArray(struct ndr_print *ndr, const char *name, struct lsa_TransNameArray *r)
+NTSTATUS ndr_pull_lsa_EnumTrustDom(struct ndr_pull *ndr, struct lsa_EnumTrustDom *r)
 {
-       ndr_print_struct(ndr, name, "lsa_TransNameArray");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "names", r->names);
-       ndr->depth++;
-       if (r->names) {
-               ndr_print_array(ndr, "names", r->names, sizeof(r->names[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TranslatedName);
-       }
-       ndr->depth--;
-       ndr->depth--;
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.resume_handle));
+       NDR_CHECK(ndr_pull_lsa_DomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_LookupSids(struct ndr_push *ndr, struct lsa_LookupSids *r)
+static NTSTATUS ndr_pull_lsa_TranslatedSid(struct ndr_pull *ndr, int ndr_flags, struct lsa_TranslatedSid *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_lsa_SidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.sids));
-       NDR_CHECK(ndr_push_lsa_TransNameArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.names));
-       NDR_CHECK(ndr_push_uint16(ndr, r->in.level));
-       NDR_CHECK(ndr_push_uint32(ndr, *r->in.count));
-
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint16(ndr, &r->sid_type));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->rid));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->sid_index));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_LookupSids(struct ndr_pull *ndr, struct lsa_LookupSids *r)
+static NTSTATUS ndr_pull_lsa_TransSidArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_TransSidArray *r)
 {
-       uint32 _ptr_domains;
-       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
-       if (_ptr_domains) {
-               NDR_ALLOC(ndr, r->out.domains);
+       uint32 _ptr_sids;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sids));
+       if (_ptr_sids) {
+               NDR_ALLOC(ndr, r->sids);
        } else {
-               r->out.domains = NULL;
+               r->sids = NULL;
        }
-       if (r->out.domains) {
-               NDR_CHECK(ndr_pull_lsa_RefDomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->sids) {
+       {
+               uint32 _array_size;
+               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
+               if (r->count > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
+               }
        }
-       NDR_CHECK(ndr_pull_lsa_TransNameArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.names));
-       NDR_CHECK(ndr_pull_uint32(ndr, r->out.count));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
-       return NT_STATUS_OK;
-}
-
-NTSTATUS ndr_push_CREATESECRET(struct ndr_push *ndr, struct CREATESECRET *r)
-{
-
+               NDR_ALLOC_N_SIZE(ndr, r->sids, r->count, sizeof(r->sids[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->sids, sizeof(r->sids[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TranslatedSid));
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_CREATESECRET(struct ndr_pull *ndr, struct CREATESECRET *r)
+static NTSTATUS ndr_pull_lsa_TrustInformation(struct ndr_pull *ndr, int ndr_flags, struct lsa_TrustInformation *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
-
+       uint32 _ptr_sid;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid));
+       if (_ptr_sid) {
+               NDR_ALLOC(ndr, r->sid);
+       } else {
+               r->sid = NULL;
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
+       if (r->sid) {
+               NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid));
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_OpenAccount(struct ndr_push *ndr, struct lsa_OpenAccount *r)
+static NTSTATUS ndr_pull_lsa_RefDomainList(struct ndr_pull *ndr, int ndr_flags, struct lsa_RefDomainList *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_dom_sid2(ndr, r->in.sid));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access));
-
+       uint32 _ptr_domains;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
+       if (_ptr_domains) {
+               NDR_ALLOC(ndr, r->domains);
+       } else {
+               r->domains = NULL;
+       }
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->max_count));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->domains) {
+       {
+               uint32 _array_size;
+               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
+               if (r->count > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
+               }
+       }
+               NDR_ALLOC_N_SIZE(ndr, r->domains, r->count, sizeof(r->domains[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->domains, sizeof(r->domains[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TrustInformation));
+       }
+done:
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_OpenAccount(struct ndr_pull *ndr, struct lsa_OpenAccount *r)
+NTSTATUS ndr_pull_lsa_LookupNames(struct ndr_pull *ndr, struct lsa_LookupNames *r)
 {
-       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.acct_handle));
+       uint32 _ptr_domains;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
+       if (_ptr_domains) {
+               NDR_ALLOC(ndr, r->out.domains);
+       } else {
+               r->out.domains = NULL;
+       }
+       if (r->out.domains) {
+               NDR_CHECK(ndr_pull_lsa_RefDomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
+       }
+       NDR_CHECK(ndr_pull_lsa_TransSidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.sids));
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.count));
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-static NTSTATUS ndr_pull_lsa_LUID(struct ndr_pull *ndr, int ndr_flags, struct lsa_LUID *r)
+static NTSTATUS ndr_pull_lsa_TranslatedName(struct ndr_pull *ndr, int ndr_flags, struct lsa_TranslatedName *r)
 {
        NDR_CHECK(ndr_pull_align(ndr, 4));
        if (!(ndr_flags & NDR_SCALARS)) goto buffers;
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->low));
-       NDR_CHECK(ndr_pull_uint32(ndr, &r->high));
+       NDR_CHECK(ndr_pull_uint16(ndr, &r->sid_type));
+       NDR_CHECK(ndr_pull_lsa_Name(ndr, NDR_SCALARS, &r->name));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->sid_index));
 buffers:
        if (!(ndr_flags & NDR_BUFFERS)) goto done;
+               NDR_CHECK(ndr_pull_lsa_Name(ndr, ndr_flags, &r->name));
 done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_LUID(struct ndr_print *ndr, const char *name, struct lsa_LUID *r)
+static NTSTATUS ndr_pull_lsa_TransNameArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_TransNameArray *r)
 {
-       ndr_print_struct(ndr, name, "lsa_LUID");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "low", r->low);
-       ndr_print_uint32(ndr, "high", r->high);
-       ndr->depth--;
+       uint32 _ptr_names;
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->count));
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_names));
+       if (_ptr_names) {
+               NDR_ALLOC(ndr, r->names);
+       } else {
+               r->names = NULL;
+       }
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+       if (r->names) {
+       {
+               uint32 _array_size;
+               NDR_CHECK(ndr_pull_uint32(ndr, &_array_size));
+               if (r->count > _array_size) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should be %u", _array_size, r->count);
+               }
+       }
+               NDR_ALLOC_N_SIZE(ndr, r->names, r->count, sizeof(r->names[0]));
+               NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)r->names, sizeof(r->names[0]), r->count, (ndr_pull_flags_fn_t)ndr_pull_lsa_TranslatedName));
+       }
+done:
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_lsa_LookupSids(struct ndr_pull *ndr, struct lsa_LookupSids *r)
+{
+       uint32 _ptr_domains;
+       NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_domains));
+       if (_ptr_domains) {
+               NDR_ALLOC(ndr, r->out.domains);
+       } else {
+               r->out.domains = NULL;
+       }
+       if (r->out.domains) {
+               NDR_CHECK(ndr_pull_lsa_RefDomainList(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.domains));
+       }
+       NDR_CHECK(ndr_pull_lsa_TransNameArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.names));
+       NDR_CHECK(ndr_pull_uint32(ndr, r->out.count));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_CREATESECRET(struct ndr_pull *ndr, struct CREATESECRET *r)
+{
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS ndr_pull_lsa_OpenAccount(struct ndr_pull *ndr, struct lsa_OpenAccount *r)
+{
+       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.acct_handle));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+
+       return NT_STATUS_OK;
+}
+
+static NTSTATUS ndr_pull_lsa_LUID(struct ndr_pull *ndr, int ndr_flags, struct lsa_LUID *r)
+{
+       NDR_CHECK(ndr_pull_align(ndr, 4));
+       if (!(ndr_flags & NDR_SCALARS)) goto buffers;
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->low));
+       NDR_CHECK(ndr_pull_uint32(ndr, &r->high));
+buffers:
+       if (!(ndr_flags & NDR_BUFFERS)) goto done;
+done:
+       return NT_STATUS_OK;
 }
 
 static NTSTATUS ndr_pull_lsa_LUIDAttribute(struct ndr_pull *ndr, int ndr_flags, struct lsa_LUIDAttribute *r)
@@ -1531,15 +1303,6 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_LUIDAttribute(struct ndr_print *ndr, const char *name, struct lsa_LUIDAttribute *r)
-{
-       ndr_print_struct(ndr, name, "lsa_LUIDAttribute");
-       ndr->depth++;
-       ndr_print_lsa_LUID(ndr, "luid", &r->luid);
-       ndr_print_uint32(ndr, "attribute", r->attribute);
-       ndr->depth--;
-}
-
 static NTSTATUS ndr_pull_lsa_PrivilegeSet(struct ndr_pull *ndr, int ndr_flags, struct lsa_PrivilegeSet *r)
 {
        uint32 _conformant_size;
@@ -1559,26 +1322,6 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_PrivilegeSet(struct ndr_print *ndr, const char *name, struct lsa_PrivilegeSet *r)
-{
-       ndr_print_struct(ndr, name, "lsa_PrivilegeSet");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_uint32(ndr, "unknown", r->unknown);
-       ndr_print_ptr(ndr, "set", r->set);
-       ndr->depth++;
-               ndr_print_array(ndr, "set", r->set, sizeof(r->set[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_LUIDAttribute);
-       ndr->depth--;
-       ndr->depth--;
-}
-
-NTSTATUS ndr_push_lsa_EnumPrivsAccount(struct ndr_push *ndr, struct lsa_EnumPrivsAccount *r)
-{
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_lsa_EnumPrivsAccount(struct ndr_pull *ndr, struct lsa_EnumPrivsAccount *r)
 {
        uint32 _ptr_privs;
@@ -1596,12 +1339,6 @@ NTSTATUS ndr_pull_lsa_EnumPrivsAccount(struct ndr_pull *ndr, struct lsa_EnumPriv
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_ADDPRIVS(struct ndr_push *ndr, struct ADDPRIVS *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_ADDPRIVS(struct ndr_pull *ndr, struct ADDPRIVS *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1609,12 +1346,6 @@ NTSTATUS ndr_pull_ADDPRIVS(struct ndr_pull *ndr, struct ADDPRIVS *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_REMOVEPRIVS(struct ndr_push *ndr, struct REMOVEPRIVS *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_REMOVEPRIVS(struct ndr_pull *ndr, struct REMOVEPRIVS *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1622,12 +1353,6 @@ NTSTATUS ndr_pull_REMOVEPRIVS(struct ndr_pull *ndr, struct REMOVEPRIVS *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_GETQUOTAS(struct ndr_push *ndr, struct GETQUOTAS *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_GETQUOTAS(struct ndr_pull *ndr, struct GETQUOTAS *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1635,12 +1360,6 @@ NTSTATUS ndr_pull_GETQUOTAS(struct ndr_pull *ndr, struct GETQUOTAS *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_SETQUOTAS(struct ndr_push *ndr, struct SETQUOTAS *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_SETQUOTAS(struct ndr_pull *ndr, struct SETQUOTAS *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1648,12 +1367,6 @@ NTSTATUS ndr_pull_SETQUOTAS(struct ndr_pull *ndr, struct SETQUOTAS *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_GETSYSTEMACCOUNT(struct ndr_push *ndr, struct GETSYSTEMACCOUNT *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_GETSYSTEMACCOUNT(struct ndr_pull *ndr, struct GETSYSTEMACCOUNT *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1661,12 +1374,6 @@ NTSTATUS ndr_pull_GETSYSTEMACCOUNT(struct ndr_pull *ndr, struct GETSYSTEMACCOUNT
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_SETSYSTEMACCOUNT(struct ndr_push *ndr, struct SETSYSTEMACCOUNT *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_SETSYSTEMACCOUNT(struct ndr_pull *ndr, struct SETSYSTEMACCOUNT *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1674,12 +1381,6 @@ NTSTATUS ndr_pull_SETSYSTEMACCOUNT(struct ndr_pull *ndr, struct SETSYSTEMACCOUNT
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_OPENTRUSTDOM(struct ndr_push *ndr, struct OPENTRUSTDOM *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_OPENTRUSTDOM(struct ndr_pull *ndr, struct OPENTRUSTDOM *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1687,12 +1388,6 @@ NTSTATUS ndr_pull_OPENTRUSTDOM(struct ndr_pull *ndr, struct OPENTRUSTDOM *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_QUERYTRUSTDOM(struct ndr_push *ndr, struct QUERYTRUSTDOM *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_QUERYTRUSTDOM(struct ndr_pull *ndr, struct QUERYTRUSTDOM *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1700,12 +1395,6 @@ NTSTATUS ndr_pull_QUERYTRUSTDOM(struct ndr_pull *ndr, struct QUERYTRUSTDOM *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_SETINFOTRUSTDOM(struct ndr_push *ndr, struct SETINFOTRUSTDOM *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_SETINFOTRUSTDOM(struct ndr_pull *ndr, struct SETINFOTRUSTDOM *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1713,12 +1402,6 @@ NTSTATUS ndr_pull_SETINFOTRUSTDOM(struct ndr_pull *ndr, struct SETINFOTRUSTDOM *
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_OPENSECRET(struct ndr_push *ndr, struct OPENSECRET *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_OPENSECRET(struct ndr_pull *ndr, struct OPENSECRET *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1726,12 +1409,6 @@ NTSTATUS ndr_pull_OPENSECRET(struct ndr_pull *ndr, struct OPENSECRET *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_SETSECRET(struct ndr_push *ndr, struct SETSECRET *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_SETSECRET(struct ndr_pull *ndr, struct SETSECRET *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1739,12 +1416,6 @@ NTSTATUS ndr_pull_SETSECRET(struct ndr_pull *ndr, struct SETSECRET *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_QUERYSECRET(struct ndr_push *ndr, struct QUERYSECRET *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_QUERYSECRET(struct ndr_pull *ndr, struct QUERYSECRET *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1752,12 +1423,6 @@ NTSTATUS ndr_pull_QUERYSECRET(struct ndr_pull *ndr, struct QUERYSECRET *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_LOOKUPPRIVVALUE(struct ndr_push *ndr, struct LOOKUPPRIVVALUE *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_LOOKUPPRIVVALUE(struct ndr_pull *ndr, struct LOOKUPPRIVVALUE *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1765,15 +1430,6 @@ NTSTATUS ndr_pull_LOOKUPPRIVVALUE(struct ndr_pull *ndr, struct LOOKUPPRIVVALUE *
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_lsa_LookupPrivName(struct ndr_push *ndr, struct lsa_LookupPrivName *r)
-{
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.luid_high));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.luid_low));
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_lsa_LookupPrivName(struct ndr_pull *ndr, struct lsa_LookupPrivName *r)
 {
        uint32 _ptr_name;
@@ -1791,12 +1447,6 @@ NTSTATUS ndr_pull_lsa_LookupPrivName(struct ndr_pull *ndr, struct lsa_LookupPriv
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_PRIV_GET_DISPNAME(struct ndr_push *ndr, struct PRIV_GET_DISPNAME *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_PRIV_GET_DISPNAME(struct ndr_pull *ndr, struct PRIV_GET_DISPNAME *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1804,12 +1454,6 @@ NTSTATUS ndr_pull_PRIV_GET_DISPNAME(struct ndr_pull *ndr, struct PRIV_GET_DISPNA
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_DELETEOBJECT(struct ndr_push *ndr, struct DELETEOBJECT *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_DELETEOBJECT(struct ndr_pull *ndr, struct DELETEOBJECT *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1817,12 +1461,6 @@ NTSTATUS ndr_pull_DELETEOBJECT(struct ndr_pull *ndr, struct DELETEOBJECT *r)
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_ENUMACCTWITHRIGHT(struct ndr_push *ndr, struct ENUMACCTWITHRIGHT *r)
-{
-
-       return NT_STATUS_OK;
-}
-
 NTSTATUS ndr_pull_ENUMACCTWITHRIGHT(struct ndr_pull *ndr, struct ENUMACCTWITHRIGHT *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
@@ -1830,19 +1468,6 @@ NTSTATUS ndr_pull_ENUMACCTWITHRIGHT(struct ndr_pull *ndr, struct ENUMACCTWITHRIG
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_RightAttribute(struct ndr_print *ndr, const char *name, struct lsa_RightAttribute *r)
-{
-       ndr_print_struct(ndr, name, "lsa_RightAttribute");
-       ndr->depth++;
-       ndr_print_ptr(ndr, "name", r->name);
-       ndr->depth++;
-       if (r->name) {
-               ndr_print_unistr(ndr, "name", r->name);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
 static NTSTATUS ndr_pull_lsa_RightSet(struct ndr_pull *ndr, int ndr_flags, struct lsa_RightSet *r)
 {
        uint32 _ptr_names;
@@ -1872,170 +1497,545 @@ done:
        return NT_STATUS_OK;
 }
 
-void ndr_print_lsa_RightSet(struct ndr_print *ndr, const char *name, struct lsa_RightSet *r)
-{
-       ndr_print_struct(ndr, name, "lsa_RightSet");
-       ndr->depth++;
-       ndr_print_uint32(ndr, "count", r->count);
-       ndr_print_ptr(ndr, "names", r->names);
-       ndr->depth++;
-       if (r->names) {
-               ndr_print_array(ndr, "names", r->names, sizeof(r->names[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_Name);
-       }
-       ndr->depth--;
-       ndr->depth--;
-}
-
-NTSTATUS ndr_push_lsa_EnumAccountRights(struct ndr_push *ndr, struct lsa_EnumAccountRights *r)
+NTSTATUS ndr_pull_lsa_EnumAccountRights(struct ndr_pull *ndr, struct lsa_EnumAccountRights *r)
 {
-       NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle));
-       NDR_CHECK(ndr_push_dom_sid2(ndr, r->in.sid));
+       NDR_CHECK(ndr_pull_lsa_RightSet(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.rights));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_lsa_EnumAccountRights(struct ndr_pull *ndr, struct lsa_EnumAccountRights *r)
+NTSTATUS ndr_pull_ADDACCTRIGHTS(struct ndr_pull *ndr, struct ADDACCTRIGHTS *r)
 {
-       NDR_CHECK(ndr_pull_lsa_RightSet(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.rights));
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_ADDACCTRIGHTS(struct ndr_push *ndr, struct ADDACCTRIGHTS *r)
+NTSTATUS ndr_pull_REMOVEACCTRIGHTS(struct ndr_pull *ndr, struct REMOVEACCTRIGHTS *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_ADDACCTRIGHTS(struct ndr_pull *ndr, struct ADDACCTRIGHTS *r)
+NTSTATUS ndr_pull_QUERYTRUSTDOMINFO(struct ndr_pull *ndr, struct QUERYTRUSTDOMINFO *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_REMOVEACCTRIGHTS(struct ndr_push *ndr, struct REMOVEACCTRIGHTS *r)
+NTSTATUS ndr_pull_SETTRUSTDOMINFO(struct ndr_pull *ndr, struct SETTRUSTDOMINFO *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_REMOVEACCTRIGHTS(struct ndr_pull *ndr, struct REMOVEACCTRIGHTS *r)
+NTSTATUS ndr_pull_DELETETRUSTDOM(struct ndr_pull *ndr, struct DELETETRUSTDOM *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_QUERYTRUSTDOMINFO(struct ndr_push *ndr, struct QUERYTRUSTDOMINFO *r)
+NTSTATUS ndr_pull_STOREPRIVDATA(struct ndr_pull *ndr, struct STOREPRIVDATA *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_QUERYTRUSTDOMINFO(struct ndr_pull *ndr, struct QUERYTRUSTDOMINFO *r)
+NTSTATUS ndr_pull_RETRPRIVDATA(struct ndr_pull *ndr, struct RETRPRIVDATA *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_SETTRUSTDOMINFO(struct ndr_push *ndr, struct SETTRUSTDOMINFO *r)
+NTSTATUS ndr_pull_lsa_OpenPolicy2(struct ndr_pull *ndr, struct lsa_OpenPolicy2 *r)
 {
+       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_SETTRUSTDOMINFO(struct ndr_pull *ndr, struct SETTRUSTDOMINFO *r)
+NTSTATUS ndr_pull_UNK_GET_CONNUSER(struct ndr_pull *ndr, struct UNK_GET_CONNUSER *r)
 {
        NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_push_DELETETRUSTDOM(struct ndr_push *ndr, struct DELETETRUSTDOM *r)
+NTSTATUS ndr_pull_QUERYINFO2(struct ndr_pull *ndr, struct QUERYINFO2 *r)
 {
+       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
 
        return NT_STATUS_OK;
 }
 
-NTSTATUS ndr_pull_DELETETRUSTDOM(struct ndr_pull *ndr, struct DELETETRUSTDOM *r)
+void ndr_print_lsa_Name(struct ndr_print *ndr, const char *name, struct lsa_Name *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_Name");
+       ndr->depth++;
+       ndr_print_uint16(ndr, "name_len", r->name_len);
+       ndr_print_uint16(ndr, "name_size", r->name_size);
+       ndr_print_ptr(ndr, "name", r->name);
+       ndr->depth++;
+       if (r->name) {
+               ndr_print_unistr_noterm(ndr, "name", r->name);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_PrivEntry(struct ndr_print *ndr, const char *name, struct lsa_PrivEntry *r)
+{
+       ndr_print_struct(ndr, name, "lsa_PrivEntry");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_uint32(ndr, "luid_low", r->luid_low);
+       ndr_print_uint32(ndr, "luid_high", r->luid_high);
+       ndr->depth--;
 }
 
-NTSTATUS ndr_push_STOREPRIVDATA(struct ndr_push *ndr, struct STOREPRIVDATA *r)
+void ndr_print_lsa_PrivArray(struct ndr_print *ndr, const char *name, struct lsa_PrivArray *r)
 {
+       ndr_print_struct(ndr, name, "lsa_PrivArray");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "privs", r->privs);
+       ndr->depth++;
+       if (r->privs) {
+               ndr_print_array(ndr, "privs", r->privs, sizeof(r->privs[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_PrivEntry);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_QosInfo(struct ndr_print *ndr, const char *name, struct lsa_QosInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_QosInfo");
+       ndr->depth++;
+       ndr_print_uint16(ndr, "impersonation_level", r->impersonation_level);
+       ndr_print_uint8(ndr, "context_mode", r->context_mode);
+       ndr_print_uint8(ndr, "effective_only", r->effective_only);
+       ndr->depth--;
 }
 
-NTSTATUS ndr_pull_STOREPRIVDATA(struct ndr_pull *ndr, struct STOREPRIVDATA *r)
+void ndr_print_lsa_ObjectAttribute(struct ndr_print *ndr, const char *name, struct lsa_ObjectAttribute *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_ObjectAttribute");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "root_dir", r->root_dir);
+       ndr->depth++;
+       if (r->root_dir) {
+               ndr_print_uint8(ndr, "root_dir", *r->root_dir);
+       }
+       ndr->depth--;
+       ndr_print_ptr(ndr, "object_name", r->object_name);
+       ndr->depth++;
+       if (r->object_name) {
+               ndr_print_unistr(ndr, "object_name", r->object_name);
+       }
+       ndr->depth--;
+       ndr_print_uint32(ndr, "attributes", r->attributes);
+       ndr_print_ptr(ndr, "sec_desc", r->sec_desc);
+       ndr->depth++;
+       if (r->sec_desc) {
+               ndr_print_security_descriptor(ndr, "sec_desc", r->sec_desc);
+       }
+       ndr->depth--;
+       ndr_print_ptr(ndr, "sec_qos", r->sec_qos);
+       ndr->depth++;
+       if (r->sec_qos) {
+               ndr_print_lsa_QosInfo(ndr, "sec_qos", r->sec_qos);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_AuditLogInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditLogInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_AuditLogInfo");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "percent_full", r->percent_full);
+       ndr_print_uint32(ndr, "log_size", r->log_size);
+       ndr_print_NTTIME(ndr, "retention_time", r->retention_time);
+       ndr_print_uint8(ndr, "shutdown_in_progress", r->shutdown_in_progress);
+       ndr_print_NTTIME(ndr, "time_to_shutdown", r->time_to_shutdown);
+       ndr_print_uint32(ndr, "next_audit_record", r->next_audit_record);
+       ndr_print_uint32(ndr, "unknown", r->unknown);
+       ndr->depth--;
 }
 
-NTSTATUS ndr_push_RETRPRIVDATA(struct ndr_push *ndr, struct RETRPRIVDATA *r)
+void ndr_print_lsa_AuditSettings(struct ndr_print *ndr, const char *name, struct lsa_AuditSettings *r)
+{
+       ndr_print_struct(ndr, name, "lsa_AuditSettings");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "settings", r->settings);
+       ndr->depth++;
+               ndr_print_array_uint32(ndr, "settings", r->settings, r->count);
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_lsa_AuditEventsInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditEventsInfo *r)
 {
+       ndr_print_struct(ndr, name, "lsa_AuditEventsInfo");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "auditing_mode", r->auditing_mode);
+       ndr_print_ptr(ndr, "settings", r->settings);
+       ndr->depth++;
+       if (r->settings) {
+               ndr_print_lsa_AuditSettings(ndr, "settings", r->settings);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_DomainInfo(struct ndr_print *ndr, const char *name, struct lsa_DomainInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_DomainInfo");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_ptr(ndr, "sid", r->sid);
+       ndr->depth++;
+       if (r->sid) {
+               ndr_print_dom_sid2(ndr, "sid", r->sid);
+       }
+       ndr->depth--;
+       ndr->depth--;
 }
 
-NTSTATUS ndr_pull_RETRPRIVDATA(struct ndr_pull *ndr, struct RETRPRIVDATA *r)
+void ndr_print_lsa_PDAccountInfo(struct ndr_print *ndr, const char *name, struct lsa_PDAccountInfo *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_PDAccountInfo");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_ServerRole(struct ndr_print *ndr, const char *name, struct lsa_ServerRole *r)
+{
+       ndr_print_struct(ndr, name, "lsa_ServerRole");
+       ndr->depth++;
+       ndr_print_uint16(ndr, "role", r->role);
+       ndr->depth--;
 }
 
-NTSTATUS ndr_push_lsa_OpenPolicy2(struct ndr_push *ndr, struct lsa_OpenPolicy2 *r)
+void ndr_print_lsa_ReplicaSourceInfo(struct ndr_print *ndr, const char *name, struct lsa_ReplicaSourceInfo *r)
 {
-       NDR_CHECK(ndr_push_ptr(ndr, r->in.system_name));
-       if (r->in.system_name) {
-               NDR_CHECK(ndr_push_unistr(ndr, r->in.system_name));
+       ndr_print_struct(ndr, name, "lsa_ReplicaSourceInfo");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "source", &r->source);
+       ndr_print_lsa_Name(ndr, "account", &r->account);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_DefaultQuotaInfo(struct ndr_print *ndr, const char *name, struct lsa_DefaultQuotaInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_DefaultQuotaInfo");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "paged_pool", r->paged_pool);
+       ndr_print_uint32(ndr, "non_paged_pool", r->non_paged_pool);
+       ndr_print_uint32(ndr, "min_wss", r->min_wss);
+       ndr_print_uint32(ndr, "max_wss", r->max_wss);
+       ndr_print_uint32(ndr, "pagefile", r->pagefile);
+       ndr_print_HYPER_T(ndr, "unknown", r->unknown);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_ModificationInfo(struct ndr_print *ndr, const char *name, struct lsa_ModificationInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_ModificationInfo");
+       ndr->depth++;
+       ndr_print_HYPER_T(ndr, "modified_id", r->modified_id);
+       ndr_print_NTTIME(ndr, "db_create_time", r->db_create_time);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_AuditFullSetInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditFullSetInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_AuditFullSetInfo");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "shutdown_on_full", r->shutdown_on_full);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_AuditFullQueryInfo(struct ndr_print *ndr, const char *name, struct lsa_AuditFullQueryInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_AuditFullQueryInfo");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "shutdown_on_full", r->shutdown_on_full);
+       ndr_print_uint32(ndr, "log_is_full", r->log_is_full);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_DnsDomainInfo(struct ndr_print *ndr, const char *name, struct lsa_DnsDomainInfo *r)
+{
+       ndr_print_struct(ndr, name, "lsa_DnsDomainInfo");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_lsa_Name(ndr, "dns_domain", &r->dns_domain);
+       ndr_print_lsa_Name(ndr, "dns_forest", &r->dns_forest);
+       ndr_print_GUID(ndr, "domain_guid", &r->domain_guid);
+       ndr_print_ptr(ndr, "sid", r->sid);
+       ndr->depth++;
+       if (r->sid) {
+               ndr_print_dom_sid2(ndr, "sid", r->sid);
        }
-       NDR_CHECK(ndr_push_lsa_ObjectAttribute(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.attr));
-       NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access));
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_PolicyInformation(struct ndr_print *ndr, const char *name, uint16 level, union lsa_PolicyInformation *r)
+{
+       ndr_print_union(ndr, name, level, "lsa_PolicyInformation");
+       switch (level) {
+       case 1:
+       ndr_print_lsa_AuditLogInfo(ndr, "audit_log", &r->audit_log);
+       break;
+
+       case 2:
+       ndr_print_lsa_AuditEventsInfo(ndr, "audit_events", &r->audit_events);
+       break;
+
+       case 3:
+       ndr_print_lsa_DomainInfo(ndr, "domain", &r->domain);
+       break;
+
+       case 4:
+       ndr_print_lsa_PDAccountInfo(ndr, "pd", &r->pd);
+       break;
+
+       case 5:
+       ndr_print_lsa_DomainInfo(ndr, "account_domain", &r->account_domain);
+       break;
+
+       case 6:
+       ndr_print_lsa_ServerRole(ndr, "role", &r->role);
+       break;
+
+       case 7:
+       ndr_print_lsa_ReplicaSourceInfo(ndr, "replica", &r->replica);
+       break;
+
+       case 8:
+       ndr_print_lsa_DefaultQuotaInfo(ndr, "quota", &r->quota);
+       break;
+
+       case 9:
+       ndr_print_lsa_ModificationInfo(ndr, "db", &r->db);
+       break;
+
+       case 10:
+       ndr_print_lsa_AuditFullSetInfo(ndr, "auditfullset", &r->auditfullset);
+       break;
+
+       case 11:
+       ndr_print_lsa_AuditFullQueryInfo(ndr, "auditfullquery", &r->auditfullquery);
+       break;
+
+       case 12:
+       ndr_print_lsa_DnsDomainInfo(ndr, "dns", &r->dns);
+       break;
+
+       default:
+               ndr_print_bad_level(ndr, name, level);
+       }
 }
 
-NTSTATUS ndr_pull_lsa_OpenPolicy2(struct ndr_pull *ndr, struct lsa_OpenPolicy2 *r)
+void ndr_print_lsa_SidPtr(struct ndr_print *ndr, const char *name, struct lsa_SidPtr *r)
 {
-       NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle));
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_SidPtr");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "sid", r->sid);
+       ndr->depth++;
+       if (r->sid) {
+               ndr_print_dom_sid2(ndr, "sid", r->sid);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_SidArray(struct ndr_print *ndr, const char *name, struct lsa_SidArray *r)
+{
+       ndr_print_struct(ndr, name, "lsa_SidArray");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "num_sids", r->num_sids);
+       ndr_print_ptr(ndr, "sids", r->sids);
+       ndr->depth++;
+       if (r->sids) {
+               ndr_print_array(ndr, "sids", r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_print_fn_t)ndr_print_lsa_SidPtr);
+       }
+       ndr->depth--;
+       ndr->depth--;
 }
 
-NTSTATUS ndr_push_UNK_GET_CONNUSER(struct ndr_push *ndr, struct UNK_GET_CONNUSER *r)
+void ndr_print_lsa_DomainInformation(struct ndr_print *ndr, const char *name, struct lsa_DomainInformation *r)
 {
+       ndr_print_struct(ndr, name, "lsa_DomainInformation");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_ptr(ndr, "sid", r->sid);
+       ndr->depth++;
+       if (r->sid) {
+               ndr_print_dom_sid2(ndr, "sid", r->sid);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_DomainList(struct ndr_print *ndr, const char *name, struct lsa_DomainList *r)
+{
+       ndr_print_struct(ndr, name, "lsa_DomainList");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "domains", r->domains);
+       ndr->depth++;
+       if (r->domains) {
+               ndr_print_array(ndr, "domains", r->domains, sizeof(r->domains[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_DomainInformation);
+       }
+       ndr->depth--;
+       ndr->depth--;
 }
 
-NTSTATUS ndr_pull_UNK_GET_CONNUSER(struct ndr_pull *ndr, struct UNK_GET_CONNUSER *r)
+void ndr_print_lsa_TranslatedSid(struct ndr_print *ndr, const char *name, struct lsa_TranslatedSid *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_TranslatedSid");
+       ndr->depth++;
+       ndr_print_uint16(ndr, "sid_type", r->sid_type);
+       ndr_print_uint32(ndr, "rid", r->rid);
+       ndr_print_uint32(ndr, "sid_index", r->sid_index);
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_TransSidArray(struct ndr_print *ndr, const char *name, struct lsa_TransSidArray *r)
+{
+       ndr_print_struct(ndr, name, "lsa_TransSidArray");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "sids", r->sids);
+       ndr->depth++;
+       if (r->sids) {
+               ndr_print_array(ndr, "sids", r->sids, sizeof(r->sids[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TranslatedSid);
+       }
+       ndr->depth--;
+       ndr->depth--;
 }
 
-NTSTATUS ndr_push_QUERYINFO2(struct ndr_push *ndr, struct QUERYINFO2 *r)
+void ndr_print_lsa_TrustInformation(struct ndr_print *ndr, const char *name, struct lsa_TrustInformation *r)
 {
+       ndr_print_struct(ndr, name, "lsa_TrustInformation");
+       ndr->depth++;
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_ptr(ndr, "sid", r->sid);
+       ndr->depth++;
+       if (r->sid) {
+               ndr_print_dom_sid2(ndr, "sid", r->sid);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_RefDomainList(struct ndr_print *ndr, const char *name, struct lsa_RefDomainList *r)
+{
+       ndr_print_struct(ndr, name, "lsa_RefDomainList");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "domains", r->domains);
+       ndr->depth++;
+       if (r->domains) {
+               ndr_print_array(ndr, "domains", r->domains, sizeof(r->domains[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TrustInformation);
+       }
+       ndr->depth--;
+       ndr_print_uint32(ndr, "max_count", r->max_count);
+       ndr->depth--;
 }
 
-NTSTATUS ndr_pull_QUERYINFO2(struct ndr_pull *ndr, struct QUERYINFO2 *r)
+void ndr_print_lsa_TranslatedName(struct ndr_print *ndr, const char *name, struct lsa_TranslatedName *r)
 {
-       NDR_CHECK(ndr_pull_NTSTATUS(ndr, &r->out.result));
+       ndr_print_struct(ndr, name, "lsa_TranslatedName");
+       ndr->depth++;
+       ndr_print_uint16(ndr, "sid_type", r->sid_type);
+       ndr_print_lsa_Name(ndr, "name", &r->name);
+       ndr_print_uint32(ndr, "sid_index", r->sid_index);
+       ndr->depth--;
+}
 
-       return NT_STATUS_OK;
+void ndr_print_lsa_TransNameArray(struct ndr_print *ndr, const char *name, struct lsa_TransNameArray *r)
+{
+       ndr_print_struct(ndr, name, "lsa_TransNameArray");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "names", r->names);
+       ndr->depth++;
+       if (r->names) {
+               ndr_print_array(ndr, "names", r->names, sizeof(r->names[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_TranslatedName);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_lsa_LUID(struct ndr_print *ndr, const char *name, struct lsa_LUID *r)
+{
+       ndr_print_struct(ndr, name, "lsa_LUID");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "low", r->low);
+       ndr_print_uint32(ndr, "high", r->high);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_LUIDAttribute(struct ndr_print *ndr, const char *name, struct lsa_LUIDAttribute *r)
+{
+       ndr_print_struct(ndr, name, "lsa_LUIDAttribute");
+       ndr->depth++;
+       ndr_print_lsa_LUID(ndr, "luid", &r->luid);
+       ndr_print_uint32(ndr, "attribute", r->attribute);
+       ndr->depth--;
+}
+
+void ndr_print_lsa_PrivilegeSet(struct ndr_print *ndr, const char *name, struct lsa_PrivilegeSet *r)
+{
+       ndr_print_struct(ndr, name, "lsa_PrivilegeSet");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_uint32(ndr, "unknown", r->unknown);
+       ndr_print_ptr(ndr, "set", r->set);
+       ndr->depth++;
+               ndr_print_array(ndr, "set", r->set, sizeof(r->set[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_LUIDAttribute);
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_lsa_RightAttribute(struct ndr_print *ndr, const char *name, struct lsa_RightAttribute *r)
+{
+       ndr_print_struct(ndr, name, "lsa_RightAttribute");
+       ndr->depth++;
+       ndr_print_ptr(ndr, "name", r->name);
+       ndr->depth++;
+       if (r->name) {
+               ndr_print_unistr(ndr, "name", r->name);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
+void ndr_print_lsa_RightSet(struct ndr_print *ndr, const char *name, struct lsa_RightSet *r)
+{
+       ndr_print_struct(ndr, name, "lsa_RightSet");
+       ndr->depth++;
+       ndr_print_uint32(ndr, "count", r->count);
+       ndr_print_ptr(ndr, "names", r->names);
+       ndr->depth++;
+       if (r->names) {
+               ndr_print_array(ndr, "names", r->names, sizeof(r->names[0]), r->count, (ndr_print_fn_t)ndr_print_lsa_Name);
+       }
+       ndr->depth--;
+       ndr->depth--;
 }
 
index 82c07dd19716b49c72b05266af216bad0843439a..f72e7b1a88ce4c07d155f3b73f7a35d4defa6140 100644 (file)
@@ -780,6 +780,8 @@ NTSTATUS dcerpc_ndr_request(struct dcerpc_pipe *p,
        /* retrieve the blob */
        request = ndr_push_blob(push);
 
+       dump_data(10, request.data, request.length);
+
        /* make the actual dcerpc request */
        status = dcerpc_request(p, opnum, mem_ctx, &request, &response);
        if (!NT_STATUS_IS_OK(status)) {
index 3f8d789fe8872daf063d095a07b25417da5ed2cf..f4bcc7a6296ceb95da9171e698663ef7f7fe509e 100644 (file)
@@ -45,20 +45,34 @@ static BOOL test_Enum(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
 {
        NTSTATUS status;
        struct dfs_Enum r;
-       uint32 resume_handle = 0;
+       uint32 total=0;
+       struct dfs_EnumStruct e;
+       uint32 i = 0;
+       struct dfs_String s;
+       struct dfs_Enum1 e1;
+
+       e.level = 1;
+       e.e.enum1 = &e1;
+       e.e.enum1->count = 0;
+       e.e.enum1->s = &s;
+       s.str = NULL;
 
-       r.in.name = "";
        r.in.level = 1;
-       r.in.buffer_size = 20000;
-       r.in.resume_handle = &resume_handle;
-       r.out.resume_handle = &resume_handle;
-
+       r.in.bufsize = (uint32)-1;
+       r.in.total = &total;
+       r.in.unknown = NULL;
+       r.in.info = &e;
+       
        status = dcerpc_dfs_Enum(p, mem_ctx, &r);
        if (!NT_STATUS_IS_OK(status)) {
                printf("Enum failed - %s\n", nt_errstr(status));
                return False;
        }
 
+       NDR_PRINT_DEBUG(dfs_EnumStruct, r.out.info);
+
+       printf("total=%d\n", r.out.total?*r.out.total:-1);
+
        return True;
 }
 
index c0416fdb8ac904ad7a0c2c68c78bbb78924de4c5..1e6328f3b4995e08b4bf667be314ab25cbe3bd75 100644 (file)
@@ -197,6 +197,11 @@ BOOL torture_rpc_echo(int dummy)
                return False;
        }
 
+       if (!test_testcall(p, mem_ctx)) {
+               ret = False;
+       }
+       return ret;
+
        if (!test_addone(p, mem_ctx)) {
                ret = False;
        }