diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-06-28 10:59:47 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-06-28 10:59:47 +0000 |
commit | b254d3d034d5e16326404d253c8574bea9b711d4 (patch) | |
tree | 40932c313124e89d95b53775db77bde4c79e07f2 | |
parent | 4d394250d983ab25fd6e52c45204d61b22e5335e (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.example | 8 | ||||
-rw-r--r-- | src/modules/m_spanningtree.cpp | 12 |
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) { |