2 Unix SMB/CIFS implementation.
6 Copyright (C) Andrew Tridgell 2003-2005
7 Copyright (C) Stefan (metze) Metzmacher 2004
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>.
24 #include "lib/util/dlinklist.h"
25 #include "smbd/process_model.h"
28 a linked list of registered servers
30 static struct registered_server {
31 struct registered_server *next, *prev;
32 const char *service_name;
33 NTSTATUS (*service_init)(struct event_context *, const struct model_ops *);
34 } *registered_servers;
37 register a server service.
39 NTSTATUS register_server_service(const char *name,
40 NTSTATUS (*service_init)(struct event_context *, const struct model_ops *))
42 struct registered_server *srv;
43 srv = talloc(talloc_autofree_context(), struct registered_server);
44 NT_STATUS_HAVE_NO_MEMORY(srv);
45 srv->service_name = name;
46 srv->service_init = service_init;
47 DLIST_ADD_END(registered_servers, srv, struct registered_server *);
53 initialise a server service
55 static NTSTATUS server_service_init(const char *name,
56 struct event_context *event_ctx,
57 const struct model_ops *model_ops)
59 struct registered_server *srv;
60 for (srv=registered_servers; srv; srv=srv->next) {
61 if (strcasecmp(name, srv->service_name) == 0) {
62 return srv->service_init(event_ctx, model_ops);
65 return NT_STATUS_INVALID_SYSTEM_SERVICE;
70 startup all of our server services
72 NTSTATUS server_service_startup(struct event_context *event_ctx,
73 const char *model, const char **server_services)
76 const struct model_ops *model_ops;
78 if (!server_services) {
79 DEBUG(0,("server_service_startup: no endpoint servers configured\n"));
80 return NT_STATUS_INVALID_PARAMETER;
83 model_ops = process_model_startup(event_ctx, model);
85 DEBUG(0,("process_model_startup('%s') failed\n", model));
86 return NT_STATUS_INTERNAL_ERROR;
89 for (i=0;server_services[i];i++) {
92 status = server_service_init(server_services[i], event_ctx, model_ops);
93 if (!NT_STATUS_IS_OK(status)) {
94 DEBUG(0,("Failed to start service '%s' - %s\n",
95 server_services[i], nt_errstr(status)));
97 NT_STATUS_NOT_OK_RETURN(status);