diff options
Diffstat (limited to 'src/modules')
-rw-r--r-- | src/modules/m_cgiirc.cpp | 78 |
1 files changed, 70 insertions, 8 deletions
diff --git a/src/modules/m_cgiirc.cpp b/src/modules/m_cgiirc.cpp index 6eb3f877c..0ff2ecf4c 100644 --- a/src/modules/m_cgiirc.cpp +++ b/src/modules/m_cgiirc.cpp @@ -24,12 +24,17 @@ #include "users.h" #include "modules.h" #include "helperfuncs.h" +#include "dns.h" /* $ModDesc: Change user's hosts connecting from known CGI:IRC hosts */ + +/* We need this for checking our user hasnt /quit before we finish our lookup */ +extern userrec* fd_ref_table[MAX_DESCRIPTORS]; + enum CGItype { PASS, IDENT, PASSFIRST, IDENTFIRST }; -class CGIhost +class CGIhost : public classbase { public: std::string hostmask; @@ -43,6 +48,35 @@ public: typedef std::vector<CGIhost> CGIHostlist; +class CGIResolver : public Resolver +{ + std::string typ; + int theirfd; + userrec* them; + bool notify; + public: + CGIResolver(bool NotifyOpers, const std::string &source, bool forward, userrec* u, int userfd, const std::string &type) + : Resolver(source, forward, ""), typ(type), theirfd(userfd), them(u), notify(NotifyOpers) { } + + virtual void OnLookupComplete(const std::string &result) + { + /* Check the user still exists */ + if ((them) && (them == fd_ref_table[theirfd])) + { + if (notify) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from %s", them->nick, them->host, result.c_str(), typ.c_str()); + + strlcpy(them->host, result.c_str(), 16); + strlcpy(them->dhost, result.c_str(), 16); + strlcpy(them->ident, "~cgiirc", 8); + } + } + + virtual ~CGIResolver() + { + } +}; + class ModuleCgiIRC : public Module { Server *Srv; @@ -205,18 +239,31 @@ public: { /* We were given a IP in the password, we don't do DNS so they get this is as their host as well. */ log(DEBUG, "m_cgiirc.so: Got an IP in the user's password"); + + if(NotifyOpers) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from PASS", user->nick, user->host, user->password); } else { /* We got as resolved hostname in the password. */ - inet_aton("0.0.0.0", &user->ip4); log(DEBUG, "m_cgiirc.so: Got a hostname in the user's password"); + + try + { + CGIResolver* r = new CGIResolver(NotifyOpers, user->password, false, user, user->fd, "PASS"); + Srv->AddResolver(r); + } + catch (ModuleException& e) + { + if (NotifyOpers) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), but i could not resolve their hostname!", user->nick, user->host); + } } *user->password = 0; - if(NotifyOpers) - WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from PASS", user->nick, user->host, user->password); + /*if(NotifyOpers) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from PASS", user->nick, user->host, user->password);*/ return true; } @@ -251,12 +298,27 @@ public: user->Extend("cgiirc_realhost", new std::string(user->host)); user->Extend("cgiirc_realip", new std::string(inet_ntoa(user->ip4))); inet_aton(newip, &user->ip4); - strlcpy(user->host, newip, 16); + + try + { + CGIResolver* r = new CGIResolver(NotifyOpers, newip, false, user, user->fd, "IDENT"); + Srv->AddResolver(r); + } + catch (ModuleException& e) + { + strlcpy(user->host, newip, 16); + strlcpy(user->dhost, newip, 16); + strlcpy(user->ident, "~cgiirc", 8); + + if(NotifyOpers) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), but i could not resolve their hostname!", user->nick, user->host); + } + /*strlcpy(user->host, newip, 16); strlcpy(user->dhost, newip, 16); - strlcpy(user->ident, "~cgiirc", 8); + strlcpy(user->ident, "~cgiirc", 8);*/ - if(NotifyOpers) - WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from ident", user->nick, user->host, newip); + /*if(NotifyOpers) + WriteOpers("*** Connecting user %s detected as using CGI:IRC (%s), changing real host to %s from ident", user->nick, user->host, newip);*/ return true; } |