From: brain Date: Mon, 23 May 2005 18:28:42 +0000 (+0000) Subject: Buffer size limits (hard coded to 1mb for now, will allow to raise in config later) X-Git-Tag: v2.0.23~10210 X-Git-Url: https://git.netwichtig.de/gitweb/?a=commitdiff_plain;ds=sidebyside;h=bac7dea75b15323bb678ed56ca54606ee92c0afd;p=user%2Fhenk%2Fcode%2Finspircd.git Buffer size limits (hard coded to 1mb for now, will allow to raise in config later) git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@1478 e03df62e-2008-0410-955e-edbf42e46eb7 --- diff --git a/include/connection.h b/include/connection.h index 420839b0d..8f5efe2d7 100644 --- a/include/connection.h +++ b/include/connection.h @@ -185,11 +185,10 @@ class ircd_connector : public Extensible void CloseConnection(); /** This method adds text to the ircd connection's buffer - * There is no limitation on how much text of what line width may - * be added to this buffer. It is the sending server's responsibility - * to ensure sent data is kept within reasonable quanities. + * This buffer's maximum size is one megabyte, the method returning false + * if the buffer is full. */ - void AddBuffer(std::string a); + bool AddBuffer(std::string a); /** This method returns true if the buffer contains at least one * carriage return character, e.g. one line can be read from the diff --git a/src/connection.cpp b/src/connection.cpp index 7d5df66f9..c7221ce74 100644 --- a/src/connection.cpp +++ b/src/connection.cpp @@ -117,7 +117,7 @@ void ircd_connector::SetServerPort(int p) this->port = p; } -void ircd_connector::AddBuffer(std::string a) +bool ircd_connector::AddBuffer(std::string a) { std::string b = ""; for (int i = 0; i < a.length(); i++) @@ -128,6 +128,7 @@ void ircd_connector::AddBuffer(std::string a) stream << b; log(DEBUG,"AddBuffer: %s",b.c_str()); ircdbuffer = stream.str(); + return (ircdbuffer.length() < 1048576); } bool ircd_connector::BufferIsComplete() @@ -170,7 +171,7 @@ bool ircd_connector::AddWriteBuf(std::string data) std::stringstream stream; stream << sendq << data; sendq = stream.str(); - return true; + return (sendq.length() < 1048576); } bool ircd_connector::HasBufferedOutput() diff --git a/src/servers.cpp b/src/servers.cpp index d2ace18e8..15929345f 100644 --- a/src/servers.cpp +++ b/src/servers.cpp @@ -392,7 +392,12 @@ bool serverrec::RecvPacket(std::deque &messages, char* recvhost,std int pushed = 0; if (rcvsize > 0) { - this->connectors[i].AddBuffer(data); + if (!this->connectors[i].AddBuffer(data)) + { + WriteOpers("*** Read buffer for %s exceeds maximum, closing connection!",this->connectors[i].GetServerName().c_str()); + this->connectors[i].CloseConnection(); + this->connectors[i].SetState(STATE_DISCONNECTED); + } if (this->connectors[i].BufferIsComplete()) { while (this->connectors[i].BufferIsComplete())