2 * Unix SMB/CIFS implementation.
6 * Copyright (c) 2015 Ralph Boehme <slow@samba.org>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 3 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, see <http://www.gnu.org/licenses/>.
23 #include "rpc_server/rpc_modules.h"
25 static struct rpc_module
*rpc_modules
;
28 struct rpc_module
*prev
, *next
;
30 struct rpc_module_fns
*fns
;
33 static struct rpc_module
*find_rpc_module(const char *name
)
35 struct rpc_module
*module
= NULL
;
37 for (module
= rpc_modules
; module
!= NULL
; module
= module
->next
) {
38 if (strequal(module
->name
, name
)) {
46 NTSTATUS
register_rpc_module(struct rpc_module_fns
*fns
,
49 struct rpc_module
*module
= find_rpc_module(name
);
52 DBG_ERR("RPC module %s already loaded!\n", name
);
53 return NT_STATUS_OBJECT_NAME_COLLISION
;
56 module
= SMB_XMALLOC_P(struct rpc_module
);
57 module
->name
= smb_xstrdup(name
);
60 DLIST_ADD(rpc_modules
, module
);
61 DBG_NOTICE("Successfully added RPC module '%s'\n", name
);
66 bool setup_rpc_module(struct tevent_context
*ev_ctx
,
67 struct messaging_context
*msg_ctx
,
71 struct rpc_module
*module
= find_rpc_module(name
);
77 ok
= module
->fns
->setup(ev_ctx
, msg_ctx
);
79 DBG_ERR("calling setup for %s failed\n", name
);
85 bool setup_rpc_modules(struct tevent_context
*ev_ctx
,
86 struct messaging_context
*msg_ctx
)
89 struct rpc_module
*module
= rpc_modules
;
91 for (module
= rpc_modules
; module
; module
= module
->next
) {
92 ok
= module
->fns
->setup(ev_ctx
, msg_ctx
);
94 DBG_ERR("calling setup for %s failed\n", module
->name
);
101 bool init_rpc_module(const char *name
,
102 const struct rpc_srv_callbacks
*rpc_srv_cb
)
104 struct rpc_module
*module
= find_rpc_module(name
);
107 if (module
== NULL
) {
111 status
= module
->fns
->init(rpc_srv_cb
);
112 if (!NT_STATUS_IS_OK(status
)) {
113 DBG_ERR("calling init for %s failed %s\n",
114 name
, nt_errstr(status
));
121 bool shutdown_rpc_module(const char *name
)
123 struct rpc_module
*module
= find_rpc_module(name
);
126 if (module
== NULL
) {
130 status
= module
->fns
->shutdown();
131 if (!NT_STATUS_IS_OK(status
)) {
132 DBG_ERR("calling shutdown for %s failed %s\n",
133 name
, nt_errstr(status
));