]> jfr.im git - solanum.git/blob - include/modules.h
Merge pull request #330 from edk0/caps-before-init
[solanum.git] / include / modules.h
1 /*
2 * ircd-ratbox: A slightly useful ircd.
3 * modules.h: A header for the modules functions.
4 *
5 * Copyright (C) 1990 Jarkko Oikarinen and University of Oulu, Co Center
6 * Copyright (C) 1996-2002 Hybrid Development Team
7 * Copyright (C) 2002-2004 ircd-ratbox development team
8 *
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 2 of the License, or
12 * (at your option) any later version.
13 *
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.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
22 * USA
23 */
24
25 #ifndef INCLUDED_modules_h
26 #define INCLUDED_modules_h
27 #include "serno.h"
28 #include "defaults.h"
29 #include "setup.h"
30 #include "parse.h"
31 #include "client.h" /* for IDLEN */
32
33 #define MAPI_CHARYBDIS 2
34
35 #include <ltdl.h>
36
37 #include "msg.h"
38 #include "hook.h"
39
40 struct module
41 {
42 char *name;
43 const char *version;
44 const char *description;
45 lt_dlhandle address;
46 int core; /* This is int for backwards compat reasons */
47 int origin; /* Ditto */
48 int mapi_version;
49 void *mapi_header; /* actually struct mapi_mheader_av<mapi_version> */
50 rb_dlink_node node;
51 };
52
53 #define MAPI_MAGIC_HDR 0x4D410000
54
55 #define MAPI_V1 (MAPI_MAGIC_HDR | 0x1)
56 #define MAPI_V2 (MAPI_MAGIC_HDR | 0x2)
57
58 #define MAPI_MAGIC(x) ((x) & 0xffff0000)
59 #define MAPI_VERSION(x) ((x) & 0x0000ffff)
60
61 typedef struct Message* mapi_clist_av1;
62
63 typedef struct
64 {
65 const char *hapi_name;
66 int *hapi_id;
67 } mapi_hlist_av1;
68
69 typedef struct
70 {
71 const char *hapi_name;
72 hookfn fn;
73 enum hook_priority priority;
74 } mapi_hfn_list_av1;
75
76 #define MAPI_CAP_CLIENT 1
77 #define MAPI_CAP_SERVER 2
78
79 typedef struct
80 {
81 int cap_index; /* Which cap index does this belong to? */
82 const char *cap_name; /* Capability name */
83 void *cap_ownerdata; /* Not used much but why not... */
84 unsigned int *cap_id; /* May be set to non-NULL to store cap id */
85 } mapi_cap_list_av2;
86
87 struct mapi_mheader_av1
88 {
89 int mapi_version; /* Module API version */
90 int (*mapi_register)(void); /* Register function; ret -1 = failure (unload) */
91 void (*mapi_unregister)(void); /* Unregister function. */
92 mapi_clist_av1 *mapi_command_list; /* List of commands to add. */
93 mapi_hlist_av1 *mapi_hook_list; /* List of hooks to add. */
94 mapi_hfn_list_av1 *mapi_hfn_list; /* List of hook_add_hook's to do */
95 const char *mapi_module_version; /* Module's version (freeform) */
96 };
97
98 #define MAPI_ORIGIN_UNKNOWN 0 /* Unknown provenance (AV1 etc.) */
99 #define MAPI_ORIGIN_EXTENSION 1 /* Charybdis extension */
100 #define MAPI_ORIGIN_CORE 2 /* Charybdis core module */
101
102 struct mapi_mheader_av2
103 {
104 int mapi_version; /* Module API version */
105 int (*mapi_register)(void); /* Register function; ret -1 = failure (unload) */
106 void (*mapi_unregister)(void); /* Unregister function. */
107 mapi_clist_av1 *mapi_command_list; /* List of commands to add. */
108 mapi_hlist_av1 *mapi_hook_list; /* List of hooks to add. */
109 mapi_hfn_list_av1 *mapi_hfn_list; /* List of hook_add_hook's to do */
110 mapi_cap_list_av2 *mapi_cap_list; /* List of CAPs to add */
111 const char *mapi_module_version; /* Module's version (freeform), replaced with ircd version if NULL */
112 const char *mapi_module_description; /* Module's description (freeform) */
113 unsigned long int mapi_datecode; /* Unix timestamp of module's build */
114 };
115
116 #define DECLARE_MODULE_AV1(name, reg, unreg, cl, hl, hfnlist, v) \
117 struct mapi_mheader_av1 _mheader = { MAPI_V1, reg, unreg, cl, hl, hfnlist, v}
118
119 #define DECLARE_MODULE_AV2(name, reg, unreg, cl, hl, hfnlist, caplist, v, desc) \
120 struct mapi_mheader_av2 _mheader = { MAPI_V2, reg, unreg, cl, hl, hfnlist, caplist, v, desc, DATECODE}
121
122 struct modreload
123 {
124 char module[BUFSIZE];
125 char id[IDLEN];
126 };
127
128 /* add a path */
129 void mod_add_path(const char *path);
130 void mod_clear_paths(void);
131
132 /* cap-notify utilities */
133 extern void mod_remember_clicaps(void);
134 extern void mod_notify_clicaps(void);
135
136 /* load a module */
137 extern void load_module(char *path);
138
139 /* load all modules */
140 extern void load_all_modules(bool warn);
141
142 /* load core modules */
143 extern void load_core_modules(bool);
144
145 extern bool unload_one_module(const char *, bool);
146 extern bool load_one_module(const char *, int, bool);
147 extern bool load_a_module(const char *, bool, int, bool);
148 extern struct module *findmodule_byname(const char *);
149 extern void init_modules(void);
150
151 extern rb_dlink_list module_list;
152 extern rb_dlink_list mod_paths;
153
154 #endif /* INCLUDED_modules_h */