1 /* server functions auto-generated by pidl */
2 #include "bin/default/librpc/gen_ndr/ndr_dcom.h"
4 NTSTATUS dcerpc_server_dcom_Unknown_init(void);
6 /* dcom_Unknown - dcerpc server boilerplate generated by pidl */
9 static NTSTATUS dcom_Unknown__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
11 #ifdef DCESRV_INTERFACE_DCOM_UNKNOWN_BIND
12 return DCESRV_INTERFACE_DCOM_UNKNOWN_BIND(dce_call,iface);
18 static void dcom_Unknown__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
20 #ifdef DCESRV_INTERFACE_DCOM_UNKNOWN_UNBIND
21 DCESRV_INTERFACE_DCOM_UNKNOWN_UNBIND(context, iface);
27 static NTSTATUS dcom_Unknown__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_dcom_Unknown.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_dcom_Unknown.calls[opnum].struct_size,
42 ndr_table_dcom_Unknown.calls[opnum].name);
43 NT_STATUS_HAVE_NO_MEMORY(*r);
45 /* unravel the NDR for the packet */
46 ndr_err = ndr_table_dcom_Unknown.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_dcom_Unknown, 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 dcom_Unknown__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 UseProtSeq *r2 = (struct UseProtSeq *)r;
65 if (DEBUGLEVEL >= 10) {
66 NDR_PRINT_FUNCTION_DEBUG(UseProtSeq, NDR_IN, r2);
68 dcesrv_UseProtSeq(dce_call, mem_ctx, r2);
69 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
70 DEBUG(5,("function UseProtSeq will reply async\n"));
75 struct GetCustomProtseqInfo *r2 = (struct GetCustomProtseqInfo *)r;
76 if (DEBUGLEVEL >= 10) {
77 NDR_PRINT_FUNCTION_DEBUG(GetCustomProtseqInfo, NDR_IN, r2);
79 dcesrv_GetCustomProtseqInfo(dce_call, mem_ctx, r2);
80 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
81 DEBUG(5,("function GetCustomProtseqInfo will reply async\n"));
86 struct UpdateResolverBindings *r2 = (struct UpdateResolverBindings *)r;
87 if (DEBUGLEVEL >= 10) {
88 NDR_PRINT_FUNCTION_DEBUG(UpdateResolverBindings, NDR_IN, r2);
90 dcesrv_UpdateResolverBindings(dce_call, mem_ctx, r2);
91 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
92 DEBUG(5,("function UpdateResolverBindings will reply async\n"));
98 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
102 if (dce_call->fault_code != 0) {
103 dcerpc_log_packet(dce_call->conn->packet_log_dir,
104 &ndr_table_dcom_Unknown, opnum, NDR_IN,
105 &dce_call->pkt.u.request.stub_and_verifier);
106 return NT_STATUS_NET_WRITE_FAULT;
112 static NTSTATUS dcom_Unknown__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
114 uint16_t opnum = dce_call->pkt.u.request.opnum;
118 struct UseProtSeq *r2 = (struct UseProtSeq *)r;
119 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
120 DEBUG(5,("function UseProtSeq replied async\n"));
122 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
123 NDR_PRINT_FUNCTION_DEBUG(UseProtSeq, NDR_OUT | NDR_SET_VALUES, r2);
125 if (dce_call->fault_code != 0) {
126 DEBUG(2,("dcerpc_fault %s in UseProtSeq\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
131 struct GetCustomProtseqInfo *r2 = (struct GetCustomProtseqInfo *)r;
132 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
133 DEBUG(5,("function GetCustomProtseqInfo replied async\n"));
135 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
136 NDR_PRINT_FUNCTION_DEBUG(GetCustomProtseqInfo, NDR_OUT | NDR_SET_VALUES, r2);
138 if (dce_call->fault_code != 0) {
139 DEBUG(2,("dcerpc_fault %s in GetCustomProtseqInfo\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
144 struct UpdateResolverBindings *r2 = (struct UpdateResolverBindings *)r;
145 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
146 DEBUG(5,("function UpdateResolverBindings replied async\n"));
148 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
149 NDR_PRINT_FUNCTION_DEBUG(UpdateResolverBindings, NDR_OUT | NDR_SET_VALUES, r2);
151 if (dce_call->fault_code != 0) {
152 DEBUG(2,("dcerpc_fault %s in UpdateResolverBindings\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
158 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
162 if (dce_call->fault_code != 0) {
163 dcerpc_log_packet(dce_call->conn->packet_log_dir,
164 &ndr_table_dcom_Unknown, opnum, NDR_IN,
165 &dce_call->pkt.u.request.stub_and_verifier);
166 return NT_STATUS_NET_WRITE_FAULT;
172 static NTSTATUS dcom_Unknown__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
174 enum ndr_err_code ndr_err;
175 uint16_t opnum = dce_call->pkt.u.request.opnum;
177 ndr_err = ndr_table_dcom_Unknown.calls[opnum].ndr_push(push, NDR_OUT, r);
178 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
179 dce_call->fault_code = DCERPC_FAULT_NDR;
180 return NT_STATUS_NET_WRITE_FAULT;
186 const struct dcesrv_interface dcesrv_dcom_Unknown_interface = {
187 .name = "dcom_Unknown",
188 .syntax_id = {{0x18f70770,0x8e64,0x11cf,{0x9a,0xf1},{0x00,0x20,0xaf,0x6e,0x72,0xf4}},0.0},
189 .bind = dcom_Unknown__op_bind,
190 .unbind = dcom_Unknown__op_unbind,
191 .ndr_pull = dcom_Unknown__op_ndr_pull,
192 .dispatch = dcom_Unknown__op_dispatch,
193 .reply = dcom_Unknown__op_reply,
194 .ndr_push = dcom_Unknown__op_ndr_push
198 static NTSTATUS dcom_Unknown__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
202 for (i=0;i<ndr_table_dcom_Unknown.endpoints->count;i++) {
204 const char *name = ndr_table_dcom_Unknown.endpoints->names[i];
206 ret = dcesrv_interface_register(dce_ctx, name, &dcesrv_dcom_Unknown_interface, NULL);
207 if (!NT_STATUS_IS_OK(ret)) {
208 DEBUG(1,("dcom_Unknown_op_init_server: failed to register endpoint '%s'\n",name));
216 static bool dcom_Unknown__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
218 if (dcesrv_dcom_Unknown_interface.syntax_id.if_version == if_version &&
219 GUID_equal(&dcesrv_dcom_Unknown_interface.syntax_id.uuid, uuid)) {
220 memcpy(iface,&dcesrv_dcom_Unknown_interface, sizeof(*iface));
227 static bool dcom_Unknown__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
229 if (strcmp(dcesrv_dcom_Unknown_interface.name, name)==0) {
230 memcpy(iface, &dcesrv_dcom_Unknown_interface, sizeof(*iface));
237 NTSTATUS dcerpc_server_dcom_Unknown_init(void)
240 struct dcesrv_endpoint_server ep_server;
242 /* fill in our name */
243 ep_server.name = "dcom_Unknown";
245 /* fill in all the operations */
246 ep_server.init_server = dcom_Unknown__op_init_server;
248 ep_server.interface_by_uuid = dcom_Unknown__op_interface_by_uuid;
249 ep_server.interface_by_name = dcom_Unknown__op_interface_by_name;
251 /* register ourselves with the DCERPC subsystem. */
252 ret = dcerpc_register_ep_server(&ep_server);
254 if (!NT_STATUS_IS_OK(ret)) {
255 DEBUG(0,("Failed to register 'dcom_Unknown' endpoint server!\n"));
262 NTSTATUS dcerpc_server_IMachineLocalActivator_init(void);
264 /* IMachineLocalActivator - dcerpc server boilerplate generated by pidl */
267 static NTSTATUS IMachineLocalActivator__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
269 #ifdef DCESRV_INTERFACE_IMACHINELOCALACTIVATOR_BIND
270 return DCESRV_INTERFACE_IMACHINELOCALACTIVATOR_BIND(dce_call,iface);
276 static void IMachineLocalActivator__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
278 #ifdef DCESRV_INTERFACE_IMACHINELOCALACTIVATOR_UNBIND
279 DCESRV_INTERFACE_IMACHINELOCALACTIVATOR_UNBIND(context, iface);
285 static NTSTATUS IMachineLocalActivator__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
287 enum ndr_err_code ndr_err;
288 uint16_t opnum = dce_call->pkt.u.request.opnum;
290 dce_call->fault_code = 0;
292 if (opnum >= ndr_table_IMachineLocalActivator.num_calls) {
293 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
294 return NT_STATUS_NET_WRITE_FAULT;
297 *r = talloc_named(mem_ctx,
298 ndr_table_IMachineLocalActivator.calls[opnum].struct_size,
300 ndr_table_IMachineLocalActivator.calls[opnum].name);
301 NT_STATUS_HAVE_NO_MEMORY(*r);
303 /* unravel the NDR for the packet */
304 ndr_err = ndr_table_IMachineLocalActivator.calls[opnum].ndr_pull(pull, NDR_IN, *r);
305 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
306 dcerpc_log_packet(dce_call->conn->packet_log_dir,
307 &ndr_table_IMachineLocalActivator, opnum, NDR_IN,
308 &dce_call->pkt.u.request.stub_and_verifier);
309 dce_call->fault_code = DCERPC_FAULT_NDR;
310 return NT_STATUS_NET_WRITE_FAULT;
316 static NTSTATUS IMachineLocalActivator__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
318 uint16_t opnum = dce_call->pkt.u.request.opnum;
322 struct IMachineLocalActivator_foo *r2 = (struct IMachineLocalActivator_foo *)r;
323 if (DEBUGLEVEL >= 10) {
324 NDR_PRINT_FUNCTION_DEBUG(IMachineLocalActivator_foo, NDR_IN, r2);
326 r2->out.result = dcesrv_IMachineLocalActivator_foo(dce_call, mem_ctx, r2);
327 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
328 DEBUG(5,("function IMachineLocalActivator_foo will reply async\n"));
334 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
338 if (dce_call->fault_code != 0) {
339 dcerpc_log_packet(dce_call->conn->packet_log_dir,
340 &ndr_table_IMachineLocalActivator, opnum, NDR_IN,
341 &dce_call->pkt.u.request.stub_and_verifier);
342 return NT_STATUS_NET_WRITE_FAULT;
348 static NTSTATUS IMachineLocalActivator__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
350 uint16_t opnum = dce_call->pkt.u.request.opnum;
354 struct IMachineLocalActivator_foo *r2 = (struct IMachineLocalActivator_foo *)r;
355 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
356 DEBUG(5,("function IMachineLocalActivator_foo replied async\n"));
358 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
359 NDR_PRINT_FUNCTION_DEBUG(IMachineLocalActivator_foo, NDR_OUT | NDR_SET_VALUES, r2);
361 if (dce_call->fault_code != 0) {
362 DEBUG(2,("dcerpc_fault %s in IMachineLocalActivator_foo\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
368 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
372 if (dce_call->fault_code != 0) {
373 dcerpc_log_packet(dce_call->conn->packet_log_dir,
374 &ndr_table_IMachineLocalActivator, opnum, NDR_IN,
375 &dce_call->pkt.u.request.stub_and_verifier);
376 return NT_STATUS_NET_WRITE_FAULT;
382 static NTSTATUS IMachineLocalActivator__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
384 enum ndr_err_code ndr_err;
385 uint16_t opnum = dce_call->pkt.u.request.opnum;
387 ndr_err = ndr_table_IMachineLocalActivator.calls[opnum].ndr_push(push, NDR_OUT, r);
388 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
389 dce_call->fault_code = DCERPC_FAULT_NDR;
390 return NT_STATUS_NET_WRITE_FAULT;
396 const struct dcesrv_interface dcesrv_IMachineLocalActivator_interface = {
397 .name = "IMachineLocalActivator",
398 .syntax_id = {{0xc6f3ee72,0xce7e,0x11d1,{0xb7,0x1e},{0x00,0xc0,0x4f,0xc3,0x11,0x1a}},0.0},
399 .bind = IMachineLocalActivator__op_bind,
400 .unbind = IMachineLocalActivator__op_unbind,
401 .ndr_pull = IMachineLocalActivator__op_ndr_pull,
402 .dispatch = IMachineLocalActivator__op_dispatch,
403 .reply = IMachineLocalActivator__op_reply,
404 .ndr_push = IMachineLocalActivator__op_ndr_push
408 static NTSTATUS IMachineLocalActivator__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
412 for (i=0;i<ndr_table_IMachineLocalActivator.endpoints->count;i++) {
414 const char *name = ndr_table_IMachineLocalActivator.endpoints->names[i];
416 ret = dcesrv_interface_register(dce_ctx, name, &dcesrv_IMachineLocalActivator_interface, NULL);
417 if (!NT_STATUS_IS_OK(ret)) {
418 DEBUG(1,("IMachineLocalActivator_op_init_server: failed to register endpoint '%s'\n",name));
426 static bool IMachineLocalActivator__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
428 if (dcesrv_IMachineLocalActivator_interface.syntax_id.if_version == if_version &&
429 GUID_equal(&dcesrv_IMachineLocalActivator_interface.syntax_id.uuid, uuid)) {
430 memcpy(iface,&dcesrv_IMachineLocalActivator_interface, sizeof(*iface));
437 static bool IMachineLocalActivator__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
439 if (strcmp(dcesrv_IMachineLocalActivator_interface.name, name)==0) {
440 memcpy(iface, &dcesrv_IMachineLocalActivator_interface, sizeof(*iface));
447 NTSTATUS dcerpc_server_IMachineLocalActivator_init(void)
450 struct dcesrv_endpoint_server ep_server;
452 /* fill in our name */
453 ep_server.name = "IMachineLocalActivator";
455 /* fill in all the operations */
456 ep_server.init_server = IMachineLocalActivator__op_init_server;
458 ep_server.interface_by_uuid = IMachineLocalActivator__op_interface_by_uuid;
459 ep_server.interface_by_name = IMachineLocalActivator__op_interface_by_name;
461 /* register ourselves with the DCERPC subsystem. */
462 ret = dcerpc_register_ep_server(&ep_server);
464 if (!NT_STATUS_IS_OK(ret)) {
465 DEBUG(0,("Failed to register 'IMachineLocalActivator' endpoint server!\n"));
472 NTSTATUS dcerpc_server_ILocalObjectExporter_init(void);
474 /* ILocalObjectExporter - dcerpc server boilerplate generated by pidl */
477 static NTSTATUS ILocalObjectExporter__op_bind(struct dcesrv_call_state *dce_call, const struct dcesrv_interface *iface, uint32_t if_version)
479 #ifdef DCESRV_INTERFACE_ILOCALOBJECTEXPORTER_BIND
480 return DCESRV_INTERFACE_ILOCALOBJECTEXPORTER_BIND(dce_call,iface);
486 static void ILocalObjectExporter__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
488 #ifdef DCESRV_INTERFACE_ILOCALOBJECTEXPORTER_UNBIND
489 DCESRV_INTERFACE_ILOCALOBJECTEXPORTER_UNBIND(context, iface);
495 static NTSTATUS ILocalObjectExporter__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
497 enum ndr_err_code ndr_err;
498 uint16_t opnum = dce_call->pkt.u.request.opnum;
500 dce_call->fault_code = 0;
502 if (opnum >= ndr_table_ILocalObjectExporter.num_calls) {
503 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
504 return NT_STATUS_NET_WRITE_FAULT;
507 *r = talloc_named(mem_ctx,
508 ndr_table_ILocalObjectExporter.calls[opnum].struct_size,
510 ndr_table_ILocalObjectExporter.calls[opnum].name);
511 NT_STATUS_HAVE_NO_MEMORY(*r);
513 /* unravel the NDR for the packet */
514 ndr_err = ndr_table_ILocalObjectExporter.calls[opnum].ndr_pull(pull, NDR_IN, *r);
515 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
516 dcerpc_log_packet(dce_call->conn->packet_log_dir,
517 &ndr_table_ILocalObjectExporter, opnum, NDR_IN,
518 &dce_call->pkt.u.request.stub_and_verifier);
519 dce_call->fault_code = DCERPC_FAULT_NDR;
520 return NT_STATUS_NET_WRITE_FAULT;
526 static NTSTATUS ILocalObjectExporter__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
528 uint16_t opnum = dce_call->pkt.u.request.opnum;
532 struct ILocalObjectExporter_Foo *r2 = (struct ILocalObjectExporter_Foo *)r;
533 if (DEBUGLEVEL >= 10) {
534 NDR_PRINT_FUNCTION_DEBUG(ILocalObjectExporter_Foo, NDR_IN, r2);
536 r2->out.result = dcesrv_ILocalObjectExporter_Foo(dce_call, mem_ctx, r2);
537 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
538 DEBUG(5,("function ILocalObjectExporter_Foo will reply async\n"));
544 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
548 if (dce_call->fault_code != 0) {
549 dcerpc_log_packet(dce_call->conn->packet_log_dir,
550 &ndr_table_ILocalObjectExporter, opnum, NDR_IN,
551 &dce_call->pkt.u.request.stub_and_verifier);
552 return NT_STATUS_NET_WRITE_FAULT;
558 static NTSTATUS ILocalObjectExporter__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
560 uint16_t opnum = dce_call->pkt.u.request.opnum;
564 struct ILocalObjectExporter_Foo *r2 = (struct ILocalObjectExporter_Foo *)r;
565 if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
566 DEBUG(5,("function ILocalObjectExporter_Foo replied async\n"));
568 if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
569 NDR_PRINT_FUNCTION_DEBUG(ILocalObjectExporter_Foo, NDR_OUT | NDR_SET_VALUES, r2);
571 if (dce_call->fault_code != 0) {
572 DEBUG(2,("dcerpc_fault %s in ILocalObjectExporter_Foo\n", dcerpc_errstr(mem_ctx, dce_call->fault_code)));
578 dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
582 if (dce_call->fault_code != 0) {
583 dcerpc_log_packet(dce_call->conn->packet_log_dir,
584 &ndr_table_ILocalObjectExporter, opnum, NDR_IN,
585 &dce_call->pkt.u.request.stub_and_verifier);
586 return NT_STATUS_NET_WRITE_FAULT;
592 static NTSTATUS ILocalObjectExporter__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
594 enum ndr_err_code ndr_err;
595 uint16_t opnum = dce_call->pkt.u.request.opnum;
597 ndr_err = ndr_table_ILocalObjectExporter.calls[opnum].ndr_push(push, NDR_OUT, r);
598 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
599 dce_call->fault_code = DCERPC_FAULT_NDR;
600 return NT_STATUS_NET_WRITE_FAULT;
606 const struct dcesrv_interface dcesrv_ILocalObjectExporter_interface = {
607 .name = "ILocalObjectExporter",
608 .syntax_id = {{0xe60c73e6,0x88f9,0x11cf,{0x9a,0xf1},{0x00,0x20,0xaf,0x6e,0x72,0xf4}},0.0},
609 .bind = ILocalObjectExporter__op_bind,
610 .unbind = ILocalObjectExporter__op_unbind,
611 .ndr_pull = ILocalObjectExporter__op_ndr_pull,
612 .dispatch = ILocalObjectExporter__op_dispatch,
613 .reply = ILocalObjectExporter__op_reply,
614 .ndr_push = ILocalObjectExporter__op_ndr_push
618 static NTSTATUS ILocalObjectExporter__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
622 for (i=0;i<ndr_table_ILocalObjectExporter.endpoints->count;i++) {
624 const char *name = ndr_table_ILocalObjectExporter.endpoints->names[i];
626 ret = dcesrv_interface_register(dce_ctx, name, &dcesrv_ILocalObjectExporter_interface, NULL);
627 if (!NT_STATUS_IS_OK(ret)) {
628 DEBUG(1,("ILocalObjectExporter_op_init_server: failed to register endpoint '%s'\n",name));
636 static bool ILocalObjectExporter__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
638 if (dcesrv_ILocalObjectExporter_interface.syntax_id.if_version == if_version &&
639 GUID_equal(&dcesrv_ILocalObjectExporter_interface.syntax_id.uuid, uuid)) {
640 memcpy(iface,&dcesrv_ILocalObjectExporter_interface, sizeof(*iface));
647 static bool ILocalObjectExporter__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
649 if (strcmp(dcesrv_ILocalObjectExporter_interface.name, name)==0) {
650 memcpy(iface, &dcesrv_ILocalObjectExporter_interface, sizeof(*iface));
657 NTSTATUS dcerpc_server_ILocalObjectExporter_init(void)
660 struct dcesrv_endpoint_server ep_server;
662 /* fill in our name */
663 ep_server.name = "ILocalObjectExporter";
665 /* fill in all the operations */
666 ep_server.init_server = ILocalObjectExporter__op_init_server;
668 ep_server.interface_by_uuid = ILocalObjectExporter__op_interface_by_uuid;
669 ep_server.interface_by_name = ILocalObjectExporter__op_interface_by_name;
671 /* register ourselves with the DCERPC subsystem. */
672 ret = dcerpc_register_ep_server(&ep_server);
674 if (!NT_STATUS_IS_OK(ret)) {
675 DEBUG(0,("Failed to register 'ILocalObjectExporter' endpoint server!\n"));