📄 service.c
字号:
/* Unix SMB/CIFS implementation. SERVER SERVICE code Copyright (C) Andrew Tridgell 2003-2005 Copyright (C) Stefan (metze) Metzmacher 2004 This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>.*/#include "includes.h"#include "lib/util/dlinklist.h"#include "smbd/process_model.h"/* a linked list of registered servers*/static struct registered_server { struct registered_server *next, *prev; const char *service_name; void (*task_init)(struct task_server *);} *registered_servers;/* register a server service. */NTSTATUS register_server_service(const char *name, void (*task_init)(struct task_server *)){ struct registered_server *srv; srv = talloc(talloc_autofree_context(), struct registered_server); NT_STATUS_HAVE_NO_MEMORY(srv); srv->service_name = name; srv->task_init = task_init; DLIST_ADD_END(registered_servers, srv, struct registered_server *); return NT_STATUS_OK;}/* initialise a server service*/static NTSTATUS server_service_init(const char *name, struct event_context *event_context, struct loadparm_context *lp_ctx, const struct model_ops *model_ops){ struct registered_server *srv; for (srv=registered_servers; srv; srv=srv->next) { if (strcasecmp(name, srv->service_name) == 0) { return task_server_startup(event_context, lp_ctx, srv->service_name, model_ops, srv->task_init); } } return NT_STATUS_INVALID_SYSTEM_SERVICE;}/* startup all of our server services*/NTSTATUS server_service_startup(struct event_context *event_ctx, struct loadparm_context *lp_ctx, const char *model, const char **server_services){ int i; const struct model_ops *model_ops; if (!server_services) { DEBUG(0,("server_service_startup: no endpoint servers configured\n")); return NT_STATUS_INVALID_PARAMETER; } model_ops = process_model_startup(event_ctx, model); if (!model_ops) { DEBUG(0,("process_model_startup('%s') failed\n", model)); return NT_STATUS_INTERNAL_ERROR; } for (i=0;server_services[i];i++) { NTSTATUS status; status = server_service_init(server_services[i], event_ctx, lp_ctx, model_ops); if (!NT_STATUS_IS_OK(status)) { DEBUG(0,("Failed to start service '%s' - %s\n", server_services[i], nt_errstr(status))); } NT_STATUS_NOT_OK_RETURN(status); } return NT_STATUS_OK;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -