This is designed to stop the spam bots which sit outside a channel, while a spy sits inside, preventing channel operators dealing with the problem.
We currently also block invites, this might not be such a good idea, but these days everyone can get Q.
-diff -r f2182ca2442a include/channel.h
---- a/include/channel.h Sun Jan 11 22:53:16 2009 +0000
-+++ b/include/channel.h Sun Jan 11 22:54:00 2009 +0000
-@@ -462,5 +462,6 @@
+diff -r 3825aab95440 include/channel.h
+--- a/include/channel.h Mon Aug 10 14:18:18 2009 +0100
++++ b/include/channel.h Mon Aug 10 14:18:25 2009 +0100
+@@ -463,5 +463,6 @@
extern void free_ban(struct Ban *ban);
extern unsigned int get_channel_marker(void);
+extern int common_chan_count(struct Client *a, struct Client *b, int max);
#endif /* INCLUDED_channel_h */
-diff -r f2182ca2442a include/client.h
---- a/include/client.h Sun Jan 11 22:53:16 2009 +0000
-+++ b/include/client.h Sun Jan 11 22:54:00 2009 +0000
+diff -r 3825aab95440 include/client.h
+--- a/include/client.h Mon Aug 10 14:18:18 2009 +0100
++++ b/include/client.h Mon Aug 10 14:18:25 2009 +0100
@@ -90,7 +90,7 @@
#define FlagClr(set,flag) ((set)->bits[FLAGSET_INDEX(flag)] &= ~FLAGSET_MASK(flag))
/** Character to indicate no oper name available */
#define NOOPERNAMECHARACTER '-'
-@@ -192,7 +192,8 @@
+@@ -194,7 +194,8 @@
FLAG_NOIDLE, /**< user's idletime is hidden */
FLAG_XTRAOP, /**< oper has special powers */
FLAG_OPERNAME, /**< Server sends oper name in mode string */
FLAG_LAST_FLAG, /**< number of flags */
FLAG_LOCAL_UMODES = FLAG_LOCOP, /**< First local mode flag */
FLAG_GLOBAL_UMODES = FLAG_OPER /**< First global mode flag */
-@@ -622,6 +623,8 @@
+@@ -626,6 +627,8 @@
#define IsParanoid(x) HasFlag(x, FLAG_PARANOID)
/** Return non-zero if the server should send opername information */
#define IsSendOperName(x) HasFlag(x, FLAG_OPERNAME)
/** Return non-zero if the client has operator or server privileges. */
#define IsPrivileged(x) (IsAnOper(x) || IsServer(x))
-@@ -685,6 +688,8 @@
+@@ -689,6 +692,8 @@
#define SetAccountOnly(x) SetFlag(x, FLAG_ACCOUNTONLY)
/** Mark a client as having mode +P (paranoid). */
#define SetParanoid(x) SetFlag(x, FLAG_PARANOID)
/** Return non-zero if \a sptr sees \a acptr as an operator. */
#define SeeOper(sptr,acptr) (IsAnOper(acptr) && (HasPriv(acptr, PRIV_DISPLAY) \
-@@ -730,6 +735,8 @@
+@@ -736,6 +741,8 @@
#define ClearAccountOnly(x) ClrFlag(x, FLAG_ACCOUNTONLY)
/** Remove mode +P (paranoid) from a client */
#define ClearParanoid(x) ClrFlag(x, FLAG_PARANOID)
/* free flags */
#define FREEFLAG_SOCKET 0x0001 /**< socket needs to be freed */
-diff -r f2182ca2442a include/numeric.h
---- a/include/numeric.h Sun Jan 11 22:53:16 2009 +0000
-+++ b/include/numeric.h Sun Jan 11 22:54:00 2009 +0000
-@@ -420,6 +420,7 @@
+diff -r 3825aab95440 include/numeric.h
+--- a/include/numeric.h Mon Aug 10 14:18:18 2009 +0100
++++ b/include/numeric.h Mon Aug 10 14:18:25 2009 +0100
+@@ -421,6 +421,7 @@
/* ERR_HTMDISABLED 486 unreal */
#define ERR_ACCOUNTONLY 486 /* QuakeNet/ASUKA extension */
/* ERR_CHANTOORECENT 487 IRCnet extension (?) */
/* ERR_TSLESSCHAN 488 IRCnet extension (?) */
#define ERR_VOICENEEDED 489 /* Undernet extension */
-diff -r f2182ca2442a ircd/channel.c
---- a/ircd/channel.c Sun Jan 11 22:53:16 2009 +0000
-+++ b/ircd/channel.c Sun Jan 11 22:54:00 2009 +0000
-@@ -3801,3 +3801,39 @@
+diff -r 3825aab95440 ircd/channel.c
+--- a/ircd/channel.c Mon Aug 10 14:18:18 2009 +0100
++++ b/ircd/channel.c Mon Aug 10 14:18:25 2009 +0100
+@@ -3804,3 +3804,39 @@
return marker;
}
+
+ return count;
+}
-diff -r f2182ca2442a ircd/ircd_relay.c
---- a/ircd/ircd_relay.c Sun Jan 11 22:53:16 2009 +0000
-+++ b/ircd/ircd_relay.c Sun Jan 11 22:54:00 2009 +0000
-@@ -308,6 +308,10 @@
+diff -r 3825aab95440 ircd/ircd_relay.c
+--- a/ircd/ircd_relay.c Mon Aug 10 14:18:18 2009 +0100
++++ b/ircd/ircd_relay.c Mon Aug 10 14:18:25 2009 +0100
+@@ -309,6 +309,10 @@
if (IsAccountOnly(acptr) && !IsAccount(sptr) && !IsXtraOp(sptr))
return;
if (!(is_silenced(sptr, acptr)))
sendcmdto_one(sptr, CMD_PRIVATE, acptr, "%s :%s", name, text);
}
-@@ -360,6 +364,9 @@
+@@ -361,6 +365,9 @@
if (IsAccountOnly(acptr) && !IsAccount(sptr) && !IsXtraOp(sptr))
return;
if (!(is_silenced(sptr, acptr)))
sendcmdto_one(sptr, CMD_NOTICE, acptr, "%s :%s", name, text);
}
-@@ -399,6 +406,11 @@
+@@ -400,6 +407,11 @@
return;
}
/*
* send away message if user away
*/
-@@ -443,6 +455,9 @@
+@@ -444,6 +456,9 @@
if (IsAccountOnly(acptr) && !IsAccount(sptr) && !IsXtraOp(sptr))
return;
/*
* deliver the message
*/
-diff -r f2182ca2442a ircd/m_invite.c
---- a/ircd/m_invite.c Sun Jan 11 22:53:16 2009 +0000
-+++ b/ircd/m_invite.c Sun Jan 11 22:54:00 2009 +0000
+diff -r 3825aab95440 ircd/m_invite.c
+--- a/ircd/m_invite.c Mon Aug 10 14:18:18 2009 +0100
++++ b/ircd/m_invite.c Mon Aug 10 14:18:25 2009 +0100
@@ -171,6 +171,9 @@
return 0;
}
if (check_target_limit(sptr, acptr, cli_name(acptr), 0))
return 0;
-diff -r f2182ca2442a ircd/s_err.c
---- a/ircd/s_err.c Sun Jan 11 22:53:16 2009 +0000
-+++ b/ircd/s_err.c Sun Jan 11 22:54:00 2009 +0000
+diff -r 3825aab95440 ircd/s_err.c
+--- a/ircd/s_err.c Mon Aug 10 14:18:18 2009 +0100
++++ b/ircd/s_err.c Mon Aug 10 14:18:25 2009 +0100
@@ -1006,7 +1006,7 @@
/* 486 */
{ ERR_ACCOUNTONLY, "%s :You must be authed in order to message this user -- For details of how to obtain an account visit %s", "486" },
/* 488 */
{ 0 },
/* 489 */
-diff -r f2182ca2442a ircd/s_user.c
---- a/ircd/s_user.c Sun Jan 11 22:53:16 2009 +0000
-+++ b/ircd/s_user.c Sun Jan 11 22:54:00 2009 +0000
+diff -r 3825aab95440 ircd/s_user.c
+--- a/ircd/s_user.c Mon Aug 10 14:18:18 2009 +0100
++++ b/ircd/s_user.c Mon Aug 10 14:18:25 2009 +0100
@@ -546,7 +546,8 @@
{ FLAG_NOCHAN, 'n' },
{ FLAG_NOIDLE, 'I' },
};
/** Length of #userModeList. */
-@@ -856,7 +857,9 @@
- send_reply(source, ERR_ACCOUNTONLY, cli_name(source), feature_str(FEAT_URLREG));
+@@ -857,7 +858,9 @@
+ send_reply(source, ERR_ACCOUNTONLY, cli_name(dest), feature_str(FEAT_URLREG));
return 0;
}
-
if (is_notice)
sendcmdto_one(source, CMD_NOTICE, dest, "%C :%s", dest, text);
else
-@@ -1428,6 +1431,12 @@
+@@ -1429,6 +1432,12 @@
else
ClearParanoid(sptr);
break;