g_lock: Make g_lock_record_store also store userdata
[Samba.git] / source4 / smbd / process_model.h
blob4399d3689fbe16ec9edb58027ce7b3ce72789ab9
1 /*
2 Unix SMB/CIFS implementation.
4 process model manager - structures
6 Copyright (C) Andrew Tridgell 1992-2005
7 Copyright (C) James J Myers 2003 <myersjj@samba.org>
8 Copyright (C) Stefan (metze) Metzmacher 2004-2005
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 3 of the License, or
13 (at your option) any later version.
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
20 You should have received a copy of the GNU General Public License
21 along with this program. If not, see <http://www.gnu.org/licenses/>.
24 #ifndef __PROCESS_MODEL_H__
25 #define __PROCESS_MODEL_H__
27 #include "lib/socket/socket.h"
28 #include "smbd/service.h"
29 #include "smbd/process_model_proto.h"
31 /* modules can use the following to determine if the interface has changed
32 * please increment the version number after each interface change
33 * with a comment and maybe update struct process_model_critical_sizes.
35 /* version 1 - initial version - metze */
36 #define PROCESS_MODEL_VERSION 1
38 /* the process model operations structure - contains function pointers to
39 the model-specific implementations of each operation */
40 struct model_ops {
41 /* the name of the process_model */
42 const char *name;
44 /* called at startup when the model is selected */
45 void (*model_init)(void);
47 /* function to accept new connection */
48 void (*accept_connection)(struct tevent_context *,
49 struct loadparm_context *,
50 struct socket_context *,
51 void (*)(struct tevent_context *,
52 struct loadparm_context *,
53 struct socket_context *,
54 struct server_id , void *),
55 void *);
57 /* function to create a task */
58 void (*new_task)(struct tevent_context *,
59 struct loadparm_context *lp_ctx,
60 const char *service_name,
61 void (*)(struct tevent_context *,
62 struct loadparm_context *, struct server_id,
63 void *),
64 void *);
66 /* function to terminate a connection or task */
67 void (*terminate)(struct tevent_context *, struct loadparm_context *lp_ctx,
68 const char *reason);
70 /* function to set a title for the connection or task */
71 void (*set_title)(struct tevent_context *, const char *title);
74 /* this structure is used by modules to determine the size of some critical types */
75 struct process_model_critical_sizes {
76 int interface_version;
77 int sizeof_model_ops;
80 extern const struct model_ops single_ops;
82 const struct model_ops *process_model_startup(const char *model);
83 NTSTATUS register_process_model(const struct model_ops *ops);
84 NTSTATUS process_model_init(struct loadparm_context *lp_ctx);
86 #endif /* __PROCESS_MODEL_H__ */