2007-01-25 06:40:21 +00:00
|
|
|
/************************************************************************
|
|
|
|
* IRC - Internet Relay Chat, doc/example_module.c
|
|
|
|
* Copyright (C) 2001 Hybrid Development Team
|
|
|
|
*
|
|
|
|
* 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 1, 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, write to the Free Software
|
|
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* List of ircd includes from ../include/ */
|
|
|
|
#include "stdinc.h"
|
|
|
|
#include "modules.h"
|
|
|
|
#include "hook.h"
|
|
|
|
#include "client.h"
|
|
|
|
#include "ircd.h"
|
|
|
|
#include "send.h"
|
|
|
|
|
2016-03-09 07:29:41 +00:00
|
|
|
/* This string describes the module. Always declare it a static const char[].
|
|
|
|
* It is preferred for stylistic reasons to put it first.
|
|
|
|
*
|
|
|
|
* Make it short, sweet, and to the point.
|
|
|
|
*/
|
2020-10-15 14:51:12 +00:00
|
|
|
static const char example_desc[] = "This is an example Solanum module.";
|
2016-03-09 07:29:41 +00:00
|
|
|
|
2007-01-25 06:40:21 +00:00
|
|
|
/* Declare the void's initially up here, as modules dont have an
|
|
|
|
* include file, we will normally have client_p, source_p, parc
|
|
|
|
* and parv[] where:
|
|
|
|
*
|
|
|
|
* client_p == client issuing command
|
|
|
|
* source_p == where the command came from
|
|
|
|
* parc == the number of parameters
|
|
|
|
* parv == an array of the parameters
|
|
|
|
*/
|
|
|
|
|
2016-03-09 07:37:03 +00:00
|
|
|
static void munreg_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
|
|
|
|
static void mclient_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
|
|
|
|
static void mserver_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
|
|
|
|
static void mrclient_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
|
|
|
|
static void moper_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
|
2007-01-25 06:40:21 +00:00
|
|
|
|
|
|
|
/* Show the commands this module can handle in a msgtab
|
|
|
|
* and give the msgtab a name, here its test_msgtab
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct Message test_msgtab = {
|
2016-03-09 07:29:41 +00:00
|
|
|
"TEST", /* the /COMMAND you want */
|
|
|
|
0, /* SET TO ZERO -- number of times command used by clients */
|
|
|
|
0, /* SET TO ZERO -- number of times command used by clients */
|
|
|
|
0, /* SET TO ZERO -- number of times command used by clients */
|
|
|
|
0, /* ALWAYS SET TO 0 */
|
|
|
|
|
|
|
|
/* the functions to call for each handler. If not using the generic
|
|
|
|
* handlers, the first param is the function to call, the second is the
|
|
|
|
* required number of parameters. NOTE: If you specify a min para of 2,
|
|
|
|
* then parv[1] must *also* be non-empty.
|
|
|
|
*/
|
|
|
|
{
|
|
|
|
{munreg_test, 0}, /* function call for unregistered clients, 0 parms required */
|
|
|
|
{mclient_test, 0}, /* function call for local clients, 0 parms required */
|
|
|
|
{mrclient_test, 0}, /* function call for remote clients, 0 parms required */
|
|
|
|
{mserver_test, 0}, /* function call for servers, 0 parms required */
|
|
|
|
mg_ignore, /* function call for ENCAP, unused in this test */
|
|
|
|
{moper_test, 0} /* function call for operators, 0 parms required */
|
|
|
|
}
|
2007-01-25 06:40:21 +00:00
|
|
|
};
|
|
|
|
/*
|
|
|
|
* There are also some macros for the above function calls and parameter counts.
|
|
|
|
* Here's a list:
|
|
|
|
*
|
|
|
|
* mg_ignore: ignore the command when it comes from certain types
|
|
|
|
* mg_not_oper: tell the client it requires being an operator
|
|
|
|
* mg_reg: prevent the client using this if registered
|
|
|
|
* mg_unreg: prevent the client using this if unregistered
|
|
|
|
*
|
|
|
|
* These macros assume a parameter count of zero; you do not set it.
|
|
|
|
* For further details, see include/msg.h
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/* The mapi_clist_av1 indicates which commands (struct Message)
|
|
|
|
* should be loaded from the module. The list should be terminated
|
|
|
|
* by a NULL.
|
|
|
|
*/
|
|
|
|
mapi_clist_av1 test_clist[] = { &test_msgtab, NULL };
|
|
|
|
|
|
|
|
/* The mapi_hlist_av1 indicates which hook functions we need to be able to
|
|
|
|
* call. We need to declare an integer, then add the name of the hook
|
|
|
|
* function to call and a pointer to this integer. The list should be
|
|
|
|
* terminated with NULLs.
|
|
|
|
*/
|
|
|
|
int doing_example_hook;
|
2014-03-03 04:25:47 +00:00
|
|
|
mapi_hlist_av1 test_hlist[] = {
|
2007-01-25 06:40:21 +00:00
|
|
|
{ "doing_example_hook", &doing_example_hook, },
|
|
|
|
{ NULL, NULL }
|
|
|
|
};
|
|
|
|
|
|
|
|
/* The mapi_hfn_list_av1 declares the hook functions which other modules can
|
|
|
|
* call. The first parameter is the name of the hook, the second is a void
|
|
|
|
* returning function, with arbitrary parameters casted to (hookfn). This
|
|
|
|
* list must be terminated with NULLs.
|
|
|
|
*/
|
|
|
|
static void show_example_hook(void *unused);
|
|
|
|
|
|
|
|
mapi_hfn_list_av1 test_hfnlist[] = {
|
|
|
|
{ "doing_example_hook", (hookfn) show_example_hook },
|
|
|
|
{ NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2016-03-07 07:27:57 +00:00
|
|
|
/* The mapi_cap_list_av2 declares the capabilities this module adds. This is
|
|
|
|
* for protocol usage. Here we declare both server and client capabilities.
|
|
|
|
* The first parameter is the cap type (server or client). The second is the
|
|
|
|
* name of the capability we wish to register. The third is the data attached
|
|
|
|
* to the cap (typically NULL). The last parameter is a pointer to an integer
|
|
|
|
* for the CAP index (recommended).
|
|
|
|
*/
|
|
|
|
unsigned int CAP_TESTCAP_SERVER, CAP_TESTCAP_CLIENT;
|
|
|
|
mapi_cap_list_av2 test_cap_list[] = {
|
|
|
|
{ MAPI_CAP_SERVER, "TESTCAP", NULL, &CAP_TESTCAP_SERVER },
|
|
|
|
{ MAPI_CAP_CLIENT, "testcap", NULL, &CAP_TESTCAP_CLIENT },
|
|
|
|
{ 0, NULL, NULL, NULL }
|
2016-03-07 07:35:35 +00:00
|
|
|
};
|
2016-03-07 07:27:57 +00:00
|
|
|
|
2007-01-25 06:40:21 +00:00
|
|
|
/* Here we tell it what to do when the module is loaded */
|
|
|
|
static int
|
|
|
|
modinit(void)
|
|
|
|
{
|
|
|
|
/* Nothing to do for the example module. */
|
|
|
|
/* The init function should return -1 on failure,
|
|
|
|
which will cause the module to be unloaded,
|
|
|
|
otherwise 0 to indicate success. */
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* here we tell it what to do when the module is unloaded */
|
|
|
|
static void
|
|
|
|
moddeinit(void)
|
|
|
|
{
|
|
|
|
/* Again, nothing to do. */
|
|
|
|
}
|
|
|
|
|
2016-03-07 07:27:57 +00:00
|
|
|
/* DECLARE_MODULE_AV2() actually declare the MAPI header. */
|
|
|
|
DECLARE_MODULE_AV2(
|
2016-03-09 07:29:41 +00:00
|
|
|
/* The first argument is the name */
|
|
|
|
example,
|
|
|
|
/* The second argument is the function to call on load */
|
|
|
|
modinit,
|
|
|
|
/* And the function to call on unload */
|
|
|
|
moddeinit,
|
|
|
|
/* Then the MAPI command list */
|
|
|
|
test_clist,
|
|
|
|
/* Next the hook list, if we have one. */
|
|
|
|
test_hlist,
|
|
|
|
/* Then the hook function list, if we have one */
|
|
|
|
test_hfnlist,
|
|
|
|
/* Then the caps list, if we have one */
|
|
|
|
test_cap_list,
|
|
|
|
/* Then the version number of this module (NULL for bundled) */
|
|
|
|
NULL,
|
|
|
|
/* And finally, the description of this module */
|
|
|
|
example_desc);
|
2007-01-25 06:40:21 +00:00
|
|
|
|
|
|
|
/* Any of the above arguments can be NULL to indicate they aren't used. */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mr_test
|
|
|
|
* parv[1] = parameter
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Here we have the functions themselves that we declared above,
|
|
|
|
* and the fairly normal C coding
|
|
|
|
*/
|
2016-03-09 07:37:03 +00:00
|
|
|
static void
|
2016-02-11 02:14:22 +00:00
|
|
|
munreg_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
|
2007-01-25 06:40:21 +00:00
|
|
|
{
|
|
|
|
if(parc < 2)
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are unregistered and sent no parameters");
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are unregistered and sent parameter: %s", parv[1]);
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* illustration of how to call a hook function */
|
|
|
|
call_hook(doing_example_hook, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mclient_test
|
|
|
|
* parv[1] = parameter
|
|
|
|
*/
|
2016-03-09 07:37:03 +00:00
|
|
|
static void
|
2016-02-11 02:14:22 +00:00
|
|
|
mclient_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
|
2007-01-25 06:40:21 +00:00
|
|
|
{
|
|
|
|
if(parc < 2)
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a normal user, and sent no parameters");
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a normal user, and send parameters: %s", parv[1]);
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* illustration of how to call a hook function */
|
|
|
|
call_hook(doing_example_hook, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mrclient_test
|
|
|
|
* parv[1] = parameter
|
|
|
|
*/
|
2016-03-09 07:37:03 +00:00
|
|
|
static void
|
2016-02-11 02:14:22 +00:00
|
|
|
mrclient_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
|
2007-01-25 06:40:21 +00:00
|
|
|
{
|
|
|
|
if(parc < 2)
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a remote client, and sent no parameters");
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a remote client, and sent parameters: %s", parv[1]);
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mserver_test
|
|
|
|
* parv[1] = parameter
|
|
|
|
*/
|
2016-03-09 07:37:03 +00:00
|
|
|
static void
|
2016-02-11 02:14:22 +00:00
|
|
|
mserver_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
|
2007-01-25 06:40:21 +00:00
|
|
|
{
|
|
|
|
if(parc < 2)
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a server, and sent no parameters");
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are a server, and sent parameters: %s", parv[1]);
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* moper_test
|
|
|
|
* parv[1] = parameter
|
|
|
|
*/
|
2016-03-09 07:37:03 +00:00
|
|
|
static void
|
2016-02-11 02:14:22 +00:00
|
|
|
moper_test(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
|
2007-01-25 06:40:21 +00:00
|
|
|
{
|
|
|
|
if(parc < 2)
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are an operator, and sent no parameters");
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2007-01-25 07:23:01 +00:00
|
|
|
sendto_one_notice(source_p, ":You are an operator, and sent parameters: %s", parv[1]);
|
2007-01-25 06:40:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
show_example_hook(void *unused)
|
|
|
|
{
|
|
|
|
sendto_realops_snomask(SNO_GENERAL, L_ALL, "Called example hook!");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* END OF EXAMPLE MODULE */
|