summaryrefslogtreecommitdiff
path: root/src/modules/m_antibottler.cpp
blob: fd91183dce820484fab40acd2fd43b0606b06952 (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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/*       +------------------------------------+
 *       | Inspire Internet Relay Chat Daemon |
 *       +------------------------------------+
 *
 *  Inspire is copyright (C) 2002-2004 ChatSpike-Dev.
 *                       E-mail:
 *                <brain@chatspike.net>
 *           	  <Craig@chatspike.net>
 *     
 * Written by Craig Edwards, Craig McLure, and others.
 * This program is free but copyrighted software; see
 *            the file COPYING for details.
 *
 * ---------------------------------------------------
 */
using namespace std;

#include "users.h"
#include "channels.h"
#include "modules.h"

/* $ModDesc: Changes the ident of connecting bottler clients to 'bottler' */

class ModuleAntiBottler : public Module
{
 private:
	 
	 Server *Srv;
 public:
	ModuleAntiBottler(Server* Me)
		: Module::Module(Me)
	{
		Srv = Me;
	}
	
	virtual ~ModuleAntiBottler()
	{
	}
	
	virtual Version GetVersion()
	{
		return Version(1,0,0,1,VF_VENDOR);
	}

	/* XXX - OnServerRaw? Wouldn't it be easier to use an OnUserConnect, or something? --w00t */
	virtual void OnServerRaw(std::string &raw, bool inbound, userrec* user)
	{
		if (inbound)
		{
			char data[MAXBUF];
			strncpy(data,raw.c_str(),MAXBUF);
			bool not_bottler = false;
			if (!strncmp(data,"user ",5))
			{
				for (unsigned int j = 0; j < strlen(data); j++)
				{
					if (data[j] == ':')
						break;
						
					if (data[j] == '"')
					{
						not_bottler = true;
					}
				}
				// Bug Fix (#14) -- FCS

				if (!(data) || !(*data))
					return;

				/*
				 * slight efficiency fix: strtok() just returns NULL if it has no more
				 * tokens to return. Plus strlen's here really could have been replaced
				 * with above pointer voodoo :-). --w00t
				 */
				strtok(data," ");
				char *ident = strtok(NULL," ");
				char *local = strtok(NULL," ");
				char *remote = strtok(NULL," :");
				char *gecos = strtok(NULL,"\r\n");

				if (!ident || !local || !remote || !gecos)
					return;

				for (unsigned int j = 0; j < strlen(remote); j++)
				{
					if (((remote[j] < '0') || (remote[j] > '9')) && (remote[j] != '.'))
					{
						not_bottler = true;
					}
				}

				if (!not_bottler)
				{
					raw = "USER bottler "+std::string(local)+" "+std::string(remote)+" "+std::string(gecos)+" [Possible bottler, ident: "+std::string(ident)+"]";
				}
			}
		}
 	}	
};


class ModuleAntiBottlerFactory : public ModuleFactory
{
 public:
	ModuleAntiBottlerFactory()
	{
	}
	
	~ModuleAntiBottlerFactory()
	{
	}
	
	virtual Module * CreateModule(Server* Me)
	{
		return new ModuleAntiBottler(Me);
	}
	
};


extern "C" void * init_module( void )
{
	return new ModuleAntiBottlerFactory;
}