s3:winbind: Convert WINBINDD_SET_HWM to the new API
[sfrench/samba-autobuild/.git] / source3 / librpc / gen_ndr / cli_wbint.c
index 55f3b3a5f7aeb83f37d7305f218cb705b111e4c1..3e5fc441d59973cd9cfc5f219fc1a7d1ae4a42bc 100644 (file)
@@ -1162,27 +1162,26 @@ NTSTATUS rpccli_wbint_Gid2Sid(struct rpc_pipe_client *cli,
        return r.out.result;
 }
 
-struct rpccli_wbint_QueryUser_state {
-       struct wbint_QueryUser orig;
-       struct wbint_QueryUser tmp;
+struct rpccli_wbint_AllocateUid_state {
+       struct wbint_AllocateUid orig;
+       struct wbint_AllocateUid tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq);
+static void rpccli_wbint_AllocateUid_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_QueryUser_send(TALLOC_CTX *mem_ctx,
-                                              struct tevent_context *ev,
-                                              struct rpc_pipe_client *cli,
-                                              struct dom_sid *_sid /* [in] [ref] */,
-                                              struct wbint_userinfo *_info /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_AllocateUid_send(TALLOC_CTX *mem_ctx,
+                                                struct tevent_context *ev,
+                                                struct rpc_pipe_client *cli,
+                                                uint64_t *_uid /* [out] [ref] */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_QueryUser_state *state;
+       struct rpccli_wbint_AllocateUid_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_QueryUser_state);
+                               struct rpccli_wbint_AllocateUid_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1190,20 +1189,19 @@ struct tevent_req *rpccli_wbint_QueryUser_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
-       state->orig.in.sid = _sid;
 
        /* Out parameters */
-       state->orig.out.info = _info;
+       state->orig.out.uid = _uid;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QueryUser, &state->orig);
+               NDR_PRINT_IN_DEBUG(wbint_AllocateUid, &state->orig);
        }
 
        state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_QueryUser_out_memory");
+                            "rpccli_wbint_AllocateUid_out_memory");
        if (tevent_req_nomem(state->out_mem_ctx, req)) {
                return tevent_req_post(req, ev);
        }
@@ -1213,21 +1211,21 @@ struct tevent_req *rpccli_wbint_QueryUser_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_QUERYUSER,
+                                   NDR_WBINT_ALLOCATEUID,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_QueryUser_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_AllocateUid_done, req);
        return req;
 }
 
