#include "hash.h"
#include "ircd.h"
#include "ircd_chattr.h"
+#include "ircd_log.h"
#include "ircd_reply.h"
#include "ircd_string.h"
#include "numeric.h"
#include "s_user.h"
#include "send.h"
-#include <assert.h>
+/* #include <assert.h> -- Now using assert in ircd_log.h */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
{
const char* server = parv[1];
struct Client *acptr;
- time_t timestamp;
+ time_t timestamp = 0;
char *comment = 0;
if (parc < 2)
if (BadPtr(parv[parc - 1]))
comment = cli_name(sptr);
- acptr = FindNServer(server);
+ acptr = FindServer(server);
if (!acptr)
- acptr = FindServer(server);
+ acptr = FindNServer(server);
if (!acptr) {
Debug((DEBUG_NOTICE, "Ignoring SQUIT to an unknown server"));
}
/* If they are squitting me, we reverse it */
- if (IsMe(acptr)) {
- cptr = acptr;
- acptr = &me;
- }
-
- timestamp = atoi(parv[2]);
+ if (IsMe(acptr))
+ acptr = cptr; /* Bugfix by Prefect */
+
+ if (parc > 2)
+ timestamp = atoi(parv[2]);
+ else
+ protocol_violation(cptr, "SQUIT with no timestamp/reason");
/* If atoi(parv[2]) == 0 we must indeed squit !
* It will be our neighbour.
*/
- if ( timestamp != 0 && timestamp != cli_serv(acptr)->timestamp) {
+ if ( timestamp != 0 && timestamp != cli_serv(acptr)->timestamp)
+ {
Debug((DEBUG_NOTICE, "Ignoring SQUIT with the wrong timestamp"));
return 0;
}
server = parv[1];
/*
- * The following allows wild cards in SQUIT. Only usefull
+ * The following allows wild cards in SQUIT. Only useful
* when the command is issued by an oper.
*/
for (acptr = GlobalClientList; (acptr = next_client(acptr, server));
/*
* Look for a matching server that is closer,
- * that way we won't accidently squit two close
+ * that way we won't accidentally squit two close
* servers like davis.* and davis-r.* when typing
* /SQUIT davis*
*/
return exit_client(cptr, acptr, sptr, comment);
}
-
-