source4 smdb: Add a post fork hook to the service API
[kai/samba-autobuild/.git] / source4 / smbd / process_model.h
1 /* 
2    Unix SMB/CIFS implementation.
3
4    process model manager - structures
5
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
9    
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.
14    
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.
19    
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/>.
22 */
23
24 #ifndef __PROCESS_MODEL_H__
25 #define __PROCESS_MODEL_H__
26
27 #include "lib/socket/socket.h"
28 #include "smbd/service.h"
29 #include "smbd/process_model_proto.h"
30
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.
34  */
35 /* version 1 - initial version - metze */
36 #define PROCESS_MODEL_VERSION 1
37
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;
43
44         /* called at startup when the model is selected */
45         void (*model_init)(void);
46
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 *, void *),
55                                   void *, void *);
56
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                          struct task_server * (*)(struct tevent_context *,
62                                   struct loadparm_context *, struct server_id, 
63                                   void *, void *),
64                          void *,
65                          const struct service_details*,
66                          const int);
67
68         /* function to terminate a connection or task */
69         void (*terminate)(struct tevent_context *,
70                           struct loadparm_context *lp_ctx,
71                           const char *reason,
72                           void * process_context);
73
74         /* function to set a title for the connection or task */
75         void (*set_title)(struct tevent_context *, const char *title);
76 };
77
78 /* this structure is used by modules to determine the size of some critical types */
79 struct process_model_critical_sizes {
80         int interface_version;
81         int sizeof_model_ops;
82 };
83
84 extern const struct model_ops single_ops;
85
86 const struct model_ops *process_model_startup(const char *model);
87 NTSTATUS register_process_model(const struct model_ops *ops);
88 NTSTATUS process_model_init(struct loadparm_context *lp_ctx);
89
90 #endif /* __PROCESS_MODEL_H__ */