From 0e5f5ce8db8d34afe2869a73bc38672e587948a4 Mon Sep 17 00:00:00 2001 From: w00t Date: Thu, 30 Apr 2009 13:35:25 +0000 Subject: Fix bug found by Jeremy from Teranova, thanks: if an explicit bind to an IP is not made, don't assume all tags are for ipv6 IPs on an IPv6 compile (WTF). git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11342 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/inspsocket.cpp | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) (limited to 'src/inspsocket.cpp') diff --git a/src/inspsocket.cpp b/src/inspsocket.cpp index aa3c96da5..a46dffec8 100644 --- a/src/inspsocket.cpp +++ b/src/inspsocket.cpp @@ -170,15 +170,15 @@ bool BufferedSocket::BindAddr(const std::string &ip_to_bind) { ConfigReader Conf(this->ServerInstance); bool v6 = false; -#ifdef IPV6 - /* Are we looking for a binding to fit an ipv6 host? */ - if ((ip_to_bind.empty()) || (ip_to_bind.find(':') != std::string::npos)) - v6 = true; -#endif // Case one: If they provided an IP, try bind it if (!ip_to_bind.empty()) { +#ifdef IPV6 + // Check whether or not they are binding to an IPv6 IP.. + if (ip_to_bind.find(':') != std::string::npos) + v6 = true; +#endif // And if it fails, don't do anything. return this->DoBindMagic(ip_to_bind, v6); } @@ -192,6 +192,14 @@ bool BufferedSocket::BindAddr(const std::string &ip_to_bind) // set current IP to the tag std::string current_ip = Conf.ReadValue("bind","address",j); +#ifdef IPV6 + // Check whether this is for an ipv6 address + if (current_ip.find(':') != std::string::npos) + v6 = true; + else + v6 = false; +#endif + // Make sure IP is nothing local if (current_ip == "*" || current_ip == "127.0.0.1" || current_ip.empty() || current_ip == "::1") continue; -- cgit v1.2.3