summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-06-28 10:59:47 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-06-28 10:59:47 +0000
commitb254d3d034d5e16326404d253c8574bea9b711d4 (patch)
tree40932c313124e89d95b53775db77bde4c79e07f2
parent4d394250d983ab25fd6e52c45204d61b22e5335e (diff)
More stuff for allowing hostnames in <bind> and <link> again - note there is a FIXME here.
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@4076 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--docs/inspircd.conf.example8
-rw-r--r--src/modules/m_spanningtree.cpp12
2 files changed, 13 insertions, 7 deletions
diff --git a/docs/inspircd.conf.example b/docs/inspircd.conf.example
index 76ab8458f..df2c26aee 100644
--- a/docs/inspircd.conf.example
+++ b/docs/inspircd.conf.example
@@ -351,12 +351,6 @@
# that server to operoverride modes. This should only be used for #
# services and protected oper servers! #
# #
-# IMPORTANT NOTE: When specifying the ip address and/or host, the #
-# server software will prioritize RESOLVED hostnames above ip #
-# addresses, so for example if your target server resolves to a.b.com #
-# you MUST put a.b.com into your link block, and NOT the IP address #
-# of a.b.com. The system uses reverse resolution. #
-# #
# ____ _ _____ _ _ ____ _ _ _ #
# | _ \ ___ __ _ __| | |_ _| |__ (_)___ | __ )(_) |_| | #
# | |_) / _ \/ _` |/ _` | | | | '_ \| / __| | _ \| | __| | #
@@ -576,7 +570,7 @@
somaxconn="128"
softlimit="128"
operonlystats="oclgkz"
- operspywhois="no"
+ operspywhois="no"
customversion=""
maxtargets="20"
hidesplits="no"
diff --git a/src/modules/m_spanningtree.cpp b/src/modules/m_spanningtree.cpp
index e15ac11b7..44786923c 100644
--- a/src/modules/m_spanningtree.cpp
+++ b/src/modules/m_spanningtree.cpp
@@ -2705,6 +2705,7 @@ class TreeSocket : public InspSocket
* IPs for which we don't have a link block.
*/
bool found = false;
+ char resolved_host[MAXBUF];
vector<Link>::iterator i;
for (i = LinkBlocks.begin(); i != LinkBlocks.end(); i++)
{
@@ -2713,6 +2714,17 @@ class TreeSocket : public InspSocket
found = true;
break;
}
+ /* XXX: Fixme: blocks for a very short amount of time,
+ * we should cache these on rehash/startup
+ */
+ if (CleanAndResolve(resolved_host,i->IPAddr.c_str(),true))
+ {
+ if (std::string(resolved_host) == ip)
+ {
+ found = true;
+ break;
+ }
+ }
}
if (!found)
{