LCOV - code coverage report
Current view: top level - bin/default/librpc/gen_ndr - ndr_mgmt_s.c (source / functions) Hit Total Coverage
Test: coverage report for v4-17-test 1498b464 Lines: 87 157 55.4 %
Date: 2024-06-13 04:01:37 Functions: 6 11 54.5 %

          Line data    Source code
       1             : /* server functions auto-generated by pidl */
       2             : #include "bin/default/librpc/gen_ndr/ndr_mgmt.h"
       3             : #include <util/debug.h>
       4             : 
       5             : NTSTATUS dcerpc_server_mgmt_init(TALLOC_CTX *);
       6             : 
       7             : /* mgmt - dcerpc server boilerplate generated by pidl */
       8             : 
       9             : 
      10         542 : static NTSTATUS mgmt__op_bind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
      11             : {
      12             : #ifdef DCESRV_INTERFACE_MGMT_BIND
      13         542 :         return DCESRV_INTERFACE_MGMT_BIND(context,iface);
      14             : #else
      15             :         return NT_STATUS_OK;
      16             : #endif
      17             : }
      18             : 
      19         542 : static void mgmt__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
      20             : {
      21             : #ifdef DCESRV_INTERFACE_MGMT_UNBIND
      22             :         DCESRV_INTERFACE_MGMT_UNBIND(context, iface);
      23             : #else
      24         542 :         return;
      25             : #endif
      26             : }
      27             : 
      28       14518 : static NTSTATUS mgmt__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
      29             : {
      30             :         enum ndr_err_code ndr_err;
      31       14518 :         uint16_t opnum = dce_call->pkt.u.request.opnum;
      32             : 
      33       14518 :         dce_call->fault_code = 0;
      34             : 
      35       14518 :         if (opnum >= ndr_table_mgmt.num_calls) {
      36          54 :                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
      37          54 :                 return NT_STATUS_NET_WRITE_FAULT;
      38             :         }
      39             : 
      40       28928 :         *r = talloc_named(mem_ctx,
      41       14464 :                           ndr_table_mgmt.calls[opnum].struct_size,
      42             :                           "struct %s",
      43       14464 :                           ndr_table_mgmt.calls[opnum].name);
      44       14464 :         NT_STATUS_HAVE_NO_MEMORY(*r);
      45             : 
      46             :         /* unravel the NDR for the packet */
      47       14464 :         ndr_err = ndr_table_mgmt.calls[opnum].ndr_pull(pull, NDR_IN, *r);
      48       14464 :         if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
      49           0 :                 dce_call->fault_code = DCERPC_FAULT_NDR;
      50           0 :                 return NT_STATUS_NET_WRITE_FAULT;
      51             :         }
      52             : 
      53       14464 :         return NT_STATUS_OK;
      54             : }
      55             : 
      56       14464 : static NTSTATUS mgmt__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
      57             : {
      58       14464 :         uint16_t opnum = dce_call->pkt.u.request.opnum;
      59             : 
      60       14464 :         switch (opnum) {
      61         376 :         case 0: {
      62         376 :                 struct mgmt_inq_if_ids *r2 = (struct mgmt_inq_if_ids *)r;
      63         376 :                 if (DEBUGLEVEL >= 10) {
      64           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_if_ids, NDR_IN, r2);
      65             :                 }
      66         376 :                 r2->out.result = dcesrv_mgmt_inq_if_ids(dce_call, mem_ctx, r2);
      67         376 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
      68           0 :                         DEBUG(5,("function mgmt_inq_if_ids will reply async\n"));
      69             :                 }
      70         376 :                 break;
      71             :         }
      72          96 :         case 1: {
      73          96 :                 struct mgmt_inq_stats *r2 = (struct mgmt_inq_stats *)r;
      74          96 :                 if (DEBUGLEVEL >= 10) {
      75           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_stats, NDR_IN, r2);
      76             :                 }
      77          96 :                 r2->out.result = dcesrv_mgmt_inq_stats(dce_call, mem_ctx, r2);
      78          96 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
      79           0 :                         DEBUG(5,("function mgmt_inq_stats will reply async\n"));
      80             :                 }
      81          96 :                 break;
      82             :         }
      83          78 :         case 2: {
      84          78 :                 struct mgmt_is_server_listening *r2 = (struct mgmt_is_server_listening *)r;
      85          78 :                 if (DEBUGLEVEL >= 10) {
      86           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_is_server_listening, NDR_IN, r2);
      87             :                 }
      88          78 :                 r2->out.result = dcesrv_mgmt_is_server_listening(dce_call, mem_ctx, r2);
      89          78 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
      90           0 :                         DEBUG(5,("function mgmt_is_server_listening will reply async\n"));
      91             :                 }
      92          78 :                 break;
      93             :         }
      94          90 :         case 3: {
      95          90 :                 struct mgmt_stop_server_listening *r2 = (struct mgmt_stop_server_listening *)r;
      96          90 :                 if (DEBUGLEVEL >= 10) {
      97           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_stop_server_listening, NDR_IN, r2);
      98             :                 }
      99          90 :                 r2->out.result = dcesrv_mgmt_stop_server_listening(dce_call, mem_ctx, r2);
     100          90 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     101           0 :                         DEBUG(5,("function mgmt_stop_server_listening will reply async\n"));
     102             :                 }
     103          90 :                 break;
     104             :         }
     105       13824 :         case 4: {
     106       13824 :                 struct mgmt_inq_princ_name *r2 = (struct mgmt_inq_princ_name *)r;
     107       13824 :                 if (DEBUGLEVEL >= 10) {
     108           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_princ_name, NDR_IN, r2);
     109             :                 }
     110       13824 :                 r2->out.result = dcesrv_mgmt_inq_princ_name(dce_call, mem_ctx, r2);
     111       13824 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     112           0 :                         DEBUG(5,("function mgmt_inq_princ_name will reply async\n"));
     113             :                 }
     114       13824 :                 break;
     115             :         }
     116             : 
     117           0 :         default:
     118           0 :                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
     119           0 :                 break;
     120             :         }
     121             : 
     122       14464 :         if (dce_call->fault_code != 0) {
     123       13824 :                 return NT_STATUS_NET_WRITE_FAULT;
     124             :         }
     125             : 
     126         640 :         return NT_STATUS_OK;
     127             : }
     128             : 
     129         640 : static NTSTATUS mgmt__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
     130             : {
     131         640 :         uint16_t opnum = dce_call->pkt.u.request.opnum;
     132             : 
     133         640 :         switch (opnum) {
     134         376 :         case 0: {
     135         376 :                 struct mgmt_inq_if_ids *r2 = (struct mgmt_inq_if_ids *)r;
     136         376 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     137           0 :                         DEBUG(5,("function mgmt_inq_if_ids replied async\n"));
     138             :                 }
     139         376 :                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
     140           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_if_ids, NDR_OUT | NDR_SET_VALUES, r2);
     141             :                 }
     142         376 :                 if (dce_call->fault_code != 0) {
     143           0 :                         DEBUG(2,("dcerpc_fault %s in mgmt_inq_if_ids\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
     144             :                 }
     145         376 :                 break;
     146             :         }
     147          96 :         case 1: {
     148          96 :                 struct mgmt_inq_stats *r2 = (struct mgmt_inq_stats *)r;
     149          96 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     150           0 :                         DEBUG(5,("function mgmt_inq_stats replied async\n"));
     151             :                 }
     152          96 :                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
     153           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_stats, NDR_OUT | NDR_SET_VALUES, r2);
     154             :                 }
     155          96 :                 if (dce_call->fault_code != 0) {
     156           0 :                         DEBUG(2,("dcerpc_fault %s in mgmt_inq_stats\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
     157             :                 }
     158          96 :                 break;
     159             :         }
     160          78 :         case 2: {
     161          78 :                 struct mgmt_is_server_listening *r2 = (struct mgmt_is_server_listening *)r;
     162          78 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     163           0 :                         DEBUG(5,("function mgmt_is_server_listening replied async\n"));
     164             :                 }
     165          78 :                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
     166           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_is_server_listening, NDR_OUT | NDR_SET_VALUES, r2);
     167             :                 }
     168          78 :                 if (dce_call->fault_code != 0) {
     169           0 :                         DEBUG(2,("dcerpc_fault %s in mgmt_is_server_listening\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
     170             :                 }
     171          78 :                 break;
     172             :         }
     173          90 :         case 3: {
     174          90 :                 struct mgmt_stop_server_listening *r2 = (struct mgmt_stop_server_listening *)r;
     175          90 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     176           0 :                         DEBUG(5,("function mgmt_stop_server_listening replied async\n"));
     177             :                 }
     178          90 :                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
     179           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_stop_server_listening, NDR_OUT | NDR_SET_VALUES, r2);
     180             :                 }
     181          90 :                 if (dce_call->fault_code != 0) {
     182           0 :                         DEBUG(2,("dcerpc_fault %s in mgmt_stop_server_listening\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
     183             :                 }
     184          90 :                 break;
     185             :         }
     186           0 :         case 4: {
     187           0 :                 struct mgmt_inq_princ_name *r2 = (struct mgmt_inq_princ_name *)r;
     188           0 :                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
     189           0 :                         DEBUG(5,("function mgmt_inq_princ_name replied async\n"));
     190             :                 }
     191           0 :                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
     192           0 :                         NDR_PRINT_FUNCTION_DEBUG(mgmt_inq_princ_name, NDR_OUT | NDR_SET_VALUES, r2);
     193             :                 }
     194           0 :                 if (dce_call->fault_code != 0) {
     195           0 :                         DEBUG(2,("dcerpc_fault %s in mgmt_inq_princ_name\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
     196             :                 }
     197           0 :                 break;
     198             :         }
     199             : 
     200           0 :         default:
     201           0 :                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
     202           0 :                 break;
     203             :         }
     204             : 
     205         640 :         if (dce_call->fault_code != 0) {
     206           0 :                 return NT_STATUS_NET_WRITE_FAULT;
     207             :         }
     208             : 
     209         640 :         return NT_STATUS_OK;
     210             : }
     211             : 
     212         640 : static NTSTATUS mgmt__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
     213             : {
     214             :         enum ndr_err_code ndr_err;
     215         640 :         uint16_t opnum = dce_call->pkt.u.request.opnum;
     216             : 
     217         640 :         ndr_err = ndr_table_mgmt.calls[opnum].ndr_push(push, NDR_OUT, r);
     218         640 :         if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
     219           0 :                 dce_call->fault_code = DCERPC_FAULT_NDR;
     220           0 :                 return NT_STATUS_NET_WRITE_FAULT;
     221             :         }
     222             : 
     223         640 :         return NT_STATUS_OK;
     224             : }
     225             : 
     226             : static const struct dcesrv_interface dcesrv_mgmt_interface = {
     227             :         .name               = "mgmt",
     228             :         .syntax_id          = {{0xafa8bd80,0x7d8a,0x11c9,{0xbe,0xf4},{0x08,0x00,0x2b,0x10,0x29,0x89}},1.0},
     229             :         .bind               = mgmt__op_bind,
     230             :         .unbind             = mgmt__op_unbind,
     231             :         .ndr_pull           = mgmt__op_ndr_pull,
     232             :         .dispatch           = mgmt__op_dispatch,
     233             :         .reply              = mgmt__op_reply,
     234             :         .ndr_push           = mgmt__op_ndr_push,
     235             :         .local              = NULL,
     236             : #ifdef DCESRV_INTERFACE_MGMT_FLAGS
     237             :         .flags              = DCESRV_INTERFACE_MGMT_FLAGS
     238             : #else
     239             :         .flags              = 0
     240             : #endif
     241             : };
     242             : 
     243             : 
     244           0 : static NTSTATUS mgmt__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
     245             : {
     246             :         int i;
     247             : #ifdef DCESRV_INTERFACE_MGMT_NCACN_NP_SECONDARY_ENDPOINT
     248             :         const char *ncacn_np_secondary_endpoint =
     249             :                 DCESRV_INTERFACE_MGMT_NCACN_NP_SECONDARY_ENDPOINT;
     250             : #else
     251           0 :         const char *ncacn_np_secondary_endpoint = NULL;
     252             : #endif
     253             : 
     254           0 :         for (i=0;i<ndr_table_mgmt.endpoints->count;i++) {
     255             :                 NTSTATUS ret;
     256           0 :                 const char *name = ndr_table_mgmt.endpoints->names[i];
     257             : 
     258           0 :                 ret = dcesrv_interface_register(dce_ctx,
     259             :                                                 name,
     260             :                                                 ncacn_np_secondary_endpoint,
     261             :                                                 &dcesrv_mgmt_interface,
     262             :                                                 NULL);
     263           0 :                 if (!NT_STATUS_IS_OK(ret)) {
     264           0 :                         DEBUG(1,("mgmt_op_init_server: failed to register endpoint '%s'\n",name));
     265           0 :                         return ret;
     266             :                 }
     267             :         }
     268             : 
     269           0 :         return NT_STATUS_OK;
     270             : }
     271             : 
     272           0 : static NTSTATUS mgmt__op_shutdown_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
     273             : {
     274           0 :         return NT_STATUS_OK;
     275             : }
     276             : 
     277           0 : static bool mgmt__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
     278             : {
     279           0 :         if (dcesrv_mgmt_interface.syntax_id.if_version == if_version &&
     280           0 :                 GUID_equal(&dcesrv_mgmt_interface.syntax_id.uuid, uuid)) {
     281           0 :                 memcpy(iface,&dcesrv_mgmt_interface, sizeof(*iface));
     282           0 :                 return true;
     283             :         }
     284             : 
     285           0 :         return false;
     286             : }
     287             : 
     288           0 : static bool mgmt__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
     289             : {
     290           0 :         if (strcmp(dcesrv_mgmt_interface.name, name)==0) {
     291           0 :                 memcpy(iface, &dcesrv_mgmt_interface, sizeof(*iface));
     292           0 :                 return true;
     293             :         }
     294             : 
     295           0 :         return false;
     296             : }
     297             : 
     298           0 : NTSTATUS dcerpc_server_mgmt_init(TALLOC_CTX *ctx)
     299             : {
     300             :         NTSTATUS ret;
     301             :         static const struct dcesrv_endpoint_server ep_server = {
     302             :             /* fill in our name */
     303             :             .name = "mgmt",
     304             : 
     305             :             /* Initialization flag */
     306             :             .initialized = false,
     307             : 
     308             :             /* fill in all the operations */
     309             : #ifdef DCESRV_INTERFACE_MGMT_INIT_SERVER
     310             :             .init_server = DCESRV_INTERFACE_MGMT_INIT_SERVER,
     311             : #else
     312             :             .init_server = mgmt__op_init_server,
     313             : #endif
     314             : #ifdef DCESRV_INTERFACE_MGMT_SHUTDOWN_SERVER
     315             :             .shutdown_server = DCESRV_INTERFACE_MGMT_SHUTDOWN_SERVER,
     316             : #else
     317             :             .shutdown_server = mgmt__op_shutdown_server,
     318             : #endif
     319             :             .interface_by_uuid = mgmt__op_interface_by_uuid,
     320             :             .interface_by_name = mgmt__op_interface_by_name
     321             :         };
     322             :         /* register ourselves with the DCERPC subsystem. */
     323           0 :         ret = dcerpc_register_ep_server(&ep_server);
     324             : 
     325           0 :         if (!NT_STATUS_IS_OK(ret)) {
     326           0 :                 DEBUG(0,("Failed to register 'mgmt' endpoint server!\n"));
     327           0 :                 return ret;
     328             :         }
     329             : 
     330           0 :         return ret;
     331             : }
     332             : 

Generated by: LCOV version 1.13