summaryrefslogtreecommitdiff
path: root/source/librpc/gen_ndr/srv_netlogon.c
diff options
context:
space:
mode:
Diffstat (limited to 'source/librpc/gen_ndr/srv_netlogon.c')
-rw-r--r--source/librpc/gen_ndr/srv_netlogon.c3340
1 files changed, 0 insertions, 3340 deletions
diff --git a/source/librpc/gen_ndr/srv_netlogon.c b/source/librpc/gen_ndr/srv_netlogon.c
deleted file mode 100644
index 9b87c618533..00000000000
--- a/source/librpc/gen_ndr/srv_netlogon.c
+++ /dev/null
@@ -1,3340 +0,0 @@
-/*
- * Unix SMB/CIFS implementation.
- * server auto-generated by pidl. DO NOT MODIFY!
- */
-
-#include "includes.h"
-#include "librpc/gen_ndr/srv_netlogon.h"
-
-static BOOL api_netr_LogonUasLogon(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonUasLogon r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonUasLogon");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonUasLogon(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonUasLogon, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, struct netr_UasInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonUasLogon(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonUasLogon, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonUasLogon(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonUasLogoff(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonUasLogoff r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonUasLogoff");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonUasLogoff(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonUasLogoff, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, struct netr_UasLogoffInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonUasLogoff(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonUasLogoff, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonUasLogoff(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonSamLogon(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonSamLogon r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonSamLogon");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonSamLogon(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonSamLogon, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.validation = talloc_zero(mem_ctx, union netr_Validation);
- if (r.out.validation == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.authoritative = talloc_zero(mem_ctx, uint8_t);
- if (r.out.authoritative == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonSamLogon(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonSamLogon, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonSamLogon(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonSamLogoff(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonSamLogoff r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonSamLogoff");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonSamLogoff(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonSamLogoff, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.result = _netr_LogonSamLogoff(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonSamLogoff, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonSamLogoff(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerReqChallenge(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerReqChallenge r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerReqChallenge");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerReqChallenge(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerReqChallenge, &r);
-
- ZERO_STRUCT(r.out);
- r.out.credentials = r.in.credentials;
- r.out.result = _netr_ServerReqChallenge(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerReqChallenge, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerReqChallenge(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerAuthenticate(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerAuthenticate r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerAuthenticate");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerAuthenticate(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerAuthenticate, &r);
-
- ZERO_STRUCT(r.out);
- r.out.credentials = r.in.credentials;
- r.out.result = _netr_ServerAuthenticate(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerAuthenticate, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerAuthenticate(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerPasswordSet(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerPasswordSet r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerPasswordSet");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerPasswordSet(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerPasswordSet, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = talloc_zero(mem_ctx, struct netr_Authenticator);
- if (r.out.return_authenticator == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_ServerPasswordSet(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerPasswordSet, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerPasswordSet(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DatabaseDeltas(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DatabaseDeltas r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DatabaseDeltas");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DatabaseDeltas(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DatabaseDeltas, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.sequence_num = r.in.sequence_num;
- r.out.delta_enum_array = talloc_zero(mem_ctx, struct netr_DELTA_ENUM_ARRAY);
- if (r.out.delta_enum_array == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DatabaseDeltas(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DatabaseDeltas, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DatabaseDeltas(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DatabaseSync(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DatabaseSync r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DatabaseSync");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DatabaseSync(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DatabaseSync, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.sync_context = r.in.sync_context;
- r.out.delta_enum_array = talloc_zero(mem_ctx, struct netr_DELTA_ENUM_ARRAY);
- if (r.out.delta_enum_array == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DatabaseSync(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DatabaseSync, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DatabaseSync(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_AccountDeltas(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_AccountDeltas r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_AccountDeltas");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_AccountDeltas(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_AccountDeltas, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.buffer = talloc_zero(mem_ctx, struct netr_AccountBuffer);
- if (r.out.buffer == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.count_returned = talloc_zero(mem_ctx, uint32_t);
- if (r.out.count_returned == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.total_entries = talloc_zero(mem_ctx, uint32_t);
- if (r.out.total_entries == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.recordid = talloc_zero(mem_ctx, struct netr_UAS_INFO_0);
- if (r.out.recordid == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_AccountDeltas(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_AccountDeltas, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_AccountDeltas(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_AccountSync(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_AccountSync r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_AccountSync");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_AccountSync(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_AccountSync, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.buffer = talloc_zero(mem_ctx, struct netr_AccountBuffer);
- if (r.out.buffer == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.count_returned = talloc_zero(mem_ctx, uint32_t);
- if (r.out.count_returned == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.total_entries = talloc_zero(mem_ctx, uint32_t);
- if (r.out.total_entries == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.next_reference = talloc_zero(mem_ctx, uint32_t);
- if (r.out.next_reference == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.recordid = r.in.recordid;
- r.out.result = _netr_AccountSync(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_AccountSync, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_AccountSync(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_GetDcName(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_GetDcName r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_GetDcName");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_GetDcName(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_GetDcName, &r);
-
- ZERO_STRUCT(r.out);
- r.out.dcname = talloc_zero(mem_ctx, const char *);
- if (r.out.dcname == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_GetDcName(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_GetDcName, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_GetDcName(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonControl(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonControl r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonControl");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonControl(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonControl, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, union netr_CONTROL_QUERY_INFORMATION);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonControl(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonControl, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonControl(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_GetAnyDCName(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_GetAnyDCName r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_GetAnyDCName");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_GetAnyDCName(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_GetAnyDCName, &r);
-
- ZERO_STRUCT(r.out);
- r.out.dcname = talloc_zero(mem_ctx, const char *);
- if (r.out.dcname == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_GetAnyDCName(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_GetAnyDCName, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_GetAnyDCName(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonControl2(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonControl2 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonControl2");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonControl2(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonControl2, &r);
-
- ZERO_STRUCT(r.out);
- r.out.query = talloc_zero(mem_ctx, union netr_CONTROL_QUERY_INFORMATION);
- if (r.out.query == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonControl2(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonControl2, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonControl2(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerAuthenticate2(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerAuthenticate2 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerAuthenticate2");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerAuthenticate2(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerAuthenticate2, &r);
-
- ZERO_STRUCT(r.out);
- r.out.credentials = r.in.credentials;
- r.out.negotiate_flags = r.in.negotiate_flags;
- r.out.result = _netr_ServerAuthenticate2(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerAuthenticate2, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerAuthenticate2(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DatabaseSync2(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DatabaseSync2 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DatabaseSync2");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DatabaseSync2(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DatabaseSync2, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.sync_context = r.in.sync_context;
- r.out.delta_enum_array = talloc_zero(mem_ctx, struct netr_DELTA_ENUM_ARRAY);
- if (r.out.delta_enum_array == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DatabaseSync2(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DatabaseSync2, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DatabaseSync2(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DatabaseRedo(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DatabaseRedo r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DatabaseRedo");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DatabaseRedo(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DatabaseRedo, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.delta_enum_array = talloc_zero(mem_ctx, struct netr_DELTA_ENUM_ARRAY);
- if (r.out.delta_enum_array == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DatabaseRedo(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DatabaseRedo, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DatabaseRedo(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonControl2Ex(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonControl2Ex r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonControl2Ex");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonControl2Ex(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonControl2Ex, &r);
-
- ZERO_STRUCT(r.out);
- r.out.query = talloc_zero(mem_ctx, union netr_CONTROL_QUERY_INFORMATION);
- if (r.out.query == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonControl2Ex(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonControl2Ex, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonControl2Ex(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRENUMERATETRUSTEDDOMAINS(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRENUMERATETRUSTEDDOMAINS r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRENUMERATETRUSTEDDOMAINS");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRENUMERATETRUSTEDDOMAINS(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRENUMERATETRUSTEDDOMAINS, &r);
-
- r.out.result = _netr_NETRENUMERATETRUSTEDDOMAINS(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRENUMERATETRUSTEDDOMAINS, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRENUMERATETRUSTEDDOMAINS(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DsRGetDCName(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DsRGetDCName r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DsRGetDCName");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DsRGetDCName(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DsRGetDCName, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, struct netr_DsRGetDCNameInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DsRGetDCName(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DsRGetDCName, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DsRGetDCName(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONDUMMYROUTINE1(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONDUMMYROUTINE1 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONDUMMYROUTINE1");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONDUMMYROUTINE1(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONDUMMYROUTINE1, &r);
-
- r.out.result = _netr_NETRLOGONDUMMYROUTINE1(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONDUMMYROUTINE1, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONDUMMYROUTINE1(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONSETSERVICEBITS(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONSETSERVICEBITS r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONSETSERVICEBITS");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONSETSERVICEBITS(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONSETSERVICEBITS, &r);
-
- r.out.result = _netr_NETRLOGONSETSERVICEBITS(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONSETSERVICEBITS, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONSETSERVICEBITS(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONGETTRUSTRID(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONGETTRUSTRID r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONGETTRUSTRID");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONGETTRUSTRID(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONGETTRUSTRID, &r);
-
- r.out.result = _netr_NETRLOGONGETTRUSTRID(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONGETTRUSTRID, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONGETTRUSTRID(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONCOMPUTESERVERDIGEST(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONCOMPUTESERVERDIGEST r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONCOMPUTESERVERDIGEST");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONCOMPUTESERVERDIGEST(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONCOMPUTESERVERDIGEST, &r);
-
- r.out.result = _netr_NETRLOGONCOMPUTESERVERDIGEST(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONCOMPUTESERVERDIGEST, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONCOMPUTESERVERDIGEST(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONCOMPUTECLIENTDIGEST(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONCOMPUTECLIENTDIGEST r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONCOMPUTECLIENTDIGEST");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONCOMPUTECLIENTDIGEST(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONCOMPUTECLIENTDIGEST, &r);
-
- r.out.result = _netr_NETRLOGONCOMPUTECLIENTDIGEST(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONCOMPUTECLIENTDIGEST, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONCOMPUTECLIENTDIGEST(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerAuthenticate3(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerAuthenticate3 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerAuthenticate3");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerAuthenticate3(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerAuthenticate3, &r);
-
- ZERO_STRUCT(r.out);
- r.out.credentials = r.in.credentials;
- r.out.negotiate_flags = r.in.negotiate_flags;
- r.out.rid = talloc_zero(mem_ctx, uint32_t);
- if (r.out.rid == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_ServerAuthenticate3(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerAuthenticate3, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerAuthenticate3(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DsRGetDCNameEx(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DsRGetDCNameEx r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DsRGetDCNameEx");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DsRGetDCNameEx(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DsRGetDCNameEx, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, struct netr_DsRGetDCNameInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DsRGetDCNameEx(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DsRGetDCNameEx, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DsRGetDCNameEx(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DsRGetSiteName(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DsRGetSiteName r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DsRGetSiteName");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DsRGetSiteName(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DsRGetSiteName, &r);
-
- ZERO_STRUCT(r.out);
- r.out.site = talloc_zero(mem_ctx, const char *);
- if (r.out.site == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DsRGetSiteName(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DsRGetSiteName, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DsRGetSiteName(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonGetDomainInfo(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonGetDomainInfo r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonGetDomainInfo");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonGetDomainInfo(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonGetDomainInfo, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.info = talloc_zero(mem_ctx, union netr_DomainInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_LogonGetDomainInfo(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonGetDomainInfo, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonGetDomainInfo(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_ServerPasswordSet2(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_ServerPasswordSet2 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_ServerPasswordSet2");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_ServerPasswordSet2(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_ServerPasswordSet2, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = talloc_zero(mem_ctx, struct netr_Authenticator);
- if (r.out.return_authenticator == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_ServerPasswordSet2(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_ServerPasswordSet2, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_ServerPasswordSet2(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRSERVERPASSWORDGET(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRSERVERPASSWORDGET r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRSERVERPASSWORDGET");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRSERVERPASSWORDGET(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRSERVERPASSWORDGET, &r);
-
- r.out.result = _netr_NETRSERVERPASSWORDGET(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRSERVERPASSWORDGET, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRSERVERPASSWORDGET(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONSENDTOSAM(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONSENDTOSAM r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONSENDTOSAM");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONSENDTOSAM(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONSENDTOSAM, &r);
-
- r.out.result = _netr_NETRLOGONSENDTOSAM(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONSENDTOSAM, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONSENDTOSAM(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DSRADDRESSTOSITENAMESW(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DSRADDRESSTOSITENAMESW r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DSRADDRESSTOSITENAMESW");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DSRADDRESSTOSITENAMESW(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DSRADDRESSTOSITENAMESW, &r);
-
- r.out.result = _netr_DSRADDRESSTOSITENAMESW(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DSRADDRESSTOSITENAMESW, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DSRADDRESSTOSITENAMESW(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DsRGetDCNameEx2(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DsRGetDCNameEx2 r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DsRGetDCNameEx2");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DsRGetDCNameEx2(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DsRGetDCNameEx2, &r);
-
- ZERO_STRUCT(r.out);
- r.out.info = talloc_zero(mem_ctx, struct netr_DsRGetDCNameInfo);
- if (r.out.info == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DsRGetDCNameEx2(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DsRGetDCNameEx2, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DsRGetDCNameEx2(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN, &r);
-
- r.out.result = _netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRENUMERATETRUSTEDDOMAINSEX(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRENUMERATETRUSTEDDOMAINSEX r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRENUMERATETRUSTEDDOMAINSEX");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRENUMERATETRUSTEDDOMAINSEX(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRENUMERATETRUSTEDDOMAINSEX, &r);
-
- r.out.result = _netr_NETRENUMERATETRUSTEDDOMAINSEX(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRENUMERATETRUSTEDDOMAINSEX, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRENUMERATETRUSTEDDOMAINSEX(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DSRADDRESSTOSITENAMESEXW(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DSRADDRESSTOSITENAMESEXW r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DSRADDRESSTOSITENAMESEXW");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DSRADDRESSTOSITENAMESEXW(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DSRADDRESSTOSITENAMESEXW, &r);
-
- r.out.result = _netr_DSRADDRESSTOSITENAMESEXW(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DSRADDRESSTOSITENAMESEXW, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DSRADDRESSTOSITENAMESEXW(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DSRGETDCSITECOVERAGEW(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DSRGETDCSITECOVERAGEW r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DSRGETDCSITECOVERAGEW");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DSRGETDCSITECOVERAGEW(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DSRGETDCSITECOVERAGEW, &r);
-
- r.out.result = _netr_DSRGETDCSITECOVERAGEW(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DSRGETDCSITECOVERAGEW, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DSRGETDCSITECOVERAGEW(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonSamLogonEx(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonSamLogonEx r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonSamLogonEx");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonSamLogonEx(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonSamLogonEx, &r);
-
- ZERO_STRUCT(r.out);
- r.out.validation = talloc_zero(mem_ctx, union netr_Validation);
- if (r.out.validation == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.authoritative = talloc_zero(mem_ctx, uint8_t);
- if (r.out.authoritative == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.flags = r.in.flags;
- r.out.result = _netr_LogonSamLogonEx(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonSamLogonEx, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonSamLogonEx(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DsrEnumerateDomainTrusts(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DsrEnumerateDomainTrusts r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DsrEnumerateDomainTrusts");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DsrEnumerateDomainTrusts(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DsrEnumerateDomainTrusts, &r);
-
- ZERO_STRUCT(r.out);
- r.out.count = talloc_zero(mem_ctx, uint32_t);
- if (r.out.count == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.trusts = talloc_zero_array(mem_ctx, struct netr_DomainTrust *, count);
- if (r.out.trusts == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.result = _netr_DsrEnumerateDomainTrusts(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DsrEnumerateDomainTrusts, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DsrEnumerateDomainTrusts(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DSRDEREGISTERDNSHOSTRECORDS(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DSRDEREGISTERDNSHOSTRECORDS r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DSRDEREGISTERDNSHOSTRECORDS");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DSRDEREGISTERDNSHOSTRECORDS(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DSRDEREGISTERDNSHOSTRECORDS, &r);
-
- r.out.result = _netr_DSRDEREGISTERDNSHOSTRECORDS(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DSRDEREGISTERDNSHOSTRECORDS, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DSRDEREGISTERDNSHOSTRECORDS(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRSERVERTRUSTPASSWORDSGET(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRSERVERTRUSTPASSWORDSGET r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRSERVERTRUSTPASSWORDSGET");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRSERVERTRUSTPASSWORDSGET(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRSERVERTRUSTPASSWORDSGET, &r);
-
- r.out.result = _netr_NETRSERVERTRUSTPASSWORDSGET(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRSERVERTRUSTPASSWORDSGET, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRSERVERTRUSTPASSWORDSGET(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_DSRGETFORESTTRUSTINFORMATION(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_DSRGETFORESTTRUSTINFORMATION r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_DSRGETFORESTTRUSTINFORMATION");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_DSRGETFORESTTRUSTINFORMATION(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_DSRGETFORESTTRUSTINFORMATION, &r);
-
- r.out.result = _netr_DSRGETFORESTTRUSTINFORMATION(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_DSRGETFORESTTRUSTINFORMATION, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_DSRGETFORESTTRUSTINFORMATION(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRGETFORESTTRUSTINFORMATION(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRGETFORESTTRUSTINFORMATION r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRGETFORESTTRUSTINFORMATION");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRGETFORESTTRUSTINFORMATION(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRGETFORESTTRUSTINFORMATION, &r);
-
- r.out.result = _netr_NETRGETFORESTTRUSTINFORMATION(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRGETFORESTTRUSTINFORMATION, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRGETFORESTTRUSTINFORMATION(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_LogonSamLogonWithFlags(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_LogonSamLogonWithFlags r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_LogonSamLogonWithFlags");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_LogonSamLogonWithFlags(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_LogonSamLogonWithFlags, &r);
-
- ZERO_STRUCT(r.out);
- r.out.return_authenticator = r.in.return_authenticator;
- r.out.validation = talloc_zero(mem_ctx, union netr_Validation);
- if (r.out.validation == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.authoritative = talloc_zero(mem_ctx, uint8_t);
- if (r.out.authoritative == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- r.out.flags = r.in.flags;
- r.out.result = _netr_LogonSamLogonWithFlags(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_LogonSamLogonWithFlags, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_LogonSamLogonWithFlags(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-static BOOL api_netr_NETRSERVERGETTRUSTINFO(pipes_struct *p)
-{
- struct ndr_pull *pull;
- struct ndr_push *push;
- NTSTATUS status;
- DATA_BLOB blob;
- struct netr_NETRSERVERGETTRUSTINFO r;
- TALLOC_CTX *mem_ctx = talloc_init("api_netr_NETRSERVERGETTRUSTINFO");
-
- if (!prs_data_blob(&p->in_data.data, &blob, mem_ctx)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- status = ndr_pull_netr_NETRSERVERGETTRUSTINFO(pull, NDR_IN, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_IN_DEBUG(netr_NETRSERVERGETTRUSTINFO, &r);
-
- r.out.result = _netr_NETRSERVERGETTRUSTINFO(p, &r);
-
- if (p->rng_fault_state) {
- talloc_free(mem_ctx);
- /* Return True here, srv_pipe_hnd.c will take care */
- return True;
- }
-
- if (DEBUGLEVEL >= 10)
- NDR_PRINT_OUT_DEBUG(netr_NETRSERVERGETTRUSTINFO, &r);
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- talloc_free(mem_ctx);
- return False;
- }
-
- status = ndr_push_netr_NETRSERVERGETTRUSTINFO(push, NDR_OUT, &r);
- if (NT_STATUS_IS_ERR(status)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- blob = ndr_push_blob(push);
- if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
- talloc_free(mem_ctx);
- return False;
- }
-
- talloc_free(mem_ctx);
-
- return True;
-}
-
-
-/* Tables */
-static struct api_struct api_netlogon_cmds[] =
-{
- {"NETR_LOGONUASLOGON", DCERPC_NETR_LOGONUASLOGON, api_netr_LogonUasLogon},
- {"NETR_LOGONUASLOGOFF", DCERPC_NETR_LOGONUASLOGOFF, api_netr_LogonUasLogoff},
- {"NETR_LOGONSAMLOGON", DCERPC_NETR_LOGONSAMLOGON, api_netr_LogonSamLogon},
- {"NETR_LOGONSAMLOGOFF", DCERPC_NETR_LOGONSAMLOGOFF, api_netr_LogonSamLogoff},
- {"NETR_SERVERREQCHALLENGE", DCERPC_NETR_SERVERREQCHALLENGE, api_netr_ServerReqChallenge},
- {"NETR_SERVERAUTHENTICATE", DCERPC_NETR_SERVERAUTHENTICATE, api_netr_ServerAuthenticate},
- {"NETR_SERVERPASSWORDSET", DCERPC_NETR_SERVERPASSWORDSET, api_netr_ServerPasswordSet},
- {"NETR_DATABASEDELTAS", DCERPC_NETR_DATABASEDELTAS, api_netr_DatabaseDeltas},
- {"NETR_DATABASESYNC", DCERPC_NETR_DATABASESYNC, api_netr_DatabaseSync},
- {"NETR_ACCOUNTDELTAS", DCERPC_NETR_ACCOUNTDELTAS, api_netr_AccountDeltas},
- {"NETR_ACCOUNTSYNC", DCERPC_NETR_ACCOUNTSYNC, api_netr_AccountSync},
- {"NETR_GETDCNAME", DCERPC_NETR_GETDCNAME, api_netr_GetDcName},
- {"NETR_LOGONCONTROL", DCERPC_NETR_LOGONCONTROL, api_netr_LogonControl},
- {"NETR_GETANYDCNAME", DCERPC_NETR_GETANYDCNAME, api_netr_GetAnyDCName},
- {"NETR_LOGONCONTROL2", DCERPC_NETR_LOGONCONTROL2, api_netr_LogonControl2},
- {"NETR_SERVERAUTHENTICATE2", DCERPC_NETR_SERVERAUTHENTICATE2, api_netr_ServerAuthenticate2},
- {"NETR_DATABASESYNC2", DCERPC_NETR_DATABASESYNC2, api_netr_DatabaseSync2},
- {"NETR_DATABASEREDO", DCERPC_NETR_DATABASEREDO, api_netr_DatabaseRedo},
- {"NETR_LOGONCONTROL2EX", DCERPC_NETR_LOGONCONTROL2EX, api_netr_LogonControl2Ex},
- {"NETR_NETRENUMERATETRUSTEDDOMAINS", DCERPC_NETR_NETRENUMERATETRUSTEDDOMAINS, api_netr_NETRENUMERATETRUSTEDDOMAINS},
- {"NETR_DSRGETDCNAME", DCERPC_NETR_DSRGETDCNAME, api_netr_DsRGetDCName},
- {"NETR_NETRLOGONDUMMYROUTINE1", DCERPC_NETR_NETRLOGONDUMMYROUTINE1, api_netr_NETRLOGONDUMMYROUTINE1},
- {"NETR_NETRLOGONSETSERVICEBITS", DCERPC_NETR_NETRLOGONSETSERVICEBITS, api_netr_NETRLOGONSETSERVICEBITS},
- {"NETR_NETRLOGONGETTRUSTRID", DCERPC_NETR_NETRLOGONGETTRUSTRID, api_netr_NETRLOGONGETTRUSTRID},
- {"NETR_NETRLOGONCOMPUTESERVERDIGEST", DCERPC_NETR_NETRLOGONCOMPUTESERVERDIGEST, api_netr_NETRLOGONCOMPUTESERVERDIGEST},
- {"NETR_NETRLOGONCOMPUTECLIENTDIGEST", DCERPC_NETR_NETRLOGONCOMPUTECLIENTDIGEST, api_netr_NETRLOGONCOMPUTECLIENTDIGEST},
- {"NETR_SERVERAUTHENTICATE3", DCERPC_NETR_SERVERAUTHENTICATE3, api_netr_ServerAuthenticate3},
- {"NETR_DSRGETDCNAMEEX", DCERPC_NETR_DSRGETDCNAMEEX, api_netr_DsRGetDCNameEx},
- {"NETR_DSRGETSITENAME", DCERPC_NETR_DSRGETSITENAME, api_netr_DsRGetSiteName},
- {"NETR_LOGONGETDOMAININFO", DCERPC_NETR_LOGONGETDOMAININFO, api_netr_LogonGetDomainInfo},
- {"NETR_SERVERPASSWORDSET2", DCERPC_NETR_SERVERPASSWORDSET2, api_netr_ServerPasswordSet2},
- {"NETR_NETRSERVERPASSWORDGET", DCERPC_NETR_NETRSERVERPASSWORDGET, api_netr_NETRSERVERPASSWORDGET},
- {"NETR_NETRLOGONSENDTOSAM", DCERPC_NETR_NETRLOGONSENDTOSAM, api_netr_NETRLOGONSENDTOSAM},
- {"NETR_DSRADDRESSTOSITENAMESW", DCERPC_NETR_DSRADDRESSTOSITENAMESW, api_netr_DSRADDRESSTOSITENAMESW},
- {"NETR_DSRGETDCNAMEEX2", DCERPC_NETR_DSRGETDCNAMEEX2, api_netr_DsRGetDCNameEx2},
- {"NETR_NETRLOGONGETTIMESERVICEPARENTDOMAIN", DCERPC_NETR_NETRLOGONGETTIMESERVICEPARENTDOMAIN, api_netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN},
- {"NETR_NETRENUMERATETRUSTEDDOMAINSEX", DCERPC_NETR_NETRENUMERATETRUSTEDDOMAINSEX, api_netr_NETRENUMERATETRUSTEDDOMAINSEX},
- {"NETR_DSRADDRESSTOSITENAMESEXW", DCERPC_NETR_DSRADDRESSTOSITENAMESEXW, api_netr_DSRADDRESSTOSITENAMESEXW},
- {"NETR_DSRGETDCSITECOVERAGEW", DCERPC_NETR_DSRGETDCSITECOVERAGEW, api_netr_DSRGETDCSITECOVERAGEW},
- {"NETR_LOGONSAMLOGONEX", DCERPC_NETR_LOGONSAMLOGONEX, api_netr_LogonSamLogonEx},
- {"NETR_DSRENUMERATEDOMAINTRUSTS", DCERPC_NETR_DSRENUMERATEDOMAINTRUSTS, api_netr_DsrEnumerateDomainTrusts},
- {"NETR_DSRDEREGISTERDNSHOSTRECORDS", DCERPC_NETR_DSRDEREGISTERDNSHOSTRECORDS, api_netr_DSRDEREGISTERDNSHOSTRECORDS},
- {"NETR_NETRSERVERTRUSTPASSWORDSGET", DCERPC_NETR_NETRSERVERTRUSTPASSWORDSGET, api_netr_NETRSERVERTRUSTPASSWORDSGET},
- {"NETR_DSRGETFORESTTRUSTINFORMATION", DCERPC_NETR_DSRGETFORESTTRUSTINFORMATION, api_netr_DSRGETFORESTTRUSTINFORMATION},
- {"NETR_NETRGETFORESTTRUSTINFORMATION", DCERPC_NETR_NETRGETFORESTTRUSTINFORMATION, api_netr_NETRGETFORESTTRUSTINFORMATION},
- {"NETR_LOGONSAMLOGONWITHFLAGS", DCERPC_NETR_LOGONSAMLOGONWITHFLAGS, api_netr_LogonSamLogonWithFlags},
- {"NETR_NETRSERVERGETTRUSTINFO", DCERPC_NETR_NETRSERVERGETTRUSTINFO, api_netr_NETRSERVERGETTRUSTINFO},
-};
-
-void netlogon_get_pipe_fns(struct api_struct **fns, int *n_fns)
-{
- *fns = api_netlogon_cmds;
- *n_fns = sizeof(api_netlogon_cmds) / sizeof(struct api_struct);
-}
-
-NTSTATUS rpc_netlogon_init(void)
-{
- return rpc_pipe_register_commands(SMB_RPC_INTERFACE_VERSION, "netlogon", "netlogon", api_netlogon_cmds, sizeof(api_netlogon_cmds) / sizeof(struct api_struct));
-}