git add -f bin/default/librpc/gen_ndr/*.[ch] bin/default/source*/librpc/gen_ndr/...
[metze/samba/wip.git] / bin.gen_ndr / default / librpc / gen_ndr / ndr_drsuapi_s.c
1 /* server functions auto-generated by pidl */
2 #include "bin/default/librpc/gen_ndr/ndr_drsuapi.h"
3
4 NTSTATUS dcerpc_server_drsuapi_init(void);
5
6 /* drsuapi - dcerpc server boilerplate generated by pidl */
7
8
9 static NTSTATUS drsuapi__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
10 {
11 #ifdef DCESRV_INTERFACE_DRSUAPI_BIND
12         return DCESRV_INTERFACE_DRSUAPI_BIND(dce_call,iface);
13 #else
14         return NT_STATUS_OK;
15 #endif
16 }
17
18 static void drsuapi__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
19 {
20 #ifdef DCESRV_INTERFACE_DRSUAPI_UNBIND
21         DCESRV_INTERFACE_DRSUAPI_UNBIND(context, iface);
22 #else
23         return;
24 #endif
25 }
26
27 static NTSTATUS drsuapi__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_drsuapi.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_drsuapi.calls[opnum].struct_size,
41                           "struct %s",
42                           ndr_table_drsuapi.calls[opnum].name);
43         NT_STATUS_HAVE_NO_MEMORY(*r);
44
45         /* unravel the NDR for the packet */
46         ndr_err = ndr_table_drsuapi.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_drsuapi, 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 drsuapi__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 drsuapi_DsBind *r2 = (struct drsuapi_DsBind *)r;
65                 if (DEBUGLEVEL >= 10) {
66                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsBind, NDR_IN, r2);
67                 }
68                 r2->out.result = dcesrv_drsuapi_DsBind(dce_call, mem_ctx, r2);
69                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
70                         DEBUG(5,("function drsuapi_DsBind will reply async\n"));
71                 }
72                 break;
73         }
74         case 1: {
75                 struct drsuapi_DsUnbind *r2 = (struct drsuapi_DsUnbind *)r;
76                 if (DEBUGLEVEL >= 10) {
77                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsUnbind, NDR_IN, r2);
78                 }
79                 r2->out.result = dcesrv_drsuapi_DsUnbind(dce_call, mem_ctx, r2);
80                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
81                         DEBUG(5,("function drsuapi_DsUnbind will reply async\n"));
82                 }
83                 break;
84         }
85         case 2: {
86                 struct drsuapi_DsReplicaSync *r2 = (struct drsuapi_DsReplicaSync *)r;
87                 if (DEBUGLEVEL >= 10) {
88                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaSync, NDR_IN, r2);
89                 }
90                 r2->out.result = dcesrv_drsuapi_DsReplicaSync(dce_call, mem_ctx, r2);
91                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
92                         DEBUG(5,("function drsuapi_DsReplicaSync will reply async\n"));
93                 }
94                 break;
95         }
96         case 3: {
97                 struct drsuapi_DsGetNCChanges *r2 = (struct drsuapi_DsGetNCChanges *)r;
98                 if (DEBUGLEVEL >= 10) {
99                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetNCChanges, NDR_IN, r2);
100                 }
101                 r2->out.result = dcesrv_drsuapi_DsGetNCChanges(dce_call, mem_ctx, r2);
102                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
103                         DEBUG(5,("function drsuapi_DsGetNCChanges will reply async\n"));
104                 }
105                 break;
106         }
107         case 4: {
108                 struct drsuapi_DsReplicaUpdateRefs *r2 = (struct drsuapi_DsReplicaUpdateRefs *)r;
109                 if (DEBUGLEVEL >= 10) {
110                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaUpdateRefs, NDR_IN, r2);
111                 }
112                 r2->out.result = dcesrv_drsuapi_DsReplicaUpdateRefs(dce_call, mem_ctx, r2);
113                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
114                         DEBUG(5,("function drsuapi_DsReplicaUpdateRefs will reply async\n"));
115                 }
116                 break;
117         }
118         case 5: {
119                 struct drsuapi_DsReplicaAdd *r2 = (struct drsuapi_DsReplicaAdd *)r;
120                 if (DEBUGLEVEL >= 10) {
121                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaAdd, NDR_IN, r2);
122                 }
123                 r2->out.result = dcesrv_drsuapi_DsReplicaAdd(dce_call, mem_ctx, r2);
124                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
125                         DEBUG(5,("function drsuapi_DsReplicaAdd will reply async\n"));
126                 }
127                 break;
128         }
129         case 6: {
130                 struct drsuapi_DsReplicaDel *r2 = (struct drsuapi_DsReplicaDel *)r;
131                 if (DEBUGLEVEL >= 10) {
132                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaDel, NDR_IN, r2);
133                 }
134                 r2->out.result = dcesrv_drsuapi_DsReplicaDel(dce_call, mem_ctx, r2);
135                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
136                         DEBUG(5,("function drsuapi_DsReplicaDel will reply async\n"));
137                 }
138                 break;
139         }
140         case 7: {
141                 struct drsuapi_DsReplicaMod *r2 = (struct drsuapi_DsReplicaMod *)r;
142                 if (DEBUGLEVEL >= 10) {
143                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaMod, NDR_IN, r2);
144                 }
145                 r2->out.result = dcesrv_drsuapi_DsReplicaMod(dce_call, mem_ctx, r2);
146                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
147                         DEBUG(5,("function drsuapi_DsReplicaMod will reply async\n"));
148                 }
149                 break;
150         }
151         case 8: {
152                 struct DRSUAPI_VERIFY_NAMES *r2 = (struct DRSUAPI_VERIFY_NAMES *)r;
153                 if (DEBUGLEVEL >= 10) {
154                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_VERIFY_NAMES, NDR_IN, r2);
155                 }
156                 r2->out.result = dcesrv_DRSUAPI_VERIFY_NAMES(dce_call, mem_ctx, r2);
157                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
158                         DEBUG(5,("function DRSUAPI_VERIFY_NAMES will reply async\n"));
159                 }
160                 break;
161         }
162         case 9: {
163                 struct drsuapi_DsGetMemberships *r2 = (struct drsuapi_DsGetMemberships *)r;
164                 if (DEBUGLEVEL >= 10) {
165                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetMemberships, NDR_IN, r2);
166                 }
167                 r2->out.result = dcesrv_drsuapi_DsGetMemberships(dce_call, mem_ctx, r2);
168                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
169                         DEBUG(5,("function drsuapi_DsGetMemberships will reply async\n"));
170                 }
171                 break;
172         }
173         case 10: {
174                 struct DRSUAPI_INTER_DOMAIN_MOVE *r2 = (struct DRSUAPI_INTER_DOMAIN_MOVE *)r;
175                 if (DEBUGLEVEL >= 10) {
176                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_INTER_DOMAIN_MOVE, NDR_IN, r2);
177                 }
178                 r2->out.result = dcesrv_DRSUAPI_INTER_DOMAIN_MOVE(dce_call, mem_ctx, r2);
179                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
180                         DEBUG(5,("function DRSUAPI_INTER_DOMAIN_MOVE will reply async\n"));
181                 }
182                 break;
183         }
184         case 11: {
185                 struct drsuapi_DsGetNT4ChangeLog *r2 = (struct drsuapi_DsGetNT4ChangeLog *)r;
186                 if (DEBUGLEVEL >= 10) {
187                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetNT4ChangeLog, NDR_IN, r2);
188                 }
189                 r2->out.result = dcesrv_drsuapi_DsGetNT4ChangeLog(dce_call, mem_ctx, r2);
190                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
191                         DEBUG(5,("function drsuapi_DsGetNT4ChangeLog will reply async\n"));
192                 }
193                 break;
194         }
195         case 12: {
196                 struct drsuapi_DsCrackNames *r2 = (struct drsuapi_DsCrackNames *)r;
197                 if (DEBUGLEVEL >= 10) {
198                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsCrackNames, NDR_IN, r2);
199                 }
200                 r2->out.result = dcesrv_drsuapi_DsCrackNames(dce_call, mem_ctx, r2);
201                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
202                         DEBUG(5,("function drsuapi_DsCrackNames will reply async\n"));
203                 }
204                 break;
205         }
206         case 13: {
207                 struct drsuapi_DsWriteAccountSpn *r2 = (struct drsuapi_DsWriteAccountSpn *)r;
208                 if (DEBUGLEVEL >= 10) {
209                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsWriteAccountSpn, NDR_IN, r2);
210                 }
211                 r2->out.result = dcesrv_drsuapi_DsWriteAccountSpn(dce_call, mem_ctx, r2);
212                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
213                         DEBUG(5,("function drsuapi_DsWriteAccountSpn will reply async\n"));
214                 }
215                 break;
216         }
217         case 14: {
218                 struct drsuapi_DsRemoveDSServer *r2 = (struct drsuapi_DsRemoveDSServer *)r;
219                 if (DEBUGLEVEL >= 10) {
220                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsRemoveDSServer, NDR_IN, r2);
221                 }
222                 r2->out.result = dcesrv_drsuapi_DsRemoveDSServer(dce_call, mem_ctx, r2);
223                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
224                         DEBUG(5,("function drsuapi_DsRemoveDSServer will reply async\n"));
225                 }
226                 break;
227         }
228         case 15: {
229                 struct DRSUAPI_REMOVE_DS_DOMAIN *r2 = (struct DRSUAPI_REMOVE_DS_DOMAIN *)r;
230                 if (DEBUGLEVEL >= 10) {
231                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_REMOVE_DS_DOMAIN, NDR_IN, r2);
232                 }
233                 r2->out.result = dcesrv_DRSUAPI_REMOVE_DS_DOMAIN(dce_call, mem_ctx, r2);
234                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
235                         DEBUG(5,("function DRSUAPI_REMOVE_DS_DOMAIN will reply async\n"));
236                 }
237                 break;
238         }
239         case 16: {
240                 struct drsuapi_DsGetDomainControllerInfo *r2 = (struct drsuapi_DsGetDomainControllerInfo *)r;
241                 if (DEBUGLEVEL >= 10) {
242                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetDomainControllerInfo, NDR_IN, r2);
243                 }
244                 r2->out.result = dcesrv_drsuapi_DsGetDomainControllerInfo(dce_call, mem_ctx, r2);
245                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
246                         DEBUG(5,("function drsuapi_DsGetDomainControllerInfo will reply async\n"));
247                 }
248                 break;
249         }
250         case 17: {
251                 struct drsuapi_DsAddEntry *r2 = (struct drsuapi_DsAddEntry *)r;
252                 if (DEBUGLEVEL >= 10) {
253                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsAddEntry, NDR_IN, r2);
254                 }
255                 r2->out.result = dcesrv_drsuapi_DsAddEntry(dce_call, mem_ctx, r2);
256                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
257                         DEBUG(5,("function drsuapi_DsAddEntry will reply async\n"));
258                 }
259                 break;
260         }
261         case 18: {
262                 struct drsuapi_DsExecuteKCC *r2 = (struct drsuapi_DsExecuteKCC *)r;
263                 if (DEBUGLEVEL >= 10) {
264                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsExecuteKCC, NDR_IN, r2);
265                 }
266                 r2->out.result = dcesrv_drsuapi_DsExecuteKCC(dce_call, mem_ctx, r2);
267                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
268                         DEBUG(5,("function drsuapi_DsExecuteKCC will reply async\n"));
269                 }
270                 break;
271         }
272         case 19: {
273                 struct drsuapi_DsReplicaGetInfo *r2 = (struct drsuapi_DsReplicaGetInfo *)r;
274                 if (DEBUGLEVEL >= 10) {
275                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaGetInfo, NDR_IN, r2);
276                 }
277                 r2->out.result = dcesrv_drsuapi_DsReplicaGetInfo(dce_call, mem_ctx, r2);
278                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
279                         DEBUG(5,("function drsuapi_DsReplicaGetInfo will reply async\n"));
280                 }
281                 break;
282         }
283         case 20: {
284                 struct DRSUAPI_ADD_SID_HISTORY *r2 = (struct DRSUAPI_ADD_SID_HISTORY *)r;
285                 if (DEBUGLEVEL >= 10) {
286                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_ADD_SID_HISTORY, NDR_IN, r2);
287                 }
288                 r2->out.result = dcesrv_DRSUAPI_ADD_SID_HISTORY(dce_call, mem_ctx, r2);
289                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
290                         DEBUG(5,("function DRSUAPI_ADD_SID_HISTORY will reply async\n"));
291                 }
292                 break;
293         }
294         case 21: {
295                 struct drsuapi_DsGetMemberships2 *r2 = (struct drsuapi_DsGetMemberships2 *)r;
296                 if (DEBUGLEVEL >= 10) {
297                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetMemberships2, NDR_IN, r2);
298                 }
299                 r2->out.result = dcesrv_drsuapi_DsGetMemberships2(dce_call, mem_ctx, r2);
300                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
301                         DEBUG(5,("function drsuapi_DsGetMemberships2 will reply async\n"));
302                 }
303                 break;
304         }
305         case 22: {
306                 struct DRSUAPI_REPLICA_VERIFY_OBJECTS *r2 = (struct DRSUAPI_REPLICA_VERIFY_OBJECTS *)r;
307                 if (DEBUGLEVEL >= 10) {
308                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_REPLICA_VERIFY_OBJECTS, NDR_IN, r2);
309                 }
310                 r2->out.result = dcesrv_DRSUAPI_REPLICA_VERIFY_OBJECTS(dce_call, mem_ctx, r2);
311                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
312                         DEBUG(5,("function DRSUAPI_REPLICA_VERIFY_OBJECTS will reply async\n"));
313                 }
314                 break;
315         }
316         case 23: {
317                 struct DRSUAPI_GET_OBJECT_EXISTENCE *r2 = (struct DRSUAPI_GET_OBJECT_EXISTENCE *)r;
318                 if (DEBUGLEVEL >= 10) {
319                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_GET_OBJECT_EXISTENCE, NDR_IN, r2);
320                 }
321                 r2->out.result = dcesrv_DRSUAPI_GET_OBJECT_EXISTENCE(dce_call, mem_ctx, r2);
322                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
323                         DEBUG(5,("function DRSUAPI_GET_OBJECT_EXISTENCE will reply async\n"));
324                 }
325                 break;
326         }
327         case 24: {
328                 struct drsuapi_QuerySitesByCost *r2 = (struct drsuapi_QuerySitesByCost *)r;
329                 if (DEBUGLEVEL >= 10) {
330                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_QuerySitesByCost, NDR_IN, r2);
331                 }
332                 r2->out.result = dcesrv_drsuapi_QuerySitesByCost(dce_call, mem_ctx, r2);
333                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
334                         DEBUG(5,("function drsuapi_QuerySitesByCost will reply async\n"));
335                 }
336                 break;
337         }
338
339         default:
340                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
341                 break;
342         }
343
344         if (dce_call->fault_code != 0) {
345                 dcerpc_log_packet(dce_call->conn->packet_log_dir, 
346                           &ndr_table_drsuapi, opnum, NDR_IN,
347                                   &dce_call->pkt.u.request.stub_and_verifier);
348                 return NT_STATUS_NET_WRITE_FAULT;
349         }
350
351         return NT_STATUS_OK;
352 }
353
354 static NTSTATUS drsuapi__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
355 {
356         uint16_t opnum = dce_call->pkt.u.request.opnum;
357
358         switch (opnum) {
359         case 0: {
360                 struct drsuapi_DsBind *r2 = (struct drsuapi_DsBind *)r;
361                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
362                         DEBUG(5,("function drsuapi_DsBind replied async\n"));
363                 }
364                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
365                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsBind, NDR_OUT | NDR_SET_VALUES, r2);
366                 }
367                 if (dce_call->fault_code != 0) {
368                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsBind\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
369                 }
370                 break;
371         }
372         case 1: {
373                 struct drsuapi_DsUnbind *r2 = (struct drsuapi_DsUnbind *)r;
374                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
375                         DEBUG(5,("function drsuapi_DsUnbind replied async\n"));
376                 }
377                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
378                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsUnbind, NDR_OUT | NDR_SET_VALUES, r2);
379                 }
380                 if (dce_call->fault_code != 0) {
381                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsUnbind\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
382                 }
383                 break;
384         }
385         case 2: {
386                 struct drsuapi_DsReplicaSync *r2 = (struct drsuapi_DsReplicaSync *)r;
387                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
388                         DEBUG(5,("function drsuapi_DsReplicaSync replied async\n"));
389                 }
390                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
391                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaSync, NDR_OUT | NDR_SET_VALUES, r2);
392                 }
393                 if (dce_call->fault_code != 0) {
394                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaSync\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
395                 }
396                 break;
397         }
398         case 3: {
399                 struct drsuapi_DsGetNCChanges *r2 = (struct drsuapi_DsGetNCChanges *)r;
400                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
401                         DEBUG(5,("function drsuapi_DsGetNCChanges replied async\n"));
402                 }
403                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
404                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetNCChanges, NDR_OUT | NDR_SET_VALUES, r2);
405                 }
406                 if (dce_call->fault_code != 0) {
407                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsGetNCChanges\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
408                 }
409                 break;
410         }
411         case 4: {
412                 struct drsuapi_DsReplicaUpdateRefs *r2 = (struct drsuapi_DsReplicaUpdateRefs *)r;
413                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
414                         DEBUG(5,("function drsuapi_DsReplicaUpdateRefs replied async\n"));
415                 }
416                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
417                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaUpdateRefs, NDR_OUT | NDR_SET_VALUES, r2);
418                 }
419                 if (dce_call->fault_code != 0) {
420                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaUpdateRefs\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
421                 }
422                 break;
423         }
424         case 5: {
425                 struct drsuapi_DsReplicaAdd *r2 = (struct drsuapi_DsReplicaAdd *)r;
426                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
427                         DEBUG(5,("function drsuapi_DsReplicaAdd replied async\n"));
428                 }
429                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
430                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaAdd, NDR_OUT | NDR_SET_VALUES, r2);
431                 }
432                 if (dce_call->fault_code != 0) {
433                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaAdd\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
434                 }
435                 break;
436         }
437         case 6: {
438                 struct drsuapi_DsReplicaDel *r2 = (struct drsuapi_DsReplicaDel *)r;
439                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
440                         DEBUG(5,("function drsuapi_DsReplicaDel replied async\n"));
441                 }
442                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
443                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaDel, NDR_OUT | NDR_SET_VALUES, r2);
444                 }
445                 if (dce_call->fault_code != 0) {
446                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaDel\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
447                 }
448                 break;
449         }
450         case 7: {
451                 struct drsuapi_DsReplicaMod *r2 = (struct drsuapi_DsReplicaMod *)r;
452                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
453                         DEBUG(5,("function drsuapi_DsReplicaMod replied async\n"));
454                 }
455                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
456                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaMod, NDR_OUT | NDR_SET_VALUES, r2);
457                 }
458                 if (dce_call->fault_code != 0) {
459                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaMod\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
460                 }
461                 break;
462         }
463         case 8: {
464                 struct DRSUAPI_VERIFY_NAMES *r2 = (struct DRSUAPI_VERIFY_NAMES *)r;
465                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
466                         DEBUG(5,("function DRSUAPI_VERIFY_NAMES replied async\n"));
467                 }
468                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
469                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_VERIFY_NAMES, NDR_OUT | NDR_SET_VALUES, r2);
470                 }
471                 if (dce_call->fault_code != 0) {
472                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_VERIFY_NAMES\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
473                 }
474                 break;
475         }
476         case 9: {
477                 struct drsuapi_DsGetMemberships *r2 = (struct drsuapi_DsGetMemberships *)r;
478                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
479                         DEBUG(5,("function drsuapi_DsGetMemberships replied async\n"));
480                 }
481                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
482                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetMemberships, NDR_OUT | NDR_SET_VALUES, r2);
483                 }
484                 if (dce_call->fault_code != 0) {
485                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsGetMemberships\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
486                 }
487                 break;
488         }
489         case 10: {
490                 struct DRSUAPI_INTER_DOMAIN_MOVE *r2 = (struct DRSUAPI_INTER_DOMAIN_MOVE *)r;
491                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
492                         DEBUG(5,("function DRSUAPI_INTER_DOMAIN_MOVE replied async\n"));
493                 }
494                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
495                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_INTER_DOMAIN_MOVE, NDR_OUT | NDR_SET_VALUES, r2);
496                 }
497                 if (dce_call->fault_code != 0) {
498                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_INTER_DOMAIN_MOVE\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
499                 }
500                 break;
501         }
502         case 11: {
503                 struct drsuapi_DsGetNT4ChangeLog *r2 = (struct drsuapi_DsGetNT4ChangeLog *)r;
504                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
505                         DEBUG(5,("function drsuapi_DsGetNT4ChangeLog replied async\n"));
506                 }
507                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
508                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetNT4ChangeLog, NDR_OUT | NDR_SET_VALUES, r2);
509                 }
510                 if (dce_call->fault_code != 0) {
511                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsGetNT4ChangeLog\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
512                 }
513                 break;
514         }
515         case 12: {
516                 struct drsuapi_DsCrackNames *r2 = (struct drsuapi_DsCrackNames *)r;
517                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
518                         DEBUG(5,("function drsuapi_DsCrackNames replied async\n"));
519                 }
520                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
521                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsCrackNames, NDR_OUT | NDR_SET_VALUES, r2);
522                 }
523                 if (dce_call->fault_code != 0) {
524                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsCrackNames\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
525                 }
526                 break;
527         }
528         case 13: {
529                 struct drsuapi_DsWriteAccountSpn *r2 = (struct drsuapi_DsWriteAccountSpn *)r;
530                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
531                         DEBUG(5,("function drsuapi_DsWriteAccountSpn replied async\n"));
532                 }
533                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
534                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsWriteAccountSpn, NDR_OUT | NDR_SET_VALUES, r2);
535                 }
536                 if (dce_call->fault_code != 0) {
537                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsWriteAccountSpn\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
538                 }
539                 break;
540         }
541         case 14: {
542                 struct drsuapi_DsRemoveDSServer *r2 = (struct drsuapi_DsRemoveDSServer *)r;
543                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
544                         DEBUG(5,("function drsuapi_DsRemoveDSServer replied async\n"));
545                 }
546                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
547                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsRemoveDSServer, NDR_OUT | NDR_SET_VALUES, r2);
548                 }
549                 if (dce_call->fault_code != 0) {
550                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsRemoveDSServer\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
551                 }
552                 break;
553         }
554         case 15: {
555                 struct DRSUAPI_REMOVE_DS_DOMAIN *r2 = (struct DRSUAPI_REMOVE_DS_DOMAIN *)r;
556                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
557                         DEBUG(5,("function DRSUAPI_REMOVE_DS_DOMAIN replied async\n"));
558                 }
559                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
560                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_REMOVE_DS_DOMAIN, NDR_OUT | NDR_SET_VALUES, r2);
561                 }
562                 if (dce_call->fault_code != 0) {
563                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_REMOVE_DS_DOMAIN\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
564                 }
565                 break;
566         }
567         case 16: {
568                 struct drsuapi_DsGetDomainControllerInfo *r2 = (struct drsuapi_DsGetDomainControllerInfo *)r;
569                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
570                         DEBUG(5,("function drsuapi_DsGetDomainControllerInfo replied async\n"));
571                 }
572                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
573                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetDomainControllerInfo, NDR_OUT | NDR_SET_VALUES, r2);
574                 }
575                 if (dce_call->fault_code != 0) {
576                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsGetDomainControllerInfo\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
577                 }
578                 break;
579         }
580         case 17: {
581                 struct drsuapi_DsAddEntry *r2 = (struct drsuapi_DsAddEntry *)r;
582                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
583                         DEBUG(5,("function drsuapi_DsAddEntry replied async\n"));
584                 }
585                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
586                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsAddEntry, NDR_OUT | NDR_SET_VALUES, r2);
587                 }
588                 if (dce_call->fault_code != 0) {
589                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsAddEntry\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
590                 }
591                 break;
592         }
593         case 18: {
594                 struct drsuapi_DsExecuteKCC *r2 = (struct drsuapi_DsExecuteKCC *)r;
595                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
596                         DEBUG(5,("function drsuapi_DsExecuteKCC replied async\n"));
597                 }
598                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
599                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsExecuteKCC, NDR_OUT | NDR_SET_VALUES, r2);
600                 }
601                 if (dce_call->fault_code != 0) {
602                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsExecuteKCC\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
603                 }
604                 break;
605         }
606         case 19: {
607                 struct drsuapi_DsReplicaGetInfo *r2 = (struct drsuapi_DsReplicaGetInfo *)r;
608                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
609                         DEBUG(5,("function drsuapi_DsReplicaGetInfo replied async\n"));
610                 }
611                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
612                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsReplicaGetInfo, NDR_OUT | NDR_SET_VALUES, r2);
613                 }
614                 if (dce_call->fault_code != 0) {
615                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsReplicaGetInfo\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
616                 }
617                 break;
618         }
619         case 20: {
620                 struct DRSUAPI_ADD_SID_HISTORY *r2 = (struct DRSUAPI_ADD_SID_HISTORY *)r;
621                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
622                         DEBUG(5,("function DRSUAPI_ADD_SID_HISTORY replied async\n"));
623                 }
624                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
625                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_ADD_SID_HISTORY, NDR_OUT | NDR_SET_VALUES, r2);
626                 }
627                 if (dce_call->fault_code != 0) {
628                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_ADD_SID_HISTORY\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
629                 }
630                 break;
631         }
632         case 21: {
633                 struct drsuapi_DsGetMemberships2 *r2 = (struct drsuapi_DsGetMemberships2 *)r;
634                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
635                         DEBUG(5,("function drsuapi_DsGetMemberships2 replied async\n"));
636                 }
637                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
638                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_DsGetMemberships2, NDR_OUT | NDR_SET_VALUES, r2);
639                 }
640                 if (dce_call->fault_code != 0) {
641                         DEBUG(2,("dcerpc_fault %s in drsuapi_DsGetMemberships2\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
642                 }
643                 break;
644         }
645         case 22: {
646                 struct DRSUAPI_REPLICA_VERIFY_OBJECTS *r2 = (struct DRSUAPI_REPLICA_VERIFY_OBJECTS *)r;
647                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
648                         DEBUG(5,("function DRSUAPI_REPLICA_VERIFY_OBJECTS replied async\n"));
649                 }
650                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
651                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_REPLICA_VERIFY_OBJECTS, NDR_OUT | NDR_SET_VALUES, r2);
652                 }
653                 if (dce_call->fault_code != 0) {
654                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_REPLICA_VERIFY_OBJECTS\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
655                 }
656                 break;
657         }
658         case 23: {
659                 struct DRSUAPI_GET_OBJECT_EXISTENCE *r2 = (struct DRSUAPI_GET_OBJECT_EXISTENCE *)r;
660                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
661                         DEBUG(5,("function DRSUAPI_GET_OBJECT_EXISTENCE replied async\n"));
662                 }
663                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
664                         NDR_PRINT_FUNCTION_DEBUG(DRSUAPI_GET_OBJECT_EXISTENCE, NDR_OUT | NDR_SET_VALUES, r2);
665                 }
666                 if (dce_call->fault_code != 0) {
667                         DEBUG(2,("dcerpc_fault %s in DRSUAPI_GET_OBJECT_EXISTENCE\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
668                 }
669                 break;
670         }
671         case 24: {
672                 struct drsuapi_QuerySitesByCost *r2 = (struct drsuapi_QuerySitesByCost *)r;
673                 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
674                         DEBUG(5,("function drsuapi_QuerySitesByCost replied async\n"));
675                 }
676                 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
677                         NDR_PRINT_FUNCTION_DEBUG(drsuapi_QuerySitesByCost, NDR_OUT | NDR_SET_VALUES, r2);
678                 }
679                 if (dce_call->fault_code != 0) {
680                         DEBUG(2,("dcerpc_fault %s in drsuapi_QuerySitesByCost\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
681                 }
682                 break;
683         }
684
685         default:
686                 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
687                 break;
688         }
689
690         if (dce_call->fault_code != 0) {
691                 dcerpc_log_packet(dce_call->conn->packet_log_dir,
692                           &ndr_table_drsuapi, opnum, NDR_IN,
693                                   &dce_call->pkt.u.request.stub_and_verifier);
694                 return NT_STATUS_NET_WRITE_FAULT;
695         }
696
697         return NT_STATUS_OK;
698 }
699
700 static NTSTATUS drsuapi__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
701 {
702         enum ndr_err_code ndr_err;
703         uint16_t opnum = dce_call->pkt.u.request.opnum;
704
705         ndr_err = ndr_table_drsuapi.calls[opnum].ndr_push(push, NDR_OUT, r);
706         if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
707                 dce_call->fault_code = DCERPC_FAULT_NDR;
708                 return NT_STATUS_NET_WRITE_FAULT;
709         }
710
711         return NT_STATUS_OK;
712 }
713
714 const struct dcesrv_interface dcesrv_drsuapi_interface = {
715         .name           = "drsuapi",
716         .syntax_id  = {{0xe3514235,0x4b06,0x11d1,{0xab,0x04},{0x00,0xc0,0x4f,0xc2,0xdc,0xd2}},4.0},
717         .bind           = drsuapi__op_bind,
718         .unbind         = drsuapi__op_unbind,
719         .ndr_pull       = drsuapi__op_ndr_pull,
720         .dispatch       = drsuapi__op_dispatch,
721         .reply          = drsuapi__op_reply,
722         .ndr_push       = drsuapi__op_ndr_push
723 };
724
725
726 static NTSTATUS drsuapi__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
727 {
728         int i;
729
730         for (i=0;i<ndr_table_drsuapi.endpoints->count;i++) {
731                 NTSTATUS ret;
732                 const char *name = ndr_table_drsuapi.endpoints->names[i];
733
734                 ret = dcesrv_interface_register(dce_ctx, name, &dcesrv_drsuapi_interface, NULL);
735                 if (!NT_STATUS_IS_OK(ret)) {
736                         DEBUG(1,("drsuapi_op_init_server: failed to register endpoint '%s'\n",name));
737                         return ret;
738                 }
739         }
740
741         return NT_STATUS_OK;
742 }
743
744 static bool drsuapi__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
745 {
746         if (dcesrv_drsuapi_interface.syntax_id.if_version == if_version &&
747                 GUID_equal(&dcesrv_drsuapi_interface.syntax_id.uuid, uuid)) {
748                 memcpy(iface,&dcesrv_drsuapi_interface, sizeof(*iface));
749                 return true;
750         }
751
752         return false;
753 }
754
755 static bool drsuapi__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
756 {
757         if (strcmp(dcesrv_drsuapi_interface.name, name)==0) {
758                 memcpy(iface, &dcesrv_drsuapi_interface, sizeof(*iface));
759                 return true;
760         }
761
762         return false;
763 }
764
765 NTSTATUS dcerpc_server_drsuapi_init(void)
766 {
767         NTSTATUS ret;
768         struct dcesrv_endpoint_server ep_server;
769
770         /* fill in our name */
771         ep_server.name = "drsuapi";
772
773         /* fill in all the operations */
774         ep_server.init_server = drsuapi__op_init_server;
775
776         ep_server.interface_by_uuid = drsuapi__op_interface_by_uuid;
777         ep_server.interface_by_name = drsuapi__op_interface_by_name;
778
779         /* register ourselves with the DCERPC subsystem. */
780         ret = dcerpc_register_ep_server(&ep_server);
781
782         if (!NT_STATUS_IS_OK(ret)) {
783                 DEBUG(0,("Failed to register 'drsuapi' endpoint server!\n"));
784                 return ret;
785         }
786
787         return ret;
788 }
789