s4:rpc_server: only use context within op_bind() hooks and dcesrv_interface_bind_...
[samba.git] / source4 / rpc_server / dcesrv_mgmt.c
1 /* 
2    Unix SMB/CIFS implementation.
3
4    endpoint server for the mgmt pipe
5
6    Copyright (C) Jelmer Vernooij 2006
7    
8    This program is free software; you can redistribute it and/or modify
9    it under the terms of the GNU General Public License as published by
10    the Free Software Foundation; either version 3 of the License, or
11    (at your option) any later version.
12    
13    This program is distributed in the hope that it will be useful,
14    but WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16    GNU General Public License for more details.
17    
18    You should have received a copy of the GNU General Public License
19    along with this program.  If not, see <http://www.gnu.org/licenses/>.
20 */
21
22 #include "includes.h"
23 #include "rpc_server/dcerpc_server.h"
24 #include "rpc_server/dcerpc_server_proto.h"
25 #include "librpc/gen_ndr/ndr_mgmt.h"
26
27 #define DCESRV_INTERFACE_MGMT_BIND(call, iface) \
28        dcesrv_interface_mgmt_bind(call, iface)
29 /*
30  * This #define allows the mgmt interface to accept invalid
31  * association groups, because association groups are to coordinate
32  * handles, and handles are not used in mgmt. This in turn avoids
33  * the need to coordinate these across multiple possible NETLOGON
34  * processes, as an mgmt interface is added to each
35  */
36
37 #define DCESRV_INTERFACE_MGMT_FLAGS DCESRV_INTERFACE_FLAGS_HANDLES_NOT_USED
38
39 static NTSTATUS dcesrv_interface_mgmt_bind(struct dcesrv_call_state *dce_call,
40                                              const struct dcesrv_interface *iface)
41 {
42         struct dcesrv_connection_context *context = dce_call->context;
43         return dcesrv_interface_bind_allow_connect(context, iface);
44 }
45
46 /* 
47   mgmt_inq_if_ids 
48 */
49 static WERROR dcesrv_mgmt_inq_if_ids(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
50                        struct mgmt_inq_if_ids *r)
51 {
52         const struct dcesrv_endpoint *ep = dce_call->conn->endpoint;
53         struct dcesrv_if_list *l;
54         struct rpc_if_id_vector_t *vector;
55
56         vector = *r->out.if_id_vector = talloc(mem_ctx, struct rpc_if_id_vector_t);
57         vector->count = 0;
58         vector->if_id = NULL;
59         for (l = ep->interface_list; l; l = l->next) {
60                 vector->count++;
61                 vector->if_id = talloc_realloc(mem_ctx, vector->if_id, struct ndr_syntax_id_p, vector->count);
62                 vector->if_id[vector->count-1].id = &l->iface.syntax_id;
63         }
64         return WERR_OK;
65 }
66
67
68 /* 
69   mgmt_inq_stats 
70 */
71 static WERROR dcesrv_mgmt_inq_stats(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
72                        struct mgmt_inq_stats *r)
73 {
74         if (r->in.max_count != MGMT_STATS_ARRAY_MAX_SIZE)
75                 return WERR_NOT_SUPPORTED;
76
77         r->out.statistics->count = r->in.max_count;
78         r->out.statistics->statistics = talloc_array(mem_ctx, uint32_t, r->in.max_count);
79         /* FIXME */
80         r->out.statistics->statistics[MGMT_STATS_CALLS_IN] = 0;
81         r->out.statistics->statistics[MGMT_STATS_CALLS_OUT] = 0;
82         r->out.statistics->statistics[MGMT_STATS_PKTS_IN] = 0;
83         r->out.statistics->statistics[MGMT_STATS_PKTS_OUT] = 0;
84
85         return WERR_OK;
86 }
87
88
89 /* 
90   mgmt_is_server_listening 
91 */
92 static uint32_t dcesrv_mgmt_is_server_listening(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
93                        struct mgmt_is_server_listening *r)
94 {
95         *r->out.status = 0;
96         return 1;
97 }
98
99
100 /* 
101   mgmt_stop_server_listening 
102 */
103 static WERROR dcesrv_mgmt_stop_server_listening(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
104                        struct mgmt_stop_server_listening *r)
105 {
106         return WERR_ACCESS_DENIED;
107 }
108
109
110 /* 
111   mgmt_inq_princ_name 
112 */
113 static WERROR dcesrv_mgmt_inq_princ_name(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
114                        struct mgmt_inq_princ_name *r)
115 {
116         DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
117 }
118
119
120 /* include the generated boilerplate */
121 #include "librpc/gen_ndr/ndr_mgmt_s.c"
122
123 const struct dcesrv_interface dcesrv_get_mgmt_interface(void)
124 {
125         return dcesrv_mgmt_interface;
126 }