1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-28 07:21:54 +03:00
samba-mirror/librpc/gen_ndr/cli_epmapper.c
2009-11-08 19:43:47 +01:00

1176 lines
28 KiB
C

/*
* Unix SMB/CIFS implementation.
* client auto-generated by pidl. DO NOT MODIFY!
*/
#include "includes.h"
#include "../librpc/gen_ndr/cli_epmapper.h"
struct rpccli_epm_Insert_state {
struct epm_Insert orig;
struct epm_Insert tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_Insert_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_Insert_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
uint32_t _num_ents /* [in] */,
struct epm_entry_t *_entries /* [in] [size_is(num_ents)] */,
uint32_t _replace /* [in] */)
{
struct tevent_req *req;
struct rpccli_epm_Insert_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_Insert_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.num_ents = _num_ents;
state->orig.in.entries = _entries;
state->orig.in.replace = _replace;
/* Out parameters */
/* Result */
ZERO_STRUCT(state->orig.out.result);
/* make a temporary copy, that we pass to the dispatch function */
state->tmp = state->orig;
subreq = cli->dispatch_send(state, ev, cli,
&ndr_table_epmapper,
NDR_EPM_INSERT,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_Insert_done, req);
return req;
}
static void rpccli_epm_Insert_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_Insert_state *state = tevent_req_data(
req, struct rpccli_epm_Insert_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 */
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_Insert_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_Insert_state *state = tevent_req_data(
req, struct rpccli_epm_Insert_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_epm_Insert(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
uint32_t num_ents /* [in] */,
struct epm_entry_t *entries /* [in] [size_is(num_ents)] */,
uint32_t replace /* [in] */)
{
struct epm_Insert r;
NTSTATUS status;
/* In parameters */
r.in.num_ents = num_ents;
r.in.entries = entries;
r.in.replace = replace;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_INSERT,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_Delete_state {
struct epm_Delete orig;
struct epm_Delete tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_Delete_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_Delete_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
uint32_t _num_ents /* [in] */,
struct epm_entry_t *_entries /* [in] [size_is(num_ents)] */)
{
struct tevent_req *req;
struct rpccli_epm_Delete_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_Delete_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.num_ents = _num_ents;
state->orig.in.entries = _entries;
/* Out parameters */
/* Result */
ZERO_STRUCT(state->orig.out.result);
/* make a temporary copy, that we pass to the dispatch function */
state->tmp = state->orig;
subreq = cli->dispatch_send(state, ev, cli,
&ndr_table_epmapper,
NDR_EPM_DELETE,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_Delete_done, req);
return req;
}
static void rpccli_epm_Delete_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_Delete_state *state = tevent_req_data(
req, struct rpccli_epm_Delete_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 */
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_Delete_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_Delete_state *state = tevent_req_data(
req, struct rpccli_epm_Delete_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_epm_Delete(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
uint32_t num_ents /* [in] */,
struct epm_entry_t *entries /* [in] [size_is(num_ents)] */)
{
struct epm_Delete r;
NTSTATUS status;
/* In parameters */
r.in.num_ents = num_ents;
r.in.entries = entries;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_DELETE,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_Lookup_state {
struct epm_Lookup orig;
struct epm_Lookup tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_Lookup_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_Lookup_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
uint32_t _inquiry_type /* [in] */,
struct GUID *_object /* [in] [ptr] */,
struct rpc_if_id_t *_interface_id /* [in] [ptr] */,
uint32_t _vers_option /* [in] */,
struct policy_handle *_entry_handle /* [in,out] [ref] */,
uint32_t _max_ents /* [in] */,
uint32_t *_num_ents /* [out] [ref] */,
struct epm_entry_t *_entries /* [out] [length_is(*num_ents),size_is(max_ents)] */)
{
struct tevent_req *req;
struct rpccli_epm_Lookup_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_Lookup_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.inquiry_type = _inquiry_type;
state->orig.in.object = _object;
state->orig.in.interface_id = _interface_id;
state->orig.in.vers_option = _vers_option;
state->orig.in.entry_handle = _entry_handle;
state->orig.in.max_ents = _max_ents;
/* Out parameters */
state->orig.out.entry_handle = _entry_handle;
state->orig.out.num_ents = _num_ents;
state->orig.out.entries = _entries;
/* Result */
ZERO_STRUCT(state->orig.out.result);
state->out_mem_ctx = talloc_named_const(state, 0,
"rpccli_epm_Lookup_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_epmapper,
NDR_EPM_LOOKUP,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_Lookup_done, req);
return req;
}
static void rpccli_epm_Lookup_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_Lookup_state *state = tevent_req_data(
req, struct rpccli_epm_Lookup_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.entry_handle = *state->tmp.out.entry_handle;
*state->orig.out.num_ents = *state->tmp.out.num_ents;
memcpy(state->orig.out.entries, state->tmp.out.entries, state->tmp.in.max_ents * sizeof(*state->orig.out.entries));
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_Lookup_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_Lookup_state *state = tevent_req_data(
req, struct rpccli_epm_Lookup_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_epm_Lookup(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
uint32_t inquiry_type /* [in] */,
struct GUID *object /* [in] [ptr] */,
struct rpc_if_id_t *interface_id /* [in] [ptr] */,
uint32_t vers_option /* [in] */,
struct policy_handle *entry_handle /* [in,out] [ref] */,
uint32_t max_ents /* [in] */,
uint32_t *num_ents /* [out] [ref] */,
struct epm_entry_t *entries /* [out] [length_is(*num_ents),size_is(max_ents)] */)
{
struct epm_Lookup r;
NTSTATUS status;
/* In parameters */
r.in.inquiry_type = inquiry_type;
r.in.object = object;
r.in.interface_id = interface_id;
r.in.vers_option = vers_option;
r.in.entry_handle = entry_handle;
r.in.max_ents = max_ents;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_LOOKUP,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
*entry_handle = *r.out.entry_handle;
*num_ents = *r.out.num_ents;
memcpy(entries, r.out.entries, r.in.max_ents * sizeof(*entries));
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_Map_state {
struct epm_Map orig;
struct epm_Map tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_Map_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_Map_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
struct GUID *_object /* [in] [ptr] */,
struct epm_twr_t *_map_tower /* [in] [ptr] */,
struct policy_handle *_entry_handle /* [in,out] [ref] */,
uint32_t _max_towers /* [in] */,
uint32_t *_num_towers /* [out] [ref] */,
struct epm_twr_p_t *_towers /* [out] [length_is(*num_towers),size_is(max_towers)] */)
{
struct tevent_req *req;
struct rpccli_epm_Map_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_Map_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.object = _object;
state->orig.in.map_tower = _map_tower;
state->orig.in.entry_handle = _entry_handle;
state->orig.in.max_towers = _max_towers;
/* Out parameters */
state->orig.out.entry_handle = _entry_handle;
state->orig.out.num_towers = _num_towers;
state->orig.out.towers = _towers;
/* Result */
ZERO_STRUCT(state->orig.out.result);
state->out_mem_ctx = talloc_named_const(state, 0,
"rpccli_epm_Map_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_epmapper,
NDR_EPM_MAP,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_Map_done, req);
return req;
}
static void rpccli_epm_Map_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_Map_state *state = tevent_req_data(
req, struct rpccli_epm_Map_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.entry_handle = *state->tmp.out.entry_handle;
*state->orig.out.num_towers = *state->tmp.out.num_towers;
memcpy(state->orig.out.towers, state->tmp.out.towers, state->tmp.in.max_towers * sizeof(*state->orig.out.towers));
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_Map_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_Map_state *state = tevent_req_data(
req, struct rpccli_epm_Map_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_epm_Map(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct GUID *object /* [in] [ptr] */,
struct epm_twr_t *map_tower /* [in] [ptr] */,
struct policy_handle *entry_handle /* [in,out] [ref] */,
uint32_t max_towers /* [in] */,
uint32_t *num_towers /* [out] [ref] */,
struct epm_twr_p_t *towers /* [out] [length_is(*num_towers),size_is(max_towers)] */)
{
struct epm_Map r;
NTSTATUS status;
/* In parameters */
r.in.object = object;
r.in.map_tower = map_tower;
r.in.entry_handle = entry_handle;
r.in.max_towers = max_towers;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_MAP,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
*entry_handle = *r.out.entry_handle;
*num_towers = *r.out.num_towers;
memcpy(towers, r.out.towers, r.in.max_towers * sizeof(*towers));
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_LookupHandleFree_state {
struct epm_LookupHandleFree orig;
struct epm_LookupHandleFree tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_LookupHandleFree_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_LookupHandleFree_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
struct policy_handle *_entry_handle /* [in,out] [ref] */)
{
struct tevent_req *req;
struct rpccli_epm_LookupHandleFree_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_LookupHandleFree_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.entry_handle = _entry_handle;
/* Out parameters */
state->orig.out.entry_handle = _entry_handle;
/* Result */
ZERO_STRUCT(state->orig.out.result);
state->out_mem_ctx = talloc_named_const(state, 0,
"rpccli_epm_LookupHandleFree_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_epmapper,
NDR_EPM_LOOKUPHANDLEFREE,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_LookupHandleFree_done, req);
return req;
}
static void rpccli_epm_LookupHandleFree_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_LookupHandleFree_state *state = tevent_req_data(
req, struct rpccli_epm_LookupHandleFree_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.entry_handle = *state->tmp.out.entry_handle;
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_LookupHandleFree_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_LookupHandleFree_state *state = tevent_req_data(
req, struct rpccli_epm_LookupHandleFree_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_epm_LookupHandleFree(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *entry_handle /* [in,out] [ref] */)
{
struct epm_LookupHandleFree r;
NTSTATUS status;
/* In parameters */
r.in.entry_handle = entry_handle;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_LOOKUPHANDLEFREE,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
*entry_handle = *r.out.entry_handle;
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_InqObject_state {
struct epm_InqObject orig;
struct epm_InqObject tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_InqObject_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_InqObject_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
struct GUID *_epm_object /* [in] [ref] */)
{
struct tevent_req *req;
struct rpccli_epm_InqObject_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_InqObject_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.epm_object = _epm_object;
/* Out parameters */
/* Result */
ZERO_STRUCT(state->orig.out.result);
/* make a temporary copy, that we pass to the dispatch function */
state->tmp = state->orig;
subreq = cli->dispatch_send(state, ev, cli,
&ndr_table_epmapper,
NDR_EPM_INQOBJECT,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_InqObject_done, req);
return req;
}
static void rpccli_epm_InqObject_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_InqObject_state *state = tevent_req_data(
req, struct rpccli_epm_InqObject_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 */
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_InqObject_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_InqObject_state *state = tevent_req_data(
req, struct rpccli_epm_InqObject_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_epm_InqObject(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct GUID *epm_object /* [in] [ref] */)
{
struct epm_InqObject r;
NTSTATUS status;
/* In parameters */
r.in.epm_object = epm_object;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_INQOBJECT,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_MgmtDelete_state {
struct epm_MgmtDelete orig;
struct epm_MgmtDelete tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_MgmtDelete_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_MgmtDelete_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli,
uint32_t _object_speced /* [in] */,
struct GUID *_object /* [in] [ptr] */,
struct epm_twr_t *_tower /* [in] [ptr] */)
{
struct tevent_req *req;
struct rpccli_epm_MgmtDelete_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_MgmtDelete_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
state->orig.in.object_speced = _object_speced;
state->orig.in.object = _object;
state->orig.in.tower = _tower;
/* Out parameters */
/* Result */
ZERO_STRUCT(state->orig.out.result);
/* make a temporary copy, that we pass to the dispatch function */
state->tmp = state->orig;
subreq = cli->dispatch_send(state, ev, cli,
&ndr_table_epmapper,
NDR_EPM_MGMTDELETE,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_MgmtDelete_done, req);
return req;
}
static void rpccli_epm_MgmtDelete_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_MgmtDelete_state *state = tevent_req_data(
req, struct rpccli_epm_MgmtDelete_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 */
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_MgmtDelete_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_MgmtDelete_state *state = tevent_req_data(
req, struct rpccli_epm_MgmtDelete_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_epm_MgmtDelete(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
uint32_t object_speced /* [in] */,
struct GUID *object /* [in] [ptr] */,
struct epm_twr_t *tower /* [in] [ptr] */)
{
struct epm_MgmtDelete r;
NTSTATUS status;
/* In parameters */
r.in.object_speced = object_speced;
r.in.object = object;
r.in.tower = tower;
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_MGMTDELETE,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
/* Return result */
return NT_STATUS_OK;
}
struct rpccli_epm_MapAuth_state {
struct epm_MapAuth orig;
struct epm_MapAuth tmp;
TALLOC_CTX *out_mem_ctx;
NTSTATUS (*dispatch_recv)(struct tevent_req *req, TALLOC_CTX *mem_ctx);
};
static void rpccli_epm_MapAuth_done(struct tevent_req *subreq);
struct tevent_req *rpccli_epm_MapAuth_send(TALLOC_CTX *mem_ctx,
struct tevent_context *ev,
struct rpc_pipe_client *cli)
{
struct tevent_req *req;
struct rpccli_epm_MapAuth_state *state;
struct tevent_req *subreq;
req = tevent_req_create(mem_ctx, &state,
struct rpccli_epm_MapAuth_state);
if (req == NULL) {
return NULL;
}
state->out_mem_ctx = NULL;
state->dispatch_recv = cli->dispatch_recv;
/* In parameters */
/* Out parameters */
/* Result */
ZERO_STRUCT(state->orig.out.result);
/* make a temporary copy, that we pass to the dispatch function */
state->tmp = state->orig;
subreq = cli->dispatch_send(state, ev, cli,
&ndr_table_epmapper,
NDR_EPM_MAPAUTH,
&state->tmp);
if (tevent_req_nomem(subreq, req)) {
return tevent_req_post(req, ev);
}
tevent_req_set_callback(subreq, rpccli_epm_MapAuth_done, req);
return req;
}
static void rpccli_epm_MapAuth_done(struct tevent_req *subreq)
{
struct tevent_req *req = tevent_req_callback_data(
subreq, struct tevent_req);
struct rpccli_epm_MapAuth_state *state = tevent_req_data(
req, struct rpccli_epm_MapAuth_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 */
/* Copy result */
state->orig.out.result = state->tmp.out.result;
/* Reset temporary structure */
ZERO_STRUCT(state->tmp);
tevent_req_done(req);
}
NTSTATUS rpccli_epm_MapAuth_recv(struct tevent_req *req,
TALLOC_CTX *mem_ctx,
uint32 *result)
{
struct rpccli_epm_MapAuth_state *state = tevent_req_data(
req, struct rpccli_epm_MapAuth_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_epm_MapAuth(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx)
{
struct epm_MapAuth r;
NTSTATUS status;
/* In parameters */
status = cli->dispatch(cli,
mem_ctx,
&ndr_table_epmapper,
NDR_EPM_MAPAUTH,
&r);
if (!NT_STATUS_IS_OK(status)) {
return status;
}
if (NT_STATUS_IS_ERR(status)) {
return status;
}
/* Return variables */
/* Return result */
return NT_STATUS_OK;
}