-static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq)
+static void rpccli_wbint_AllocateUid_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_QueryUser_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QueryUser_state);
+       struct rpccli_wbint_AllocateUid_state *state = tevent_req_data(
+               req, struct rpccli_wbint_AllocateUid_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -1245,7 +1243,7 @@ static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.info = *state->tmp.out.info;
+       *state->orig.out.uid = *state->tmp.out.uid;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -1254,18 +1252,18 @@ static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QueryUser, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_AllocateUid, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_QueryUser_recv(struct tevent_req *req,
-                                    TALLOC_CTX *mem_ctx,
-                                    NTSTATUS *result)
+NTSTATUS rpccli_wbint_AllocateUid_recv(struct tevent_req *req,
+                                      TALLOC_CTX *mem_ctx,
+                                      NTSTATUS *result)
 {
-       struct rpccli_wbint_QueryUser_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QueryUser_state);
+       struct rpccli_wbint_AllocateUid_state *state = tevent_req_data(
+               req, struct rpccli_wbint_AllocateUid_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -1283,25 +1281,23 @@ NTSTATUS rpccli_wbint_QueryUser_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_QueryUser(struct rpc_pipe_client *cli,
-                               TALLOC_CTX *mem_ctx,
-                               struct dom_sid *sid /* [in] [ref] */,
-                               struct wbint_userinfo *info /* [out] [ref] */)
+NTSTATUS rpccli_wbint_AllocateUid(struct rpc_pipe_client *cli,
+                                 TALLOC_CTX *mem_ctx,
+                                 uint64_t *uid /* [out] [ref] */)
 {
-       struct wbint_QueryUser r;
+       struct wbint_AllocateUid r;
        NTSTATUS status;
 
        /* In parameters */
-       r.in.sid = sid;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QueryUser, &r);
+               NDR_PRINT_IN_DEBUG(wbint_AllocateUid, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_QUERYUSER,
+                               NDR_WBINT_ALLOCATEUID,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -1309,7 +1305,7 @@ NTSTATUS rpccli_wbint_QueryUser(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QueryUser, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_AllocateUid, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -1317,33 +1313,32 @@ NTSTATUS rpccli_wbint_QueryUser(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *info = *r.out.info;
+       *uid = *r.out.uid;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_LookupUserAliases_state {
-       struct wbint_LookupUserAliases orig;
-       struct wbint_LookupUserAliases tmp;
+struct rpccli_wbint_AllocateGid_state {
+       struct wbint_AllocateGid orig;
+       struct wbint_AllocateGid tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq);
+static void rpccli_wbint_AllocateGid_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_LookupUserAliases_send(TALLOC_CTX *mem_ctx,
-                                                      struct tevent_context *ev,
-                                                      struct rpc_pipe_client *cli,
-                                                      struct wbint_SidArray *_sids /* [in] [ref] */,
-                                                      struct wbint_RidArray *_rids /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_AllocateGid_send(TALLOC_CTX *mem_ctx,
+                                                struct tevent_context *ev,
+                                                struct rpc_pipe_client *cli,
+                                                uint64_t *_gid /* [out] [ref] */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_LookupUserAliases_state *state;
+       struct rpccli_wbint_AllocateGid_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_LookupUserAliases_state);
+                               struct rpccli_wbint_AllocateGid_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1351,20 +1346,19 @@ struct tevent_req *rpccli_wbint_LookupUserAliases_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
-       state->orig.in.sids = _sids;
 
        /* Out parameters */
-       state->orig.out.rids = _rids;
+       state->orig.out.gid = _gid;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupUserAliases, &state->orig);
+               NDR_PRINT_IN_DEBUG(wbint_AllocateGid, &state->orig);
        }
 
        state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_LookupUserAliases_out_memory");
+                            "rpccli_wbint_AllocateGid_out_memory");
        if (tevent_req_nomem(state->out_mem_ctx, req)) {
                return tevent_req_post(req, ev);
        }
@@ -1374,21 +1368,21 @@ struct tevent_req *rpccli_wbint_LookupUserAliases_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_LOOKUPUSERALIASES,
+                                   NDR_WBINT_ALLOCATEGID,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_LookupUserAliases_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_AllocateGid_done, req);
        return req;
 }
 
-static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq)
+static void rpccli_wbint_AllocateGid_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_LookupUserAliases_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupUserAliases_state);
+       struct rpccli_wbint_AllocateGid_state *state = tevent_req_data(
+               req, struct rpccli_wbint_AllocateGid_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -1406,7 +1400,7 @@ static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.rids = *state->tmp.out.rids;
+       *state->orig.out.gid = *state->tmp.out.gid;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -1415,18 +1409,18 @@ static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupUserAliases, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_AllocateGid, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_LookupUserAliases_recv(struct tevent_req *req,
-                                            TALLOC_CTX *mem_ctx,
-                                            NTSTATUS *result)
+NTSTATUS rpccli_wbint_AllocateGid_recv(struct tevent_req *req,
+                                      TALLOC_CTX *mem_ctx,
+                                      NTSTATUS *result)
 {
-       struct rpccli_wbint_LookupUserAliases_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupUserAliases_state);
+       struct rpccli_wbint_AllocateGid_state *state = tevent_req_data(
+               req, struct rpccli_wbint_AllocateGid_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -1444,25 +1438,23 @@ NTSTATUS rpccli_wbint_LookupUserAliases_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_LookupUserAliases(struct rpc_pipe_client *cli,
-                                       TALLOC_CTX *mem_ctx,
-                                       struct wbint_SidArray *sids /* [in] [ref] */,
-                                       struct wbint_RidArray *rids /* [out] [ref] */)
+NTSTATUS rpccli_wbint_AllocateGid(struct rpc_pipe_client *cli,
+                                 TALLOC_CTX *mem_ctx,
+                                 uint64_t *gid /* [out] [ref] */)
 {
-       struct wbint_LookupUserAliases r;
+       struct wbint_AllocateGid r;
        NTSTATUS status;
 
        /* In parameters */
-       r.in.sids = sids;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupUserAliases, &r);
+               NDR_PRINT_IN_DEBUG(wbint_AllocateGid, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_LOOKUPUSERALIASES,
+                               NDR_WBINT_ALLOCATEGID,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -1470,7 +1462,7 @@ NTSTATUS rpccli_wbint_LookupUserAliases(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupUserAliases, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_AllocateGid, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -1478,33 +1470,33 @@ NTSTATUS rpccli_wbint_LookupUserAliases(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *rids = *r.out.rids;
+       *gid = *r.out.gid;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_LookupUserGroups_state {
-       struct wbint_LookupUserGroups orig;
-       struct wbint_LookupUserGroups tmp;
+struct rpccli_wbint_QueryUser_state {
+       struct wbint_QueryUser orig;
+       struct wbint_QueryUser tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq);
+static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_LookupUserGroups_send(TALLOC_CTX *mem_ctx,
-                                                     struct tevent_context *ev,
-                                                     struct rpc_pipe_client *cli,
-                                                     struct dom_sid *_sid /* [in] [ref] */,
-                                                     struct wbint_SidArray *_sids /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_QueryUser_send(TALLOC_CTX *mem_ctx,
+                                              struct tevent_context *ev,
+                                              struct rpc_pipe_client *cli,
+                                              struct dom_sid *_sid /* [in] [ref] */,
+                                              struct wbint_userinfo *_info /* [out] [ref] */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_LookupUserGroups_state *state;
+       struct rpccli_wbint_QueryUser_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_LookupUserGroups_state);
+                               struct rpccli_wbint_QueryUser_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1515,17 +1507,17 @@ struct tevent_req *rpccli_wbint_LookupUserGroups_send(TALLOC_CTX *mem_ctx,
        state->orig.in.sid = _sid;
 
        /* Out parameters */
-       state->orig.out.sids = _sids;
+       state->orig.out.info = _info;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupUserGroups, &state->orig);
+               NDR_PRINT_IN_DEBUG(wbint_QueryUser, &state->orig);
        }
 
        state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_LookupUserGroups_out_memory");
+                            "rpccli_wbint_QueryUser_out_memory");
        if (tevent_req_nomem(state->out_mem_ctx, req)) {
                return tevent_req_post(req, ev);
        }
@@ -1535,21 +1527,21 @@ struct tevent_req *rpccli_wbint_LookupUserGroups_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_LOOKUPUSERGROUPS,
+                                   NDR_WBINT_QUERYUSER,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_LookupUserGroups_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_QueryUser_done, req);
        return req;
 }
 
-static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq)
+static void rpccli_wbint_QueryUser_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_LookupUserGroups_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupUserGroups_state);
+       struct rpccli_wbint_QueryUser_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryUser_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -1567,7 +1559,7 @@ static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.sids = *state->tmp.out.sids;
+       *state->orig.out.info = *state->tmp.out.info;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -1576,18 +1568,18 @@ static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupUserGroups, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_QueryUser, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_LookupUserGroups_recv(struct tevent_req *req,
-                                           TALLOC_CTX *mem_ctx,
-                                           NTSTATUS *result)
+NTSTATUS rpccli_wbint_QueryUser_recv(struct tevent_req *req,
+                                    TALLOC_CTX *mem_ctx,
+                                    NTSTATUS *result)
 {
-       struct rpccli_wbint_LookupUserGroups_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupUserGroups_state);
+       struct rpccli_wbint_QueryUser_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryUser_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -1605,25 +1597,25 @@ NTSTATUS rpccli_wbint_LookupUserGroups_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_LookupUserGroups(struct rpc_pipe_client *cli,
-                                      TALLOC_CTX *mem_ctx,
-                                      struct dom_sid *sid /* [in] [ref] */,
-                                      struct wbint_SidArray *sids /* [out] [ref] */)
+NTSTATUS rpccli_wbint_QueryUser(struct rpc_pipe_client *cli,
+                               TALLOC_CTX *mem_ctx,
+                               struct dom_sid *sid /* [in] [ref] */,
+                               struct wbint_userinfo *info /* [out] [ref] */)
 {
-       struct wbint_LookupUserGroups r;
+       struct wbint_QueryUser r;
        NTSTATUS status;
 
        /* In parameters */
        r.in.sid = sid;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupUserGroups, &r);
+               NDR_PRINT_IN_DEBUG(wbint_QueryUser, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_LOOKUPUSERGROUPS,
+                               NDR_WBINT_QUERYUSER,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -1631,7 +1623,7 @@ NTSTATUS rpccli_wbint_LookupUserGroups(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupUserGroups, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_QueryUser, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -1639,32 +1631,1164 @@ NTSTATUS rpccli_wbint_LookupUserGroups(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *sids = *r.out.sids;
+       *info = *r.out.info;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_QuerySequenceNumber_state {
-       struct wbint_QuerySequenceNumber orig;
-       struct wbint_QuerySequenceNumber tmp;
+struct rpccli_wbint_LookupUserAliases_state {
+       struct wbint_LookupUserAliases orig;
+       struct wbint_LookupUserAliases tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq);
+static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_QuerySequenceNumber_send(TALLOC_CTX *mem_ctx,
-                                                        struct tevent_context *ev,
-                                                        struct rpc_pipe_client *cli,
-                                                        uint32_t *_sequence /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_LookupUserAliases_send(TALLOC_CTX *mem_ctx,
+                                                      struct tevent_context *ev,
+                                                      struct rpc_pipe_client *cli,
+                                                      struct wbint_SidArray *_sids /* [in] [ref] */,
+                                                      struct wbint_RidArray *_rids /* [out] [ref] */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_QuerySequenceNumber_state *state;
+       struct rpccli_wbint_LookupUserAliases_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_LookupUserAliases_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+       state->orig.in.sids = _sids;
+
+       /* Out parameters */
+       state->orig.out.rids = _rids;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupUserAliases, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_LookupUserAliases_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_LOOKUPUSERALIASES,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_LookupUserAliases_done, req);
+       return req;
+}
+
+static void rpccli_wbint_LookupUserAliases_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_LookupUserAliases_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupUserAliases_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.rids = *state->tmp.out.rids;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupUserAliases, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_LookupUserAliases_recv(struct tevent_req *req,
+                                            TALLOC_CTX *mem_ctx,
+                                            NTSTATUS *result)
+{
+       struct rpccli_wbint_LookupUserAliases_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupUserAliases_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_LookupUserAliases(struct rpc_pipe_client *cli,
+                                       TALLOC_CTX *mem_ctx,
+                                       struct wbint_SidArray *sids /* [in] [ref] */,
+                                       struct wbint_RidArray *rids /* [out] [ref] */)
+{
+       struct wbint_LookupUserAliases r;
+       NTSTATUS status;
+
+       /* In parameters */
+       r.in.sids = sids;
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupUserAliases, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_LOOKUPUSERALIASES,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupUserAliases, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *rids = *r.out.rids;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_LookupUserGroups_state {
+       struct wbint_LookupUserGroups orig;
+       struct wbint_LookupUserGroups tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_LookupUserGroups_send(TALLOC_CTX *mem_ctx,
+                                                     struct tevent_context *ev,
+                                                     struct rpc_pipe_client *cli,
+                                                     struct dom_sid *_sid /* [in] [ref] */,
+                                                     struct wbint_SidArray *_sids /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_LookupUserGroups_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_LookupUserGroups_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+       state->orig.in.sid = _sid;
+
+       /* Out parameters */
+       state->orig.out.sids = _sids;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupUserGroups, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_LookupUserGroups_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_LOOKUPUSERGROUPS,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_LookupUserGroups_done, req);
+       return req;
+}
+
+static void rpccli_wbint_LookupUserGroups_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_LookupUserGroups_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupUserGroups_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.sids = *state->tmp.out.sids;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupUserGroups, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_LookupUserGroups_recv(struct tevent_req *req,
+                                           TALLOC_CTX *mem_ctx,
+                                           NTSTATUS *result)
+{
+       struct rpccli_wbint_LookupUserGroups_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupUserGroups_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_LookupUserGroups(struct rpc_pipe_client *cli,
+                                      TALLOC_CTX *mem_ctx,
+                                      struct dom_sid *sid /* [in] [ref] */,
+                                      struct wbint_SidArray *sids /* [out] [ref] */)
+{
+       struct wbint_LookupUserGroups r;
+       NTSTATUS status;
+
+       /* In parameters */
+       r.in.sid = sid;
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupUserGroups, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_LOOKUPUSERGROUPS,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupUserGroups, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *sids = *r.out.sids;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_QuerySequenceNumber_state {
+       struct wbint_QuerySequenceNumber orig;
+       struct wbint_QuerySequenceNumber tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_QuerySequenceNumber_send(TALLOC_CTX *mem_ctx,
+                                                        struct tevent_context *ev,
+                                                        struct rpc_pipe_client *cli,
+                                                        uint32_t *_sequence /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_QuerySequenceNumber_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_QuerySequenceNumber_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+
+       /* Out parameters */
+       state->orig.out.sequence = _sequence;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QuerySequenceNumber, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_QuerySequenceNumber_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_QUERYSEQUENCENUMBER,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_QuerySequenceNumber_done, req);
+       return req;
+}
+
+static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_QuerySequenceNumber_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QuerySequenceNumber_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.sequence = *state->tmp.out.sequence;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QuerySequenceNumber, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_QuerySequenceNumber_recv(struct tevent_req *req,
+                                              TALLOC_CTX *mem_ctx,
+                                              NTSTATUS *result)
+{
+       struct rpccli_wbint_QuerySequenceNumber_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QuerySequenceNumber_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_QuerySequenceNumber(struct rpc_pipe_client *cli,
+                                         TALLOC_CTX *mem_ctx,
+                                         uint32_t *sequence /* [out] [ref] */)
+{
+       struct wbint_QuerySequenceNumber r;
+       NTSTATUS status;
+
+       /* In parameters */
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QuerySequenceNumber, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_QUERYSEQUENCENUMBER,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QuerySequenceNumber, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *sequence = *r.out.sequence;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_LookupGroupMembers_state {
+       struct wbint_LookupGroupMembers orig;
+       struct wbint_LookupGroupMembers tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_LookupGroupMembers_send(TALLOC_CTX *mem_ctx,
+                                                       struct tevent_context *ev,
+                                                       struct rpc_pipe_client *cli,
+                                                       struct dom_sid *_sid /* [in] [ref] */,
+                                                       enum lsa_SidType _type /* [in]  */,
+                                                       struct wbint_Principals *_members /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_LookupGroupMembers_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_LookupGroupMembers_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+       state->orig.in.sid = _sid;
+       state->orig.in.type = _type;
+
+       /* Out parameters */
+       state->orig.out.members = _members;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupGroupMembers, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_LookupGroupMembers_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_LOOKUPGROUPMEMBERS,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_LookupGroupMembers_done, req);
+       return req;
+}
+
+static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_LookupGroupMembers_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupGroupMembers_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.members = *state->tmp.out.members;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupGroupMembers, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_LookupGroupMembers_recv(struct tevent_req *req,
+                                             TALLOC_CTX *mem_ctx,
+                                             NTSTATUS *result)
+{
+       struct rpccli_wbint_LookupGroupMembers_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupGroupMembers_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_LookupGroupMembers(struct rpc_pipe_client *cli,
+                                        TALLOC_CTX *mem_ctx,
+                                        struct dom_sid *sid /* [in] [ref] */,
+                                        enum lsa_SidType type /* [in]  */,
+                                        struct wbint_Principals *members /* [out] [ref] */)
+{
+       struct wbint_LookupGroupMembers r;
+       NTSTATUS status;
+
+       /* In parameters */
+       r.in.sid = sid;
+       r.in.type = type;
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_LookupGroupMembers, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_LOOKUPGROUPMEMBERS,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_LookupGroupMembers, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *members = *r.out.members;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_QueryUserList_state {
+       struct wbint_QueryUserList orig;
+       struct wbint_QueryUserList tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_QueryUserList_send(TALLOC_CTX *mem_ctx,
+                                                  struct tevent_context *ev,
+                                                  struct rpc_pipe_client *cli,
+                                                  struct wbint_userinfos *_users /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_QueryUserList_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_QueryUserList_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+
+       /* Out parameters */
+       state->orig.out.users = _users;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QueryUserList, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_QueryUserList_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_QUERYUSERLIST,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_QueryUserList_done, req);
+       return req;
+}
+
+static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_QueryUserList_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryUserList_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.users = *state->tmp.out.users;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QueryUserList, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_QueryUserList_recv(struct tevent_req *req,
+                                        TALLOC_CTX *mem_ctx,
+                                        NTSTATUS *result)
+{
+       struct rpccli_wbint_QueryUserList_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryUserList_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_QueryUserList(struct rpc_pipe_client *cli,
+                                   TALLOC_CTX *mem_ctx,
+                                   struct wbint_userinfos *users /* [out] [ref] */)
+{
+       struct wbint_QueryUserList r;
+       NTSTATUS status;
+
+       /* In parameters */
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QueryUserList, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_QUERYUSERLIST,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QueryUserList, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *users = *r.out.users;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_QueryGroupList_state {
+       struct wbint_QueryGroupList orig;
+       struct wbint_QueryGroupList tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_QueryGroupList_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_QueryGroupList_send(TALLOC_CTX *mem_ctx,
+                                                   struct tevent_context *ev,
+                                                   struct rpc_pipe_client *cli,
+                                                   struct wbint_Principals *_groups /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_QueryGroupList_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_QueryGroupList_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+
+       /* Out parameters */
+       state->orig.out.groups = _groups;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QueryGroupList, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_QueryGroupList_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_QUERYGROUPLIST,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_QueryGroupList_done, req);
+       return req;
+}
+
+static void rpccli_wbint_QueryGroupList_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_QueryGroupList_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryGroupList_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.groups = *state->tmp.out.groups;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QueryGroupList, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_QueryGroupList_recv(struct tevent_req *req,
+                                         TALLOC_CTX *mem_ctx,
+                                         NTSTATUS *result)
+{
+       struct rpccli_wbint_QueryGroupList_state *state = tevent_req_data(
+               req, struct rpccli_wbint_QueryGroupList_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_QueryGroupList(struct rpc_pipe_client *cli,
+                                    TALLOC_CTX *mem_ctx,
+                                    struct wbint_Principals *groups /* [out] [ref] */)
+{
+       struct wbint_QueryGroupList r;
+       NTSTATUS status;
+
+       /* In parameters */
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_QueryGroupList, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_QUERYGROUPLIST,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_QueryGroupList, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *groups = *r.out.groups;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_DsGetDcName_state {
+       struct wbint_DsGetDcName orig;
+       struct wbint_DsGetDcName tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_DsGetDcName_send(TALLOC_CTX *mem_ctx,
+                                                struct tevent_context *ev,
+                                                struct rpc_pipe_client *cli,
+                                                const char *_domain_name /* [in] [ref,charset(UTF8)] */,
+                                                struct GUID *_domain_guid /* [in] [unique] */,
+                                                const char *_site_name /* [in] [unique,charset(UTF8)] */,
+                                                uint32_t _flags /* [in]  */,
+                                                struct netr_DsRGetDCNameInfo **_dc_info /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_DsGetDcName_state *state;
+       struct tevent_req *subreq;
+
+       req = tevent_req_create(mem_ctx, &state,
+                               struct rpccli_wbint_DsGetDcName_state);
+       if (req == NULL) {
+               return NULL;
+       }
+       state->out_mem_ctx = NULL;
+       state->dispatch_recv = cli->dispatch_recv;
+
+       /* In parameters */
+       state->orig.in.domain_name = _domain_name;
+       state->orig.in.domain_guid = _domain_guid;
+       state->orig.in.site_name = _site_name;
+       state->orig.in.flags = _flags;
+
+       /* Out parameters */
+       state->orig.out.dc_info = _dc_info;
+
+       /* Result */
+       ZERO_STRUCT(state->orig.out.result);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_DsGetDcName, &state->orig);
+       }
+
+       state->out_mem_ctx = talloc_named_const(state, 0,
+                            "rpccli_wbint_DsGetDcName_out_memory");
+       if (tevent_req_nomem(state->out_mem_ctx, req)) {
+               return tevent_req_post(req, ev);
+       }
+
+       /* make a temporary copy, that we pass to the dispatch function */
+       state->tmp = state->orig;
+
+       subreq = cli->dispatch_send(state, ev, cli,
+                                   &ndr_table_wbint,
+                                   NDR_WBINT_DSGETDCNAME,
+                                   &state->tmp);
+       if (tevent_req_nomem(subreq, req)) {
+               return tevent_req_post(req, ev);
+       }
+       tevent_req_set_callback(subreq, rpccli_wbint_DsGetDcName_done, req);
+       return req;
+}
+
+static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq)
+{
+       struct tevent_req *req = tevent_req_callback_data(
+               subreq, struct tevent_req);
+       struct rpccli_wbint_DsGetDcName_state *state = tevent_req_data(
+               req, struct rpccli_wbint_DsGetDcName_state);
+       NTSTATUS status;
+       TALLOC_CTX *mem_ctx;
+
+       if (state->out_mem_ctx) {
+               mem_ctx = state->out_mem_ctx;
+       } else {
+               mem_ctx = state;
+       }
+
+       status = state->dispatch_recv(subreq, mem_ctx);
+       TALLOC_FREE(subreq);
+       if (!NT_STATUS_IS_OK(status)) {
+               tevent_req_nterror(req, status);
+               return;
+       }
+
+       /* Copy out parameters */
+       *state->orig.out.dc_info = *state->tmp.out.dc_info;
+
+       /* Copy result */
+       state->orig.out.result = state->tmp.out.result;
+
+       /* Reset temporary structure */
+       ZERO_STRUCT(state->tmp);
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_DsGetDcName, &state->orig);
+       }
+
+       tevent_req_done(req);
+}
+
+NTSTATUS rpccli_wbint_DsGetDcName_recv(struct tevent_req *req,
+                                      TALLOC_CTX *mem_ctx,
+                                      NTSTATUS *result)
+{
+       struct rpccli_wbint_DsGetDcName_state *state = tevent_req_data(
+               req, struct rpccli_wbint_DsGetDcName_state);
+       NTSTATUS status;
+
+       if (tevent_req_is_nterror(req, &status)) {
+               tevent_req_received(req);
+               return status;
+       }
+
+       /* Steal possbile out parameters to the callers context */
+       talloc_steal(mem_ctx, state->out_mem_ctx);
+
+       /* Return result */
+       *result = state->orig.out.result;
+
+       tevent_req_received(req);
+       return NT_STATUS_OK;
+}
+
+NTSTATUS rpccli_wbint_DsGetDcName(struct rpc_pipe_client *cli,
+                                 TALLOC_CTX *mem_ctx,
+                                 const char *domain_name /* [in] [ref,charset(UTF8)] */,
+                                 struct GUID *domain_guid /* [in] [unique] */,
+                                 const char *site_name /* [in] [unique,charset(UTF8)] */,
+                                 uint32_t flags /* [in]  */,
+                                 struct netr_DsRGetDCNameInfo **dc_info /* [out] [ref] */)
+{
+       struct wbint_DsGetDcName r;
+       NTSTATUS status;
+
+       /* In parameters */
+       r.in.domain_name = domain_name;
+       r.in.domain_guid = domain_guid;
+       r.in.site_name = site_name;
+       r.in.flags = flags;
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(wbint_DsGetDcName, &r);
+       }
+
+       status = cli->dispatch(cli,
+                               mem_ctx,
+                               &ndr_table_wbint,
+                               NDR_WBINT_DSGETDCNAME,
+                               &r);
+
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(wbint_DsGetDcName, &r);
+       }
+
+       if (NT_STATUS_IS_ERR(status)) {
+               return status;
+       }
+
+       /* Return variables */
+       *dc_info = *r.out.dc_info;
+
+       /* Return result */
+       return r.out.result;
+}
+
+struct rpccli_wbint_LookupRids_state {
+       struct wbint_LookupRids orig;
+       struct wbint_LookupRids tmp;
+       TALLOC_CTX *out_mem_ctx;
+       NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
+};
+
+static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq);
+
+struct tevent_req *rpccli_wbint_LookupRids_send(TALLOC_CTX *mem_ctx,
+                                               struct tevent_context *ev,
+                                               struct rpc_pipe_client *cli,
+                                               struct wbint_RidArray *_rids /* [in] [ref] */,
+                                               struct wbint_Principals *_names /* [out] [ref] */)
+{
+       struct tevent_req *req;
+       struct rpccli_wbint_LookupRids_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_QuerySequenceNumber_state);
+                               struct rpccli_wbint_LookupRids_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1672,19 +2796,20 @@ struct tevent_req *rpccli_wbint_QuerySequenceNumber_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
+       state->orig.in.rids = _rids;
 
        /* Out parameters */
-       state->orig.out.sequence = _sequence;
+       state->orig.out.names = _names;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QuerySequenceNumber, &state->orig);
+               NDR_PRINT_IN_DEBUG(wbint_LookupRids, &state->orig);
        }
 
        state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_QuerySequenceNumber_out_memory");
+                            "rpccli_wbint_LookupRids_out_memory");
        if (tevent_req_nomem(state->out_mem_ctx, req)) {
                return tevent_req_post(req, ev);
        }
@@ -1694,21 +2819,21 @@ struct tevent_req *rpccli_wbint_QuerySequenceNumber_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_QUERYSEQUENCENUMBER,
+                                   NDR_WBINT_LOOKUPRIDS,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_QuerySequenceNumber_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_LookupRids_done, req);
        return req;
 }
 
-static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq)
+static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_QuerySequenceNumber_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QuerySequenceNumber_state);
+       struct rpccli_wbint_LookupRids_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupRids_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -1726,7 +2851,7 @@ static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.sequence = *state->tmp.out.sequence;
+       *state->orig.out.names = *state->tmp.out.names;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -1735,18 +2860,18 @@ static void rpccli_wbint_QuerySequenceNumber_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QuerySequenceNumber, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_LookupRids, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_QuerySequenceNumber_recv(struct tevent_req *req,
-                                              TALLOC_CTX *mem_ctx,
-                                              NTSTATUS *result)
+NTSTATUS rpccli_wbint_LookupRids_recv(struct tevent_req *req,
+                                     TALLOC_CTX *mem_ctx,
+                                     NTSTATUS *result)
 {
-       struct rpccli_wbint_QuerySequenceNumber_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QuerySequenceNumber_state);
+       struct rpccli_wbint_LookupRids_state *state = tevent_req_data(
+               req, struct rpccli_wbint_LookupRids_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -1764,23 +2889,25 @@ NTSTATUS rpccli_wbint_QuerySequenceNumber_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_QuerySequenceNumber(struct rpc_pipe_client *cli,
-                                         TALLOC_CTX *mem_ctx,
-                                         uint32_t *sequence /* [out] [ref] */)
+NTSTATUS rpccli_wbint_LookupRids(struct rpc_pipe_client *cli,
+                                TALLOC_CTX *mem_ctx,
+                                struct wbint_RidArray *rids /* [in] [ref] */,
+                                struct wbint_Principals *names /* [out] [ref] */)
 {
-       struct wbint_QuerySequenceNumber r;
+       struct wbint_LookupRids r;
        NTSTATUS status;
 
        /* In parameters */
+       r.in.rids = rids;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QuerySequenceNumber, &r);
+               NDR_PRINT_IN_DEBUG(wbint_LookupRids, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_QUERYSEQUENCENUMBER,
+                               NDR_WBINT_LOOKUPRIDS,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -1788,7 +2915,7 @@ NTSTATUS rpccli_wbint_QuerySequenceNumber(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QuerySequenceNumber, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_LookupRids, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -1796,34 +2923,31 @@ NTSTATUS rpccli_wbint_QuerySequenceNumber(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *sequence = *r.out.sequence;
+       *names = *r.out.names;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_LookupGroupMembers_state {
-       struct wbint_LookupGroupMembers orig;
-       struct wbint_LookupGroupMembers tmp;
+struct rpccli_wbint_CheckMachineAccount_state {
+       struct wbint_CheckMachineAccount orig;
+       struct wbint_CheckMachineAccount tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq);
+static void rpccli_wbint_CheckMachineAccount_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_LookupGroupMembers_send(TALLOC_CTX *mem_ctx,
-                                                       struct tevent_context *ev,
-                                                       struct rpc_pipe_client *cli,
-                                                       struct dom_sid *_sid /* [in] [ref] */,
-                                                       enum lsa_SidType _type /* [in]  */,
-                                                       struct wbint_Principals *_members /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_CheckMachineAccount_send(TALLOC_CTX *mem_ctx,
+                                                        struct tevent_context *ev,
+                                                        struct rpc_pipe_client *cli)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_LookupGroupMembers_state *state;
+       struct rpccli_wbint_CheckMachineAccount_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_LookupGroupMembers_state);
+                               struct rpccli_wbint_CheckMachineAccount_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1831,23 +2955,14 @@ struct tevent_req *rpccli_wbint_LookupGroupMembers_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
-       state->orig.in.sid = _sid;
-       state->orig.in.type = _type;
 
        /* Out parameters */
-       state->orig.out.members = _members;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupGroupMembers, &state->orig);
-       }
-
-       state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_LookupGroupMembers_out_memory");
-       if (tevent_req_nomem(state->out_mem_ctx, req)) {
-               return tevent_req_post(req, ev);
+               NDR_PRINT_IN_DEBUG(wbint_CheckMachineAccount, &state->orig);
        }
 
        /* make a temporary copy, that we pass to the dispatch function */
@@ -1855,21 +2970,21 @@ struct tevent_req *rpccli_wbint_LookupGroupMembers_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_LOOKUPGROUPMEMBERS,
+                                   NDR_WBINT_CHECKMACHINEACCOUNT,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_LookupGroupMembers_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_CheckMachineAccount_done, req);
        return req;
 }
 
-static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq)
+static void rpccli_wbint_CheckMachineAccount_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_LookupGroupMembers_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupGroupMembers_state);
+       struct rpccli_wbint_CheckMachineAccount_state *state = tevent_req_data(
+               req, struct rpccli_wbint_CheckMachineAccount_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -1887,7 +3002,6 @@ static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.members = *state->tmp.out.members;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -1896,18 +3010,18 @@ static void rpccli_wbint_LookupGroupMembers_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupGroupMembers, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_CheckMachineAccount, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_LookupGroupMembers_recv(struct tevent_req *req,
-                                             TALLOC_CTX *mem_ctx,
-                                             NTSTATUS *result)
+NTSTATUS rpccli_wbint_CheckMachineAccount_recv(struct tevent_req *req,
+                                              TALLOC_CTX *mem_ctx,
+                                              NTSTATUS *result)
 {
-       struct rpccli_wbint_LookupGroupMembers_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupGroupMembers_state);
+       struct rpccli_wbint_CheckMachineAccount_state *state = tevent_req_data(
+               req, struct rpccli_wbint_CheckMachineAccount_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -1925,27 +3039,22 @@ NTSTATUS rpccli_wbint_LookupGroupMembers_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_LookupGroupMembers(struct rpc_pipe_client *cli,
-                                        TALLOC_CTX *mem_ctx,
-                                        struct dom_sid *sid /* [in] [ref] */,
-                                        enum lsa_SidType type /* [in]  */,
-                                        struct wbint_Principals *members /* [out] [ref] */)
+NTSTATUS rpccli_wbint_CheckMachineAccount(struct rpc_pipe_client *cli,
+                                         TALLOC_CTX *mem_ctx)
 {
-       struct wbint_LookupGroupMembers r;
+       struct wbint_CheckMachineAccount r;
        NTSTATUS status;
 
        /* In parameters */
-       r.in.sid = sid;
-       r.in.type = type;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupGroupMembers, &r);
+               NDR_PRINT_IN_DEBUG(wbint_CheckMachineAccount, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_LOOKUPGROUPMEMBERS,
+                               NDR_WBINT_CHECKMACHINEACCOUNT,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -1953,7 +3062,7 @@ NTSTATUS rpccli_wbint_LookupGroupMembers(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupGroupMembers, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_CheckMachineAccount, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -1961,32 +3070,33 @@ NTSTATUS rpccli_wbint_LookupGroupMembers(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *members = *r.out.members;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_QueryUserList_state {
-       struct wbint_QueryUserList orig;
-       struct wbint_QueryUserList tmp;
+struct rpccli_wbint_SetMapping_state {
+       struct wbint_SetMapping orig;
+       struct wbint_SetMapping tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq);
+static void rpccli_wbint_SetMapping_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_QueryUserList_send(TALLOC_CTX *mem_ctx,
-                                                  struct tevent_context *ev,
-                                                  struct rpc_pipe_client *cli,
-                                                  struct wbint_userinfos *_users /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_SetMapping_send(TALLOC_CTX *mem_ctx,
+                                               struct tevent_context *ev,
+                                               struct rpc_pipe_client *cli,
+                                               struct dom_sid *_sid /* [in] [ref] */,
+                                               enum wbint_IdType _type /* [in]  */,
+                                               uint64_t _id /* [in]  */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_QueryUserList_state *state;
+       struct rpccli_wbint_SetMapping_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_QueryUserList_state);
+                               struct rpccli_wbint_SetMapping_state);
        if (req == NULL) {
                return NULL;
        }
@@ -1994,21 +3104,17 @@ struct tevent_req *rpccli_wbint_QueryUserList_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
+       state->orig.in.sid = _sid;
+       state->orig.in.type = _type;
+       state->orig.in.id = _id;
 
        /* Out parameters */
-       state->orig.out.users = _users;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QueryUserList, &state->orig);
-       }
-
-       state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_QueryUserList_out_memory");
-       if (tevent_req_nomem(state->out_mem_ctx, req)) {
-               return tevent_req_post(req, ev);
+               NDR_PRINT_IN_DEBUG(wbint_SetMapping, &state->orig);
        }
 
        /* make a temporary copy, that we pass to the dispatch function */
@@ -2016,21 +3122,21 @@ struct tevent_req *rpccli_wbint_QueryUserList_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_QUERYUSERLIST,
+                                   NDR_WBINT_SETMAPPING,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_QueryUserList_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_SetMapping_done, req);
        return req;
 }
 
-static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq)
+static void rpccli_wbint_SetMapping_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_QueryUserList_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QueryUserList_state);
+       struct rpccli_wbint_SetMapping_state *state = tevent_req_data(
+               req, struct rpccli_wbint_SetMapping_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -2048,7 +3154,6 @@ static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.users = *state->tmp.out.users;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -2057,18 +3162,18 @@ static void rpccli_wbint_QueryUserList_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QueryUserList, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_SetMapping, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_QueryUserList_recv(struct tevent_req *req,
-                                        TALLOC_CTX *mem_ctx,
-                                        NTSTATUS *result)
+NTSTATUS rpccli_wbint_SetMapping_recv(struct tevent_req *req,
+                                     TALLOC_CTX *mem_ctx,
+                                     NTSTATUS *result)
 {
-       struct rpccli_wbint_QueryUserList_state *state = tevent_req_data(
-               req, struct rpccli_wbint_QueryUserList_state);
+       struct rpccli_wbint_SetMapping_state *state = tevent_req_data(
+               req, struct rpccli_wbint_SetMapping_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -2086,23 +3191,28 @@ NTSTATUS rpccli_wbint_QueryUserList_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_QueryUserList(struct rpc_pipe_client *cli,
-                                   TALLOC_CTX *mem_ctx,
-                                   struct wbint_userinfos *users /* [out] [ref] */)
+NTSTATUS rpccli_wbint_SetMapping(struct rpc_pipe_client *cli,
+                                TALLOC_CTX *mem_ctx,
+                                struct dom_sid *sid /* [in] [ref] */,
+                                enum wbint_IdType type /* [in]  */,
+                                uint64_t id /* [in]  */)
 {
-       struct wbint_QueryUserList r;
+       struct wbint_SetMapping r;
        NTSTATUS status;
 
        /* In parameters */
+       r.in.sid = sid;
+       r.in.type = type;
+       r.in.id = id;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_QueryUserList, &r);
+               NDR_PRINT_IN_DEBUG(wbint_SetMapping, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_QUERYUSERLIST,
+                               NDR_WBINT_SETMAPPING,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -2110,7 +3220,7 @@ NTSTATUS rpccli_wbint_QueryUserList(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_QueryUserList, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_SetMapping, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -2118,36 +3228,33 @@ NTSTATUS rpccli_wbint_QueryUserList(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *users = *r.out.users;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_DsGetDcName_state {
-       struct wbint_DsGetDcName orig;
-       struct wbint_DsGetDcName tmp;
+struct rpccli_wbint_RemoveMapping_state {
+       struct wbint_RemoveMapping orig;
+       struct wbint_RemoveMapping tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq);
+static void rpccli_wbint_RemoveMapping_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_DsGetDcName_send(TALLOC_CTX *mem_ctx,
-                                                struct tevent_context *ev,
-                                                struct rpc_pipe_client *cli,
-                                                const char *_domain_name /* [in] [ref,charset(UTF8)] */,
-                                                struct GUID *_domain_guid /* [in] [unique] */,
-                                                const char *_site_name /* [in] [unique,charset(UTF8)] */,
-                                                uint32_t _flags /* [in]  */,
-                                                struct netr_DsRGetDCNameInfo **_dc_info /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_RemoveMapping_send(TALLOC_CTX *mem_ctx,
+                                                  struct tevent_context *ev,
+                                                  struct rpc_pipe_client *cli,
+                                                  struct dom_sid *_sid /* [in] [ref] */,
+                                                  enum wbint_IdType _type /* [in]  */,
+                                                  uint64_t _id /* [in]  */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_DsGetDcName_state *state;
+       struct rpccli_wbint_RemoveMapping_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_DsGetDcName_state);
+                               struct rpccli_wbint_RemoveMapping_state);
        if (req == NULL) {
                return NULL;
        }
@@ -2155,25 +3262,17 @@ struct tevent_req *rpccli_wbint_DsGetDcName_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
-       state->orig.in.domain_name = _domain_name;
-       state->orig.in.domain_guid = _domain_guid;
-       state->orig.in.site_name = _site_name;
-       state->orig.in.flags = _flags;
+       state->orig.in.sid = _sid;
+       state->orig.in.type = _type;
+       state->orig.in.id = _id;
 
        /* Out parameters */
-       state->orig.out.dc_info = _dc_info;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_DsGetDcName, &state->orig);
-       }
-
-       state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_DsGetDcName_out_memory");
-       if (tevent_req_nomem(state->out_mem_ctx, req)) {
-               return tevent_req_post(req, ev);
+               NDR_PRINT_IN_DEBUG(wbint_RemoveMapping, &state->orig);
        }
 
        /* make a temporary copy, that we pass to the dispatch function */
@@ -2181,21 +3280,21 @@ struct tevent_req *rpccli_wbint_DsGetDcName_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_DSGETDCNAME,
+                                   NDR_WBINT_REMOVEMAPPING,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_DsGetDcName_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_RemoveMapping_done, req);
        return req;
 }
 
-static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq)
+static void rpccli_wbint_RemoveMapping_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_DsGetDcName_state *state = tevent_req_data(
-               req, struct rpccli_wbint_DsGetDcName_state);
+       struct rpccli_wbint_RemoveMapping_state *state = tevent_req_data(
+               req, struct rpccli_wbint_RemoveMapping_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -2213,7 +3312,6 @@ static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.dc_info = *state->tmp.out.dc_info;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -2222,18 +3320,18 @@ static void rpccli_wbint_DsGetDcName_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_DsGetDcName, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_RemoveMapping, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_DsGetDcName_recv(struct tevent_req *req,
-                                      TALLOC_CTX *mem_ctx,
-                                      NTSTATUS *result)
+NTSTATUS rpccli_wbint_RemoveMapping_recv(struct tevent_req *req,
+                                        TALLOC_CTX *mem_ctx,
+                                        NTSTATUS *result)
 {
-       struct rpccli_wbint_DsGetDcName_state *state = tevent_req_data(
-               req, struct rpccli_wbint_DsGetDcName_state);
+       struct rpccli_wbint_RemoveMapping_state *state = tevent_req_data(
+               req, struct rpccli_wbint_RemoveMapping_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -2251,31 +3349,28 @@ NTSTATUS rpccli_wbint_DsGetDcName_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_DsGetDcName(struct rpc_pipe_client *cli,
-                                 TALLOC_CTX *mem_ctx,
-                                 const char *domain_name /* [in] [ref,charset(UTF8)] */,
-                                 struct GUID *domain_guid /* [in] [unique] */,
-                                 const char *site_name /* [in] [unique,charset(UTF8)] */,
-                                 uint32_t flags /* [in]  */,
-                                 struct netr_DsRGetDCNameInfo **dc_info /* [out] [ref] */)
+NTSTATUS rpccli_wbint_RemoveMapping(struct rpc_pipe_client *cli,
+                                   TALLOC_CTX *mem_ctx,
+                                   struct dom_sid *sid /* [in] [ref] */,
+                                   enum wbint_IdType type /* [in]  */,
+                                   uint64_t id /* [in]  */)
 {
-       struct wbint_DsGetDcName r;
+       struct wbint_RemoveMapping r;
        NTSTATUS status;
 
        /* In parameters */
-       r.in.domain_name = domain_name;
-       r.in.domain_guid = domain_guid;
-       r.in.site_name = site_name;
-       r.in.flags = flags;
+       r.in.sid = sid;
+       r.in.type = type;
+       r.in.id = id;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_DsGetDcName, &r);
+               NDR_PRINT_IN_DEBUG(wbint_RemoveMapping, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_DSGETDCNAME,
+                               NDR_WBINT_REMOVEMAPPING,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -2283,7 +3378,7 @@ NTSTATUS rpccli_wbint_DsGetDcName(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_DsGetDcName, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_RemoveMapping, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -2291,33 +3386,32 @@ NTSTATUS rpccli_wbint_DsGetDcName(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *dc_info = *r.out.dc_info;
 
        /* Return result */
        return r.out.result;
 }
 
-struct rpccli_wbint_LookupRids_state {
-       struct wbint_LookupRids orig;
-       struct wbint_LookupRids tmp;
+struct rpccli_wbint_SetHWM_state {
+       struct wbint_SetHWM orig;
+       struct wbint_SetHWM tmp;
        TALLOC_CTX *out_mem_ctx;
        NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
 };
 
-static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq);
+static void rpccli_wbint_SetHWM_done(struct tevent_req *subreq);
 
-struct tevent_req *rpccli_wbint_LookupRids_send(TALLOC_CTX *mem_ctx,
-                                               struct tevent_context *ev,
-                                               struct rpc_pipe_client *cli,
-                                               struct wbint_RidArray *_rids /* [in] [ref] */,
-                                               struct wbint_Principals *_names /* [out] [ref] */)
+struct tevent_req *rpccli_wbint_SetHWM_send(TALLOC_CTX *mem_ctx,
+                                           struct tevent_context *ev,
+                                           struct rpc_pipe_client *cli,
+                                           enum wbint_IdType _type /* [in]  */,
+                                           uint64_t _id /* [in]  */)
 {
        struct tevent_req *req;
-       struct rpccli_wbint_LookupRids_state *state;
+       struct rpccli_wbint_SetHWM_state *state;
        struct tevent_req *subreq;
 
        req = tevent_req_create(mem_ctx, &state,
-                               struct rpccli_wbint_LookupRids_state);
+                               struct rpccli_wbint_SetHWM_state);
        if (req == NULL) {
                return NULL;
        }
@@ -2325,22 +3419,16 @@ struct tevent_req *rpccli_wbint_LookupRids_send(TALLOC_CTX *mem_ctx,
        state->dispatch_recv = cli->dispatch_recv;
 
        /* In parameters */
-       state->orig.in.rids = _rids;
+       state->orig.in.type = _type;
+       state->orig.in.id = _id;
 
        /* Out parameters */
-       state->orig.out.names = _names;
 
        /* Result */
        ZERO_STRUCT(state->orig.out.result);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupRids, &state->orig);
-       }
-
-       state->out_mem_ctx = talloc_named_const(state, 0,
-                            "rpccli_wbint_LookupRids_out_memory");
-       if (tevent_req_nomem(state->out_mem_ctx, req)) {
-               return tevent_req_post(req, ev);
+               NDR_PRINT_IN_DEBUG(wbint_SetHWM, &state->orig);
        }
 
        /* make a temporary copy, that we pass to the dispatch function */
@@ -2348,21 +3436,21 @@ struct tevent_req *rpccli_wbint_LookupRids_send(TALLOC_CTX *mem_ctx,
 
        subreq = cli->dispatch_send(state, ev, cli,
                                    &ndr_table_wbint,
-                                   NDR_WBINT_LOOKUPRIDS,
+                                   NDR_WBINT_SETHWM,
                                    &state->tmp);
        if (tevent_req_nomem(subreq, req)) {
                return tevent_req_post(req, ev);
        }
-       tevent_req_set_callback(subreq, rpccli_wbint_LookupRids_done, req);
+       tevent_req_set_callback(subreq, rpccli_wbint_SetHWM_done, req);
        return req;
 }
 
-static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq)
+static void rpccli_wbint_SetHWM_done(struct tevent_req *subreq)
 {
        struct tevent_req *req = tevent_req_callback_data(
                subreq, struct tevent_req);
-       struct rpccli_wbint_LookupRids_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupRids_state);
+       struct rpccli_wbint_SetHWM_state *state = tevent_req_data(
+               req, struct rpccli_wbint_SetHWM_state);
        NTSTATUS status;
        TALLOC_CTX *mem_ctx;
 
@@ -2380,7 +3468,6 @@ static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq)
        }
 
        /* Copy out parameters */
-       *state->orig.out.names = *state->tmp.out.names;
 
        /* Copy result */
        state->orig.out.result = state->tmp.out.result;
@@ -2389,18 +3476,18 @@ static void rpccli_wbint_LookupRids_done(struct tevent_req *subreq)
        ZERO_STRUCT(state->tmp);
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupRids, &state->orig);
+               NDR_PRINT_OUT_DEBUG(wbint_SetHWM, &state->orig);
        }
 
        tevent_req_done(req);
 }
 
-NTSTATUS rpccli_wbint_LookupRids_recv(struct tevent_req *req,
-                                     TALLOC_CTX *mem_ctx,
-                                     NTSTATUS *result)
+NTSTATUS rpccli_wbint_SetHWM_recv(struct tevent_req *req,
+                                 TALLOC_CTX *mem_ctx,
+                                 NTSTATUS *result)
 {
-       struct rpccli_wbint_LookupRids_state *state = tevent_req_data(
-               req, struct rpccli_wbint_LookupRids_state);
+       struct rpccli_wbint_SetHWM_state *state = tevent_req_data(
+               req, struct rpccli_wbint_SetHWM_state);
        NTSTATUS status;
 
        if (tevent_req_is_nterror(req, &status)) {
@@ -2418,25 +3505,26 @@ NTSTATUS rpccli_wbint_LookupRids_recv(struct tevent_req *req,
        return NT_STATUS_OK;
 }
 
-NTSTATUS rpccli_wbint_LookupRids(struct rpc_pipe_client *cli,
-                                TALLOC_CTX *mem_ctx,
-                                struct wbint_RidArray *rids /* [in] [ref] */,
-                                struct wbint_Principals *names /* [out] [ref] */)
+NTSTATUS rpccli_wbint_SetHWM(struct rpc_pipe_client *cli,
+                            TALLOC_CTX *mem_ctx,
+                            enum wbint_IdType type /* [in]  */,
+                            uint64_t id /* [in]  */)
 {
-       struct wbint_LookupRids r;
+       struct wbint_SetHWM r;
        NTSTATUS status;
 
        /* In parameters */
-       r.in.rids = rids;
+       r.in.type = type;
+       r.in.id = id;
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_IN_DEBUG(wbint_LookupRids, &r);
+               NDR_PRINT_IN_DEBUG(wbint_SetHWM, &r);
        }
 
        status = cli->dispatch(cli,
                                mem_ctx,
                                &ndr_table_wbint,
-                               NDR_WBINT_LOOKUPRIDS,
+                               NDR_WBINT_SETHWM,
                                &r);
 
        if (!NT_STATUS_IS_OK(status)) {
@@ -2444,7 +3532,7 @@ NTSTATUS rpccli_wbint_LookupRids(struct rpc_pipe_client *cli,
        }
 
        if (DEBUGLEVEL >= 10) {
-               NDR_PRINT_OUT_DEBUG(wbint_LookupRids, &r);
+               NDR_PRINT_OUT_DEBUG(wbint_SetHWM, &r);
        }
 
        if (NT_STATUS_IS_ERR(status)) {
@@ -2452,7 +3540,6 @@ NTSTATUS rpccli_wbint_LookupRids(struct rpc_pipe_client *cli,
        }
 
        /* Return variables */
-       *names = *r.out.names;
 
        /* Return result */
        return r.out.result;