summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/commands.cpp17
-rw-r--r--src/inspircd.cpp16
2 files changed, 33 insertions, 0 deletions
diff --git a/src/commands.cpp b/src/commands.cpp
index ff9a5e41c..7d8523ece 100644
--- a/src/commands.cpp
+++ b/src/commands.cpp
@@ -1911,6 +1911,23 @@ void handle_H(char token,char* params,serverrec* source,serverrec* reply, char*
ircd_connector s;
s.SetState(STATE_DISCONNECTED);
s.SetServerName(params);
+
+ for (int j = 0; j < 32; j++)
+ {
+ if (me[j] != NULL)
+ {
+ for (int k = 0; k < me[j]->connectors.size(); k++)
+ {
+ if (!strcasecmp(me[j]->connectors[k].GetServerName().c_str(),params))
+ {
+ // dont allow a server to be added twice
+ log(DEBUG,"ULined server %s already in the map!",params);
+ return;
+ }
+ }
+ }
+ }
+
source->connectors.push_back(s);
WriteOpers("Non-Mesh server %s has joined the network",params);
}
diff --git a/src/inspircd.cpp b/src/inspircd.cpp
index a71cf08ab..8b8e3a9d0 100644
--- a/src/inspircd.cpp
+++ b/src/inspircd.cpp
@@ -3010,6 +3010,22 @@ void DoSync(serverrec* serv, char* tcp_host)
}
// sync global zlines, glines, etc
sync_xlines(serv,tcp_host);
+
+ for (int j = 0; j < 32; j++)
+ {
+ if (me[j] != NULL)
+ {
+ for (int k = 0; k < me[j]->connectors.size(); k++)
+ {
+ if (is_uline(me[j]->connectors[k].GetServerName().c_str()))
+ {
+ sprintf(data,"H %s",me[j]->connectors[k].GetServerName().c_str());
+ serv->SendPacket(data,tcp_host);
+ }
+ }
+ }
+ }
+
snprintf(data,MAXBUF,"F %d",time(NULL));
serv->SendPacket(data,tcp_host);
log(DEBUG,"Sent sync");