summaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
authorRenegade334 <contact.caaeed4f@renegade334.me.uk>2015-03-28 21:18:30 +0000
committerPeter Powell <petpow@saberuk.com>2018-09-25 12:30:06 +0100
commit4995417f59c91cf62c13f1d1dcfdbf4f67714b83 (patch)
tree1722eb9f242b898038ca1c19e4528da5704aa6c4 /src/modules
parent6d09b12be1d93571d4cabb1aa7866a7376aef126 (diff)
Add extban 'a' to m_gecosban.
This has the format a:nick!user@host+gecos. e.g. a:*!*@abusive.host+*MegaBot?v2.0* Closes #1023. Closes #1026.
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/m_gecosban.cpp27
1 files changed, 23 insertions, 4 deletions
diff --git a/src/modules/m_gecosban.cpp b/src/modules/m_gecosban.cpp
index ae399a81f..09f3c9dc7 100644
--- a/src/modules/m_gecosban.cpp
+++ b/src/modules/m_gecosban.cpp
@@ -24,21 +24,40 @@ class ModuleGecosBan : public Module
public:
Version GetVersion() CXX11_OVERRIDE
{
- return Version("Extban 'r' - real name ban", VF_OPTCOMMON|VF_VENDOR);
+ return Version("Provides a way to ban users by their real name with the 'a' and 'r' extbans", VF_OPTCOMMON|VF_VENDOR);
}
ModResult OnCheckBan(User *user, Channel *c, const std::string& mask) CXX11_OVERRIDE
{
- if ((mask.length() > 2) && (mask[0] == 'r') && (mask[1] == ':'))
+ if ((mask.length() > 2) && (mask[1] == ':'))
{
- if (InspIRCd::Match(user->GetRealName(), mask.substr(2)))
- return MOD_RES_DENY;
+ if (mask[0] == 'r')
+ {
+ if (InspIRCd::Match(user->GetRealName(), mask.substr(2)))
+ return MOD_RES_DENY;
+ }
+ else if (mask[0] == 'a')
+ {
+ // Check that the user actually specified a real name.
+ const size_t divider = mask.find('+', 1);
+ if (divider == std::string::npos)
+ return MOD_RES_PASSTHRU;
+
+ // Check whether the user's mask matches.
+ if (!c->CheckBan(user, mask.substr(2, divider - 2)))
+ return MOD_RES_PASSTHRU;
+
+ // Check whether the user's real name matches.
+ if (InspIRCd::Match(user->GetRealName(), mask.substr(divider + 1)))
+ return MOD_RES_DENY;
+ }
}
return MOD_RES_PASSTHRU;
}
void On005Numeric(std::map<std::string, std::string>& tokens) CXX11_OVERRIDE
{
+ tokens["EXTBAN"].push_back('a');
tokens["EXTBAN"].push_back('r');
}
};