X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/ebc55af53c5e0736351759332ed3e124307c98f8..343e239585d12e5a9f618db5483e4193b8c571a6:/modules/core/m_message.c diff --git a/modules/core/m_message.c b/modules/core/m_message.c index 08ccc1d..3f814f6 100644 --- a/modules/core/m_message.c +++ b/modules/core/m_message.c @@ -513,12 +513,20 @@ msg_channel(int p_or_n, const char *command, if(result == CAN_SEND_OPV || !flood_attack_channel(p_or_n, source_p, chptr, chptr->chname)) { + if (p_or_n != NOTICE && *text == '\001' && + strncasecmp(text + 1, "ACTION", 6)) + { + if (chptr->mode.mode & MODE_NOCTCP) + { + sendto_one_numeric(source_p, ERR_CANNOTSENDTOCHAN, + form_str(ERR_CANNOTSENDTOCHAN), chptr->chname); + return; + } + else if (rb_dlink_list_length(&chptr->locmembers) > (unsigned)(GlobalSetOptions.floodcount / 2)) + source_p->large_ctcp_sent = rb_current_time(); + } sendto_channel_flags(client_p, ALL_MEMBERS, source_p, chptr, "%s %s :%s", command, chptr->chname, text); - if (p_or_n != NOTICE && *text == '\001' && - strncasecmp(text + 1, "ACTION", 6) && - rb_dlink_list_length(&chptr->locmembers) > (unsigned)(GlobalSetOptions.floodcount / 2)) - source_p->large_ctcp_sent = rb_current_time(); } } else if(chptr->mode.mode & MODE_OPMODERATE &&