mirror of
https://github.com/samba-team/samba.git
synced 2024-12-28 07:21:54 +03:00
e181b88978
This reverts commit daa964013b
.
1176 lines
28 KiB
C
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;
|
|
}
|
|
|