summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/modules/m_connectban.cpp35
1 files changed, 22 insertions, 13 deletions
diff --git a/src/modules/m_connectban.cpp b/src/modules/m_connectban.cpp
index 9ce583063..12b123498 100644
--- a/src/modules/m_connectban.cpp
+++ b/src/modules/m_connectban.cpp
@@ -30,6 +30,27 @@ class ModuleConnectBan : public Module
unsigned int ipv6_cidr;
std::string banmessage;
+ unsigned char GetRange(LocalUser* user)
+ {
+ int family = user->client_sa.family();
+ switch (family)
+ {
+ case AF_INET:
+ return ipv4_cidr;
+
+ case AF_INET6:
+ return ipv6_cidr;
+
+ case AF_UNIX:
+ // Ranges for UNIX sockets are ignored entirely.
+ return 0;
+ }
+
+ // If we have reached this point then we have encountered a bug.
+ ServerInstance->Logs->Log(MODNAME, LOG_DEBUG, "BUG: ModuleConnectBan::GetRange(): socket type %d is unknown!", family);
+ return 0;
+ }
+
public:
Version GetVersion() CXX11_OVERRIDE
{
@@ -52,19 +73,7 @@ class ModuleConnectBan : public Module
if (u->exempt)
return;
- unsigned char range = 32;
-
- switch (u->client_sa.family())
- {
- case AF_INET6:
- range = ipv6_cidr;
- break;
- case AF_INET:
- range = ipv4_cidr;
- break;
- }
-
- irc::sockets::cidr_mask mask(u->client_sa, range);
+ irc::sockets::cidr_mask mask(u->client_sa, GetRange(u));
ConnectMap::iterator i = connects.find(mask);
if (i != connects.end())