summaryrefslogtreecommitdiff
path: root/src/modules/m_foobar.cpp
blob: 2da6a0c9a1f2cf2bfeeb8a3fbc9222756d6e35e1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*       +------------------------------------+
 *       | Inspire Internet Relay Chat Daemon |
 *       +------------------------------------+
 *
 *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
 * See: http://www.inspircd.org/wiki/index.php/Credits
 *
 * This program is free but copyrighted software; see
 *            the file COPYING for details.
 *
 * ---------------------------------------------------
 */

#include "inspircd.h"

/* $ModDesc: A dummy module for testing */

// Class ModuleFoobar inherits from Module
// It just outputs simple debug strings to show its methods are working.

class ModuleFoobar : public Module
{
 private:

	 // It is recommended that your class makes use of one or more Server
	 // objects. A server object is a class which contains methods which
	 // encapsulate the exports from the core of the ircd.
	 // such methods include Debug, SendChannel, etc.


 public:
	ModuleFoobar(InspIRCd* Me)
		: Module(Me)
	{
		// The constructor just makes a copy of the server class


		Implementation eventlist[] = { I_OnUserConnect, I_OnUserQuit, I_OnUserJoin, I_OnUserPart, I_OnUserPreJoin };
		ServerInstance->Modules->Attach(eventlist, this, 5);
	}

	virtual ~ModuleFoobar()
	{
	}

	virtual Version GetVersion()
	{
		// this method instantiates a class of type Version, and returns
		// the modules version information using it.

		return Version("$Id$", VF_VENDOR, API_VERSION);
	}


	virtual void OnUserConnect(User* user)
	{
		// method called when a user connects

		std::string b = user->nick;
		ServerInstance->Logs->Log("m_foobar",DEBUG,"Foobar: User connecting: "+b);
	}

	virtual void OnUserQuit(User* user, const std::string &reason, const std::string &oper_message)
	{
		// method called when a user disconnects

		std::string b = user->nick;
		ServerInstance->Logs->Log("m_foobar",DEBUG,"Foobar: User quitting: "+b);
	}

	virtual void OnUserJoin(User* user, Channel* channel, bool sync, bool &silent)
	{
		// method called when a user joins a channel

		std::string c = channel->name;
		std::string b = user->nick;
		ServerInstance->Logs->Log("m_foobar",DEBUG,"Foobar: User "+b+" joined "+c);
	}

	virtual void OnUserPart(User* user, Channel* channel, std::string &partreason, bool &silent)
	{
		// method called when a user parts a channel

		std::string c = channel->name;
		std::string b = user->nick;
		ServerInstance->Logs->Log("m_foobar",DEBUG,"Foobar: User "+b+" parted "+c);
	}

	virtual int OnUserPreJoin(User* user, Channel* chan, const char* cname, std::string &privs, const std::string &keygiven)
	{
		return 0;
	}
};


MODULE_INIT(ModuleFoobar)