1 /* server functions auto-generated by pidl */
2 #include "bin/default/librpc/gen_ndr/ndr_echo.h"
4 NTSTATUS dcerpc_server_rpcecho_init(void);
6 /* rpcecho - dcerpc server boilerplate generated by pidl */
9 static NTSTATUS rpcecho__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
11 #ifdef DCESRV_INTERFACE_RPCECHO_BIND
12 return DCESRV_INTERFACE_RPCECHO_BIND(dce_call,iface);
18 static void rpcecho__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
20 #ifdef DCESRV_INTERFACE_RPCECHO_UNBIND
21 DCESRV_INTERFACE_RPCECHO_UNBIND(context, iface);
27 static NTSTATUS rpcecho__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
29 enum ndr_err_code ndr_err;
30 uint16_t opnum = dce_call->pkt.u.request.opnum;
32 dce_call->fault_code = 0;
34 if (opnum >= ndr_table_rpcecho.num_calls) {
35 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
36 return NT_STATUS_NET_WRITE_FAULT;
39 *r = talloc_named(mem_ctx,
40 ndr_table_rpcecho.calls[opnum].struct_size,
42 ndr_table_rpcecho.calls[opnum].name);
43 NT_STATUS_HAVE_NO_MEMORY(*r);
45 /* unravel the NDR for the packet */
46 ndr_err = ndr_table_rpcecho.calls[opnum].ndr_pull(pull, NDR_IN, *r);
47 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
48 dcerpc_log_packet(dce_call->conn->packet_log_dir,
49 &ndr_table_rpcecho, opnum, NDR_IN,
50 &dce_call->pkt.u.request.stub_and_verifier);
51 dce_call->fault_code = DCERPC_FAULT_NDR;
52 return NT_STATUS_NET_WRITE_FAULT;
58 static NTSTATUS rpcecho__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
60 uint16_t opnum = dce_call->pkt.u.request.opnum;
64 struct echo_AddOne *r2 = (struct echo_AddOne *)r;
65 if (DEBUGLEVEL >= 10) {
66 NDR_PRINT_FUNCTION_DEBUG(echo_AddOne, NDR_IN, r2);
68 dcesrv_echo_AddOne(dce_call, mem_ctx, r2);
69 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
70 DEBUG(5,("function echo_AddOne will reply async\n"));
75 struct echo_EchoData *r2 = (struct echo_EchoData *)r;
76 if (DEBUGLEVEL >= 10) {
77 NDR_PRINT_FUNCTION_DEBUG(echo_EchoData, NDR_IN, r2);
79 dcesrv_echo_EchoData(dce_call, mem_ctx, r2);
80 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
81 DEBUG(5,("function echo_EchoData will reply async\n"));
86 struct echo_SinkData *r2 = (struct echo_SinkData *)r;
87 if (DEBUGLEVEL >= 10) {
88 NDR_PRINT_FUNCTION_DEBUG(echo_SinkData, NDR_IN, r2);
90 dcesrv_echo_SinkData(dce_call, mem_ctx, r2);
91 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
92 DEBUG(5,("function echo_SinkData will reply async\n"));
97 struct echo_SourceData *r2 = (struct echo_SourceData *)r;
98 if (DEBUGLEVEL >= 10) {
99 NDR_PRINT_FUNCTION_DEBUG(echo_SourceData, NDR_IN, r2);
101 dcesrv_echo_SourceData(dce_call, mem_ctx, r2);
102 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
103 DEBUG(5,("function echo_SourceData will reply async\n"));
108 struct echo_TestCall *r2 = (struct echo_TestCall *)r;
109 if (DEBUGLEVEL >= 10) {
110 NDR_PRINT_FUNCTION_DEBUG(echo_TestCall, NDR_IN, r2);
112 dcesrv_echo_TestCall(dce_call, mem_ctx, r2);
113 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
114 DEBUG(5,("function echo_TestCall will reply async\n"));
119 struct echo_TestCall2 *r2 = (struct echo_TestCall2 *)r;
120 if (DEBUGLEVEL >= 10) {
121 NDR_PRINT_FUNCTION_DEBUG(echo_TestCall2, NDR_IN, r2);
123 r2->out.result = dcesrv_echo_TestCall2(dce_call, mem_ctx, r2);
124 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
125 DEBUG(5,("function echo_TestCall2 will reply async\n"));
130 struct echo_TestSleep *r2 = (struct echo_TestSleep *)r;
131 if (DEBUGLEVEL >= 10) {
132 NDR_PRINT_FUNCTION_DEBUG(echo_TestSleep, NDR_IN, r2);
134 r2->out.result = dcesrv_echo_TestSleep(dce_call, mem_ctx, r2);
135 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
136 DEBUG(5,("function echo_TestSleep will reply async\n"));
141 struct echo_TestEnum *r2 = (struct echo_TestEnum *)r;
142 if (DEBUGLEVEL >= 10) {
143 NDR_PRINT_FUNCTION_DEBUG(echo_TestEnum, NDR_IN, r2);
145 dcesrv_echo_TestEnum(dce_call, mem_ctx, r2);
146 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
147 DEBUG(5,("function echo_TestEnum will reply async\n"));
152 struct echo_TestSurrounding *r2 = (struct echo_TestSurrounding *)r;
153 if (DEBUGLEVEL >= 10) {
154 NDR_PRINT_FUNCTION_DEBUG(echo_TestSurrounding, NDR_IN, r2);
156 dcesrv_echo_TestSurrounding(dce_call, mem_ctx, r2);
157 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
158 DEBUG(5,("function echo_TestSurrounding will reply async\n"));
163 struct echo_TestDoublePointer *r2 = (struct echo_TestDoublePointer *)r;
164 if (DEBUGLEVEL >= 10) {
165 NDR_PRINT_FUNCTION_DEBUG(echo_TestDoublePointer, NDR_IN, r2);
167 r2->out.result = dcesrv_echo_TestDoublePointer(dce_call, mem_ctx, r2);
168 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
169 DEBUG(5,("function echo_TestDoublePointer will reply async\n"));
175 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
179 if (dce_call->fault_code != 0) {
180 dcerpc_log_packet(dce_call->conn->packet_log_dir,
181 &ndr_table_rpcecho, opnum, NDR_IN,
182 &dce_call->pkt.u.request.stub_and_verifier);
183 return NT_STATUS_NET_WRITE_FAULT;
189 static NTSTATUS rpcecho__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
191 uint16_t opnum = dce_call->pkt.u.request.opnum;
195 struct echo_AddOne *r2 = (struct echo_AddOne *)r;
196 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
197 DEBUG(5,("function echo_AddOne replied async\n"));
199 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
200 NDR_PRINT_FUNCTION_DEBUG(echo_AddOne, NDR_OUT | NDR_SET_VALUES, r2);
202 if (dce_call->fault_code != 0) {
203 DEBUG(2,("dcerpc_fault %s in echo_AddOne\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
208 struct echo_EchoData *r2 = (struct echo_EchoData *)r;
209 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
210 DEBUG(5,("function echo_EchoData replied async\n"));
212 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
213 NDR_PRINT_FUNCTION_DEBUG(echo_EchoData, NDR_OUT | NDR_SET_VALUES, r2);
215 if (dce_call->fault_code != 0) {
216 DEBUG(2,("dcerpc_fault %s in echo_EchoData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
221 struct echo_SinkData *r2 = (struct echo_SinkData *)r;
222 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
223 DEBUG(5,("function echo_SinkData replied async\n"));
225 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
226 NDR_PRINT_FUNCTION_DEBUG(echo_SinkData, NDR_OUT | NDR_SET_VALUES, r2);
228 if (dce_call->fault_code != 0) {
229 DEBUG(2,("dcerpc_fault %s in echo_SinkData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
234 struct echo_SourceData *r2 = (struct echo_SourceData *)r;
235 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
236 DEBUG(5,("function echo_SourceData replied async\n"));
238 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
239 NDR_PRINT_FUNCTION_DEBUG(echo_SourceData, NDR_OUT | NDR_SET_VALUES, r2);
241 if (dce_call->fault_code != 0) {
242 DEBUG(2,("dcerpc_fault %s in echo_SourceData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
247 struct echo_TestCall *r2 = (struct echo_TestCall *)r;
248 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
249 DEBUG(5,("function echo_TestCall replied async\n"));
251 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
252 NDR_PRINT_FUNCTION_DEBUG(echo_TestCall, NDR_OUT | NDR_SET_VALUES, r2);
254 if (dce_call->fault_code != 0) {
255 DEBUG(2,("dcerpc_fault %s in echo_TestCall\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
260 struct echo_TestCall2 *r2 = (struct echo_TestCall2 *)r;
261 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
262 DEBUG(5,("function echo_TestCall2 replied async\n"));
264 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
265 NDR_PRINT_FUNCTION_DEBUG(echo_TestCall2, NDR_OUT | NDR_SET_VALUES, r2);
267 if (dce_call->fault_code != 0) {
268 DEBUG(2,("dcerpc_fault %s in echo_TestCall2\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
273 struct echo_TestSleep *r2 = (struct echo_TestSleep *)r;
274 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
275 DEBUG(5,("function echo_TestSleep replied async\n"));
277 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
278 NDR_PRINT_FUNCTION_DEBUG(echo_TestSleep, NDR_OUT | NDR_SET_VALUES, r2);
280 if (dce_call->fault_code != 0) {
281 DEBUG(2,("dcerpc_fault %s in echo_TestSleep\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
286 struct echo_TestEnum *r2 = (struct echo_TestEnum *)r;
287 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
288 DEBUG(5,("function echo_TestEnum replied async\n"));
290 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
291 NDR_PRINT_FUNCTION_DEBUG(echo_TestEnum, NDR_OUT | NDR_SET_VALUES, r2);
293 if (dce_call->fault_code != 0) {
294 DEBUG(2,("dcerpc_fault %s in echo_TestEnum\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
299 struct echo_TestSurrounding *r2 = (struct echo_TestSurrounding *)r;
300 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
301 DEBUG(5,("function echo_TestSurrounding replied async\n"));
303 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
304 NDR_PRINT_FUNCTION_DEBUG(echo_TestSurrounding, NDR_OUT | NDR_SET_VALUES, r2);
306 if (dce_call->fault_code != 0) {
307 DEBUG(2,("dcerpc_fault %s in echo_TestSurrounding\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
312 struct echo_TestDoublePointer *r2 = (struct echo_TestDoublePointer *)r;
313 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
314 DEBUG(5,("function echo_TestDoublePointer replied async\n"));
316 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
317 NDR_PRINT_FUNCTION_DEBUG(echo_TestDoublePointer, NDR_OUT | NDR_SET_VALUES, r2);
319 if (dce_call->fault_code != 0) {
320 DEBUG(2,("dcerpc_fault %s in echo_TestDoublePointer\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
326 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
330 if (dce_call->fault_code != 0) {
331 dcerpc_log_packet(dce_call->conn->packet_log_dir,
332 &ndr_table_rpcecho, opnum, NDR_IN,
333 &dce_call->pkt.u.request.stub_and_verifier);
334 return NT_STATUS_NET_WRITE_FAULT;
340 static NTSTATUS rpcecho__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
342 enum ndr_err_code ndr_err;
343 uint16_t opnum = dce_call->pkt.u.request.opnum;
345 ndr_err = ndr_table_rpcecho.calls[opnum].ndr_push(push, NDR_OUT, r);
346 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
347 dce_call->fault_code = DCERPC_FAULT_NDR;
348 return NT_STATUS_NET_WRITE_FAULT;
354 const struct dcesrv_interface dcesrv_rpcecho_interface = {
356 .syntax_id = {{0x60a15ec5,0x4de8,0x11d7,{0xa6,0x37},{0x00,0x50,0x56,0xa2,0x01,0x82}},1.0},
357 .bind = rpcecho__op_bind,
358 .unbind = rpcecho__op_unbind,
359 .ndr_pull = rpcecho__op_ndr_pull,
360 .dispatch = rpcecho__op_dispatch,
361 .reply = rpcecho__op_reply,
362 .ndr_push = rpcecho__op_ndr_push
366 static NTSTATUS rpcecho__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
370 for (i=0;i<ndr_table_rpcecho.endpoints->count;i++) {
372 const char *name = ndr_table_rpcecho.endpoints->names[i];
374 ret = dcesrv_interface_register(dce_ctx, name, &dcesrv_rpcecho_interface, NULL);
375 if (!NT_STATUS_IS_OK(ret)) {
376 DEBUG(1,("rpcecho_op_init_server: failed to register endpoint '%s'\n",name));
384 static bool rpcecho__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
386 if (dcesrv_rpcecho_interface.syntax_id.if_version == if_version &&
387 GUID_equal(&dcesrv_rpcecho_interface.syntax_id.uuid, uuid)) {
388 memcpy(iface,&dcesrv_rpcecho_interface, sizeof(*iface));
395 static bool rpcecho__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
397 if (strcmp(dcesrv_rpcecho_interface.name, name)==0) {
398 memcpy(iface, &dcesrv_rpcecho_interface, sizeof(*iface));
405 NTSTATUS dcerpc_server_rpcecho_init(void)
408 struct dcesrv_endpoint_server ep_server;
410 /* fill in our name */
411 ep_server.name = "rpcecho";
413 /* fill in all the operations */
414 ep_server.init_server = rpcecho__op_init_server;
416 ep_server.interface_by_uuid = rpcecho__op_interface_by_uuid;
417 ep_server.interface_by_name = rpcecho__op_interface_by_name;
419 /* register ourselves with the DCERPC subsystem. */
420 ret = dcerpc_register_ep_server(&ep_server);
422 if (!NT_STATUS_IS_OK(ret)) {
423 DEBUG(0,("Failed to register 'rpcecho' endpoint server!\n"));