From afd91fdfaa77513cae5e3a5785481b391ac5564d Mon Sep 17 00:00:00 2001 From: brain Date: Sun, 29 May 2005 00:15:08 +0000 Subject: Servers with write errors not being split properly git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@1543 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/servers.cpp | 65 ++++++++++++++++++++++++++++++++++++--------------------- 1 file changed, 41 insertions(+), 24 deletions(-) (limited to 'src/servers.cpp') diff --git a/src/servers.cpp b/src/servers.cpp index a791d3557..5fa506ba7 100644 --- a/src/servers.cpp +++ b/src/servers.cpp @@ -255,29 +255,19 @@ ircd_connector* serverrec::FindHost(std::string findhost) // Checks to see if we can still reach a server at all (e.g. is it in ANY routing table?) bool IsRoutable(std::string servername) { - for (int x = 0; x < 32; x++) if (me[x]) + int c = 0; + for (int x = 0; x < 32; x++) + if (me[x]) { - ircd_connector* cn = me[x]->FindHost(servername.c_str()); - if (cn) + for (int i = 0; i < me[x]->connectors.size(); i++) { - if (cn->GetState() == STATE_DISCONNECTED) + if ((me[x]->connectors[i].GetServerName() == servername) && (me[x]->connectors[i].GetState() != STATE_DISCONNECTED)) { - for (int k = 0; k < me[x]->connectors.size(); k++) - { - for (int m = 0; m < me[x]->connectors[k].routes.size(); m++) - { - if (!strcasecmp(me[x]->connectors[k].routes[m].c_str(),servername.c_str())) - { - return true; - } - } - } - return false; + c++; } - else return true; - } + } } - return false; + return (c != 0); } @@ -290,16 +280,20 @@ void serverrec::FlushWriteBuffers() { // however if we reach this timer its connected timed out :) WriteOpers("*** Connection to %s timed out",this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); DoSplit(this->connectors[i].GetServerName().c_str()); return; } - else if ((this->connectors[i].GetState() == STATE_NOAUTH_INBOUND) && (TIME > this->connectors[i].age+30)) + if ((this->connectors[i].GetState() == STATE_NOAUTH_INBOUND) && (TIME > this->connectors[i].age+30)) { WriteOpers("*** Connection from %s timed out",this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); DoSplit(this->connectors[i].GetServerName().c_str()); return; } - else if (this->connectors[i].GetState() != STATE_DISCONNECTED) + if (this->connectors[i].GetState() != STATE_DISCONNECTED) { if (!this->connectors[i].CheckPing()) { @@ -309,12 +303,29 @@ void serverrec::FlushWriteBuffers() if (!IsRoutable(this->connectors[i].GetServerName())) { WriteOpers("*** Server %s is no longer routable, disconnecting.",this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); DoSplit(this->connectors[i].GetServerName().c_str()); } has_been_netsplit = true; } } - if (this->connectors[i].HasBufferedOutput()) + if ((this->connectors[i].GetWriteError() !="") && (this->connectors[i].GetState() != STATE_DISCONNECTED)) + { + // if we're here the write() caused an error, we cannot proceed + WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",this->connectors[i].GetServerName().c_str(),this->connectors[i].GetWriteError().c_str()); + this->connectors[i].CloseConnection(); + this->connectors[i].SetState(STATE_DISCONNECTED); + if (!IsRoutable(this->connectors[i].GetServerName())) + { + WriteOpers("*** Server %s is no longer routable, disconnecting.",this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); + DoSplit(this->connectors[i].GetServerName().c_str()); + } + has_been_netsplit = true; + } + if (this->connectors[i].HasBufferedOutput()) { if (!this->connectors[i].FlushWriteBuf()) { @@ -325,7 +336,9 @@ void serverrec::FlushWriteBuffers() if (!IsRoutable(this->connectors[i].GetServerName())) { WriteOpers("*** Server %s is no longer routable, disconnecting.",this->connectors[i].GetServerName().c_str()); - DoSplit(this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); + DoSplit(this->connectors[i].GetServerName().c_str()); } has_been_netsplit = true; } @@ -430,7 +443,7 @@ bool already_have_sum(std::string sum) bool serverrec::RecvPacket(std::deque &messages, char* recvhost,std::deque &sums) { - char data[65536]; + char data[65536],buffer[MAXBUF]; memset(data, 0, 65536); for (int i = 0; i < this->connectors.size(); i++) { @@ -460,7 +473,9 @@ bool serverrec::RecvPacket(std::deque &messages, char* recvhost,std if (!IsRoutable(this->connectors[i].GetServerName())) { WriteOpers("*** Server %s is no longer routable, disconnecting.",this->connectors[i].GetServerName().c_str()); - DoSplit(this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); + DoSplit(this->connectors[i].GetServerName().c_str()); } has_been_netsplit = true; } @@ -476,6 +491,8 @@ bool serverrec::RecvPacket(std::deque &messages, char* recvhost,std if (!IsRoutable(this->connectors[i].GetServerName())) { WriteOpers("*** Server %s is no longer routable, disconnecting.",this->connectors[i].GetServerName().c_str()); + snprintf(buffer,MAXBUF,"& %s",this->connectors[i].GetServerName().c_str()); + NetSendToAllExcept(this->connectors[i].GetServerName().c_str(),buffer); DoSplit(this->connectors[i].GetServerName().c_str()); } has_been_netsplit = true; -- cgit v1.2.3