summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/connection.h7
-rw-r--r--src/connection.cpp5
-rw-r--r--src/servers.cpp7
3 files changed, 12 insertions, 7 deletions
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<std::string> &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())