757473d1afb6903595e19311eb762f545e724bd8
[metze/samba/wip.git] / bin.gen_ndr / default / librpc / gen_ndr / ndr_echo_s.c
1 /* server functions auto-generated by pidl */
2 #include "bin/default/librpc/gen_ndr/ndr_echo.h"
3
4 NTSTATUS dcerpc_server_rpcecho_init(void);
5
6 /* rpcecho - dcerpc server boilerplate generated by pidl */
7
8
9 static NTSTATUS rpcecho__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
10 {
11 #ifdef DCESRV_INTERFACE_RPCECHO_BIND
12         return DCESRV_INTERFACE_RPCECHO_BIND(dce_call,iface);
13 #else
14         return NT_STATUS_OK;
15 #endif
16 }
17
18 static void rpcecho__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
19 {
20 #ifdef DCESRV_INTERFACE_RPCECHO_UNBIND
21         DCESRV_INTERFACE_RPCECHO_UNBIND(context, iface);
22 #else
23         return;
24 #endif
25 }
26
27 static NTSTATUS rpcecho__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
28 {
29         enum ndr_err_code ndr_err;
30         uint16_t opnum = dce_call->pkt.u.request.opnum;
31
32         dce_call->fault_code = 0;
33
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;
37         }
38
39         *r = talloc_named(mem_ctx,
40                           ndr_table_rpcecho.calls[opnum].struct_size,
41                           "struct %s",
42                           ndr_table_rpcecho.calls[opnum].name);
43         NT_STATUS_HAVE_NO_MEMORY(*r);
44
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;
53         }
54
55         return NT_STATUS_OK;
56 }
57
58 static NTSTATUS rpcecho__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
59 {
60         uint16_t opnum = dce_call->pkt.u.request.opnum;
61
62         switch (opnum) {
63         case 0: {
64                 struct echo_AddOne *r2 = (struct echo_AddOne *)r;
65                 if (DEBUGLEVEL >= 10) {
66                         NDR_PRINT_FUNCTION_DEBUG(echo_AddOne, NDR_IN, r2);
67                 }
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"));
71                 }
72                 break;
73         }
74         case 1: {
75                 struct echo_EchoData *r2 = (struct echo_EchoData *)r;
76                 if (DEBUGLEVEL >= 10) {
77                         NDR_PRINT_FUNCTION_DEBUG(echo_EchoData, NDR_IN, r2);
78                 }
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"));
82                 }
83                 break;
84         }
85         case 2: {
86                 struct echo_SinkData *r2 = (struct echo_SinkData *)r;
87                 if (DEBUGLEVEL >= 10) {
88                         NDR_PRINT_FUNCTION_DEBUG(echo_SinkData, NDR_IN, r2);
89                 }
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"));
93                 }
94                 break;
95         }
96         case 3: {
97                 struct echo_SourceData *r2 = (struct echo_SourceData *)r;
98                 if (DEBUGLEVEL >= 10) {
99                         NDR_PRINT_FUNCTION_DEBUG(echo_SourceData, NDR_IN, r2);
100                 }
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"));
104                 }
105                 break;
106         }
107         case 4: {
108                 struct echo_TestCall *r2 = (struct echo_TestCall *)r;
109                 if (DEBUGLEVEL >= 10) {
110                         NDR_PRINT_FUNCTION_DEBUG(echo_TestCall, NDR_IN, r2);
111                 }
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"));
115                 }
116                 break;
117         }
118         case 5: {
119                 struct echo_TestCall2 *r2 = (struct echo_TestCall2 *)r;
120                 if (DEBUGLEVEL >= 10) {
121                         NDR_PRINT_FUNCTION_DEBUG(echo_TestCall2, NDR_IN, r2);
122                 }
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"));
126                 }
127                 break;
128         }
129         case 6: {
130                 struct echo_TestSleep *r2 = (struct echo_TestSleep *)r;
131                 if (DEBUGLEVEL >= 10) {
132                         NDR_PRINT_FUNCTION_DEBUG(echo_TestSleep, NDR_IN, r2);
133                 }
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"));
137                 }
138                 break;
139         }
140         case 7: {
141                 struct echo_TestEnum *r2 = (struct echo_TestEnum *)r;
142                 if (DEBUGLEVEL >= 10) {
143                         NDR_PRINT_FUNCTION_DEBUG(echo_TestEnum, NDR_IN, r2);
144                 }
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"));
148                 }
149                 break;
150         }
151         case 8: {
152                 struct echo_TestSurrounding *r2 = (struct echo_TestSurrounding *)r;
153                 if (DEBUGLEVEL >= 10) {
154                         NDR_PRINT_FUNCTION_DEBUG(echo_TestSurrounding, NDR_IN, r2);
155                 }
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"));
159                 }
160                 break;
161         }
162         case 9: {
163                 struct echo_TestDoublePointer *r2 = (struct echo_TestDoublePointer *)r;
164                 if (DEBUGLEVEL >= 10) {
165                         NDR_PRINT_FUNCTION_DEBUG(echo_TestDoublePointer, NDR_IN, r2);
166                 }
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"));
170                 }
171                 break;
172         }
173
174         default:
175                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
176                 break;
177         }
178
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;
184         }
185
186         return NT_STATUS_OK;
187 }
188
189 static NTSTATUS rpcecho__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
190 {
191         uint16_t opnum = dce_call->pkt.u.request.opnum;
192
193         switch (opnum) {
194         case 0: {
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"));
198                 }
199                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
200                         NDR_PRINT_FUNCTION_DEBUG(echo_AddOne, NDR_OUT | NDR_SET_VALUES, r2);
201                 }
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)));
204                 }
205                 break;
206         }
207         case 1: {
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"));
211                 }
212                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
213                         NDR_PRINT_FUNCTION_DEBUG(echo_EchoData, NDR_OUT | NDR_SET_VALUES, r2);
214                 }
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)));
217                 }
218                 break;
219         }
220         case 2: {
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"));
224                 }
225                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
226                         NDR_PRINT_FUNCTION_DEBUG(echo_SinkData, NDR_OUT | NDR_SET_VALUES, r2);
227                 }
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)));
230                 }
231                 break;
232         }
233         case 3: {
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"));
237                 }
238                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
239                         NDR_PRINT_FUNCTION_DEBUG(echo_SourceData, NDR_OUT | NDR_SET_VALUES, r2);
240                 }
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)));
243                 }
244                 break;
245         }
246         case 4: {
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"));
250                 }
251                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
252                         NDR_PRINT_FUNCTION_DEBUG(echo_TestCall, NDR_OUT | NDR_SET_VALUES, r2);
253                 }
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)));
256                 }
257                 break;
258         }
259         case 5: {
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"));
263                 }
264                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
265                         NDR_PRINT_FUNCTION_DEBUG(echo_TestCall2, NDR_OUT | NDR_SET_VALUES, r2);
266                 }
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)));
269                 }
270                 break;
271         }
272         case 6: {
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"));
276                 }
277                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
278                         NDR_PRINT_FUNCTION_DEBUG(echo_TestSleep, NDR_OUT | NDR_SET_VALUES, r2);
279                 }
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)));
282                 }
283                 break;
284         }
285         case 7: {
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"));
289                 }
290                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
291                         NDR_PRINT_FUNCTION_DEBUG(echo_TestEnum, NDR_OUT | NDR_SET_VALUES, r2);
292                 }
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)));
295                 }
296                 break;
297         }
298         case 8: {
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"));
302                 }
303                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
304                         NDR_PRINT_FUNCTION_DEBUG(echo_TestSurrounding, NDR_OUT | NDR_SET_VALUES, r2);
305                 }
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)));
308                 }
309                 break;
310         }
311         case 9: {
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"));
315                 }
316                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
317                         NDR_PRINT_FUNCTION_DEBUG(echo_TestDoublePointer, NDR_OUT | NDR_SET_VALUES, r2);
318                 }
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)));
321                 }
322                 break;
323         }
324
325         default:
326                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
327                 break;
328         }
329
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;
335         }
336
337         return NT_STATUS_OK;
338 }
339
340 static NTSTATUS rpcecho__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
341 {
342         enum ndr_err_code ndr_err;
343         uint16_t opnum = dce_call->pkt.u.request.opnum;
344
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;
349         }
350
351         return NT_STATUS_OK;
352 }
353
354 const struct dcesrv_interface dcesrv_rpcecho_interface = {
355         .name           = "rpcecho",
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
363 };
364
365
366 static NTSTATUS rpcecho__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
367 {
368         int i;
369
370         for (i=0;i<ndr_table_rpcecho.endpoints->count;i++) {
371                 NTSTATUS ret;
372                 const char *name = ndr_table_rpcecho.endpoints->names[i];
373
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));
377                         return ret;
378                 }
379         }
380
381         return NT_STATUS_OK;
382 }
383
384 static bool rpcecho__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
385 {
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));
389                 return true;
390         }
391
392         return false;
393 }
394
395 static bool rpcecho__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
396 {
397         if (strcmp(dcesrv_rpcecho_interface.name, name)==0) {
398                 memcpy(iface, &dcesrv_rpcecho_interface, sizeof(*iface));
399                 return true;
400         }
401
402         return false;
403 }
404
405 NTSTATUS dcerpc_server_rpcecho_init(void)
406 {
407         NTSTATUS ret;
408         struct dcesrv_endpoint_server ep_server;
409
410         /* fill in our name */
411         ep_server.name = "rpcecho";
412
413         /* fill in all the operations */
414         ep_server.init_server = rpcecho__op_init_server;
415
416         ep_server.interface_by_uuid = rpcecho__op_interface_by_uuid;
417         ep_server.interface_by_name = rpcecho__op_interface_by_name;
418
419         /* register ourselves with the DCERPC subsystem. */
420         ret = dcerpc_register_ep_server(&ep_server);
421
422         if (!NT_STATUS_IS_OK(ret)) {
423                 DEBUG(0,("Failed to register 'rpcecho' endpoint server!\n"));
424                 return ret;
425         }
426
427         return ret;
428 }
429