1 /************************************************************************
2 * IRC - Internet Relay Chat, doc/example_module.c
3 * Copyright (C) 2001 Hybrid Development Team
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 1, or (at your option)
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 /* List of ircd includes from ../include/ */
28 /* Declare the void's initially up here, as modules dont have an
29 * include file, we will normally have client_p, source_p, parc
32 * client_p == client issuing command
33 * source_p == where the command came from
34 * parc == the number of parameters
35 * parv == an array of the parameters
38 static int munreg_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[]);
39 static int mclient_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[]);
40 static int mserver_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[]);
41 static int mrclient_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[]);
42 static int moper_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[]);
44 /* Show the commands this module can handle in a msgtab
45 * and give the msgtab a name, here its test_msgtab
48 struct Message test_msgtab
= {
49 "TEST", /* the /COMMAND you want */
50 0, /* SET TO ZERO -- number of times command used by clients */
51 0, /* SET TO ZERO -- number of times command used by clients */
52 0, /* SET TO ZERO -- number of times command used by clients */
53 0, /* ALWAYS SET TO 0 */
55 /* the functions to call for each handler. If not using the generic
56 * handlers, the first param is the function to call, the second is the
57 * required number of parameters. NOTE: If you specify a min para of 2,
58 * then parv[1] must *also* be non-empty.
61 {munreg_test
, 0}, /* function call for unregistered clients, 0 parms required */
62 {mclient_test
, 0}, /* function call for local clients, 0 parms required */
63 {mrclient_test
, 0}, /* function call for remote clients, 0 parms required */
64 {mserver_test
, 0}, /* function call for servers, 0 parms required */
65 mg_ignore
, /* function call for ENCAP, unused in this test */
66 {moper_test
, 0} /* function call for operators, 0 parms required */
70 * There are also some macros for the above function calls and parameter counts.
73 * mg_ignore: ignore the command when it comes from certain types
74 * mg_not_oper: tell the client it requires being an operator
75 * mg_reg: prevent the client using this if registered
76 * mg_unreg: prevent the client using this if unregistered
78 * These macros assume a parameter count of zero; you do not set it.
79 * For further details, see include/msg.h
83 /* The mapi_clist_av1 indicates which commands (struct Message)
84 * should be loaded from the module. The list should be terminated
87 mapi_clist_av1 test_clist
[] = { &test_msgtab
, NULL
};
89 /* The mapi_hlist_av1 indicates which hook functions we need to be able to
90 * call. We need to declare an integer, then add the name of the hook
91 * function to call and a pointer to this integer. The list should be
92 * terminated with NULLs.
94 int doing_example_hook
;
95 mapi_hlist_av1 test_hlist
[] = {
96 { "doing_example_hook", &doing_example_hook
, },
100 /* The mapi_hfn_list_av1 declares the hook functions which other modules can
101 * call. The first parameter is the name of the hook, the second is a void
102 * returning function, with arbitrary parameters casted to (hookfn). This
103 * list must be terminated with NULLs.
105 static void show_example_hook(void *unused
);
107 mapi_hfn_list_av1 test_hfnlist
[] = {
108 { "doing_example_hook", (hookfn
) show_example_hook
},
112 /* The mapi_cap_list_av2 declares the capabilities this module adds. This is
113 * for protocol usage. Here we declare both server and client capabilities.
114 * The first parameter is the cap type (server or client). The second is the
115 * name of the capability we wish to register. The third is the data attached
116 * to the cap (typically NULL). The last parameter is a pointer to an integer
117 * for the CAP index (recommended).
119 unsigned int CAP_TESTCAP_SERVER
, CAP_TESTCAP_CLIENT
;
120 mapi_cap_list_av2 test_cap_list
[] = {
121 { MAPI_CAP_SERVER
, "TESTCAP", NULL
, &CAP_TESTCAP_SERVER
},
122 { MAPI_CAP_CLIENT
, "testcap", NULL
, &CAP_TESTCAP_CLIENT
},
123 { 0, NULL
, NULL
, NULL
}
126 /* Here we tell it what to do when the module is loaded */
130 /* Nothing to do for the example module. */
131 /* The init function should return -1 on failure,
132 which will cause the module to be unloaded,
133 otherwise 0 to indicate success. */
137 /* here we tell it what to do when the module is unloaded */
141 /* Again, nothing to do. */
144 /* DECLARE_MODULE_AV2() actually declare the MAPI header. */
146 /* The first argument is the name */
148 /* The second argument is the function to call on load */
150 /* And the function to call on unload */
152 /* Then the MAPI command list */
154 /* Next the hook list, if we have one. */
156 /* Then the hook function list, if we have one */
158 /* Then the caps list, if we have one */
160 /* Then the version number of this module (NULL for bundled) */
162 /* And finally, the description of this module */
163 "This is an example module");
165 /* Any of the above arguments can be NULL to indicate they aren't used. */
170 * parv[1] = parameter
173 /* Here we have the functions themselves that we declared above,
174 * and the fairly normal C coding
177 munreg_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
181 sendto_one_notice(source_p
, ":You are unregistered and sent no parameters");
185 sendto_one_notice(source_p
, ":You are unregistered and sent parameter: %s", parv
[1]);
188 /* illustration of how to call a hook function */
189 call_hook(doing_example_hook
, NULL
);
196 * parv[1] = parameter
199 mclient_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
203 sendto_one_notice(source_p
, ":You are a normal user, and sent no parameters");
207 sendto_one_notice(source_p
, ":You are a normal user, and send parameters: %s", parv
[1]);
210 /* illustration of how to call a hook function */
211 call_hook(doing_example_hook
, NULL
);
218 * parv[1] = parameter
221 mrclient_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
225 sendto_one_notice(source_p
, ":You are a remote client, and sent no parameters");
229 sendto_one_notice(source_p
, ":You are a remote client, and sent parameters: %s", parv
[1]);
236 * parv[1] = parameter
239 mserver_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
243 sendto_one_notice(source_p
, ":You are a server, and sent no parameters");
247 sendto_one_notice(source_p
, ":You are a server, and sent parameters: %s", parv
[1]);
254 * parv[1] = parameter
257 moper_test(struct MsgBuf
*msgbuf_p
, struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
261 sendto_one_notice(source_p
, ":You are an operator, and sent no parameters");
265 sendto_one_notice(source_p
, ":You are an operator, and sent parameters: %s", parv
[1]);
271 show_example_hook(void *unused
)
273 sendto_realops_snomask(SNO_GENERAL
, L_ALL
, "Called example hook!");
276 /* END OF EXAMPLE MODULE */