free_ban(link);
}
chptr->banlist = NULL;
+
+#if 1 /* Temporary code */
+ /* Immediately destruct empty -A channels if ZANNELS is FALSE.
+ When OPLEVELS is true, ZANNELS should be TRUE too. Test for
+ that error. This is done to avoid the DESTRUCT message to
+ occur, which is necessary on a network with mixed versions
+ of 2.10.12.x, with x < 04 *and* 2.10.11 servers. Because
+ servers prior to 2.10.12.04 can cause a BURST message outside
+ the normal net.burst as a result of a DESTRUCT message, and
+ 2.10.11 SQUIT servers when they do that. */
+ if (!(feature_bool(FEAT_ZANNELS) || feature_bool(FEAT_OPLEVELS)))
+ {
+ destruct_channel(chptr);
+ return 0;
+ }
+#endif
}
if (TStime() - chptr->creationtime < 172800) /* Channel younger than 48 hours? */
schedule_destruct_event_1m(chptr); /* Get rid of it in approximately 4-5 minutes */
* we do not want to send ERR_CANNOTSENDTOCHAN more than once.
*/
if (!MyUser(member->user))
+ {
+ if (IsDelayedJoin(member) && reveal)
+ RevealDelayedJoin(member);
return 1;
+ }
/* Discourage using the Apass to get op. They should use the Upass. */
if (IsChannelManager(member) && member->channel->mode.apass[0])
/* Ok, if we were given the OPMODE flag, or its a server, hide the source.
*/
- if (mbuf->mb_dest & MODEBUF_DEST_OPMODE || IsServer(mbuf->mb_source) || IsMe(mbuf->mb_source))
+ if (feature_bool(FEAT_HIS_MODEWHO) &&
+ (mbuf->mb_dest & MODEBUF_DEST_OPMODE ||
+ IsServer(mbuf->mb_source) ||
+ IsMe(mbuf->mb_source)))
app_source = &his;
else
app_source = mbuf->mb_source;