extensions: import sno_channelcreate from ircd-seven

This commit is contained in:
William Pitcock 2016-01-06 02:03:06 -06:00
parent d610d3f344
commit 03906030a3
3 changed files with 76 additions and 8 deletions

View file

@ -34,6 +34,7 @@ extension_LTLIBRARIES = \
ip_cloaking_4.0.la \ ip_cloaking_4.0.la \
override.la \ override.la \
restrict-unauthenticated.la \ restrict-unauthenticated.la \
sno_channelcreate.la \
sno_farconnect.la \ sno_farconnect.la \
sno_globalkline.la \ sno_globalkline.la \
sno_globaloper.la \ sno_globaloper.la \

View file

@ -275,6 +275,9 @@ override_la_OBJECTS = override.lo
restrict_unauthenticated_la_LIBADD = restrict_unauthenticated_la_LIBADD =
restrict_unauthenticated_la_SOURCES = restrict-unauthenticated.c restrict_unauthenticated_la_SOURCES = restrict-unauthenticated.c
restrict_unauthenticated_la_OBJECTS = restrict-unauthenticated.lo restrict_unauthenticated_la_OBJECTS = restrict-unauthenticated.lo
sno_channelcreate_la_LIBADD =
sno_channelcreate_la_SOURCES = sno_channelcreate.c
sno_channelcreate_la_OBJECTS = sno_channelcreate.lo
sno_farconnect_la_LIBADD = sno_farconnect_la_LIBADD =
sno_farconnect_la_SOURCES = sno_farconnect.c sno_farconnect_la_SOURCES = sno_farconnect.c
sno_farconnect_la_OBJECTS = sno_farconnect.lo sno_farconnect_la_OBJECTS = sno_farconnect.lo
@ -354,10 +357,11 @@ SOURCES = chm_adminonly.c chm_nonotice.c chm_operonly.c \
m_identify.c m_mkpasswd.c m_ojoin.c m_okick.c m_omode.c \ m_identify.c m_mkpasswd.c m_ojoin.c m_okick.c m_omode.c \
m_opme.c m_remove.c m_roleplay.c m_sendbans.c m_webirc.c \ m_opme.c m_remove.c m_roleplay.c m_sendbans.c m_webirc.c \
no_kill_services.c no_locops.c no_oper_invis.c override.c \ no_kill_services.c no_locops.c no_oper_invis.c override.c \
restrict-unauthenticated.c sno_farconnect.c sno_globalkline.c \ restrict-unauthenticated.c sno_channelcreate.c \
sno_globaloper.c sno_whois.c spy_admin_notice.c \ sno_farconnect.c sno_globalkline.c sno_globaloper.c \
spy_info_notice.c spy_links_notice.c spy_motd_notice.c \ sno_whois.c spy_admin_notice.c spy_info_notice.c \
spy_stats_notice.c spy_stats_p_notice.c spy_trace_notice.c spy_links_notice.c spy_motd_notice.c spy_stats_notice.c \
spy_stats_p_notice.c spy_trace_notice.c
DIST_SOURCES = chm_adminonly.c chm_nonotice.c chm_operonly.c \ DIST_SOURCES = chm_adminonly.c chm_nonotice.c chm_operonly.c \
chm_operonly_compat.c chm_quietunreg_compat.c chm_sslonly.c \ chm_operonly_compat.c chm_quietunreg_compat.c chm_sslonly.c \
chm_sslonly_compat.c createauthonly.c createoperonly.c \ chm_sslonly_compat.c createauthonly.c createoperonly.c \
@ -370,10 +374,11 @@ DIST_SOURCES = chm_adminonly.c chm_nonotice.c chm_operonly.c \
m_identify.c m_mkpasswd.c m_ojoin.c m_okick.c m_omode.c \ m_identify.c m_mkpasswd.c m_ojoin.c m_okick.c m_omode.c \
m_opme.c m_remove.c m_roleplay.c m_sendbans.c m_webirc.c \ m_opme.c m_remove.c m_roleplay.c m_sendbans.c m_webirc.c \
no_kill_services.c no_locops.c no_oper_invis.c override.c \ no_kill_services.c no_locops.c no_oper_invis.c override.c \
restrict-unauthenticated.c sno_farconnect.c sno_globalkline.c \ restrict-unauthenticated.c sno_channelcreate.c \
sno_globaloper.c sno_whois.c spy_admin_notice.c \ sno_farconnect.c sno_globalkline.c sno_globaloper.c \
spy_info_notice.c spy_links_notice.c spy_motd_notice.c \ sno_whois.c spy_admin_notice.c spy_info_notice.c \
spy_stats_notice.c spy_stats_p_notice.c spy_trace_notice.c spy_links_notice.c spy_motd_notice.c spy_stats_notice.c \
spy_stats_p_notice.c spy_trace_notice.c
am__can_run_installinfo = \ am__can_run_installinfo = \
case $$AM_UPDATE_INFO_DIR in \ case $$AM_UPDATE_INFO_DIR in \
n|no|NO) false;; \ n|no|NO) false;; \
@ -614,6 +619,7 @@ extension_LTLIBRARIES = \
ip_cloaking_4.0.la \ ip_cloaking_4.0.la \
override.la \ override.la \
restrict-unauthenticated.la \ restrict-unauthenticated.la \
sno_channelcreate.la \
sno_farconnect.la \ sno_farconnect.la \
sno_globalkline.la \ sno_globalkline.la \
sno_globaloper.la \ sno_globaloper.la \
@ -851,6 +857,9 @@ override.la: $(override_la_OBJECTS) $(override_la_DEPENDENCIES) $(EXTRA_override
restrict-unauthenticated.la: $(restrict_unauthenticated_la_OBJECTS) $(restrict_unauthenticated_la_DEPENDENCIES) $(EXTRA_restrict_unauthenticated_la_DEPENDENCIES) restrict-unauthenticated.la: $(restrict_unauthenticated_la_OBJECTS) $(restrict_unauthenticated_la_DEPENDENCIES) $(EXTRA_restrict_unauthenticated_la_DEPENDENCIES)
$(AM_V_CCLD)$(LINK) -rpath $(extensiondir) $(restrict_unauthenticated_la_OBJECTS) $(restrict_unauthenticated_la_LIBADD) $(LIBS) $(AM_V_CCLD)$(LINK) -rpath $(extensiondir) $(restrict_unauthenticated_la_OBJECTS) $(restrict_unauthenticated_la_LIBADD) $(LIBS)
sno_channelcreate.la: $(sno_channelcreate_la_OBJECTS) $(sno_channelcreate_la_DEPENDENCIES) $(EXTRA_sno_channelcreate_la_DEPENDENCIES)
$(AM_V_CCLD)$(LINK) -rpath $(extensiondir) $(sno_channelcreate_la_OBJECTS) $(sno_channelcreate_la_LIBADD) $(LIBS)
sno_farconnect.la: $(sno_farconnect_la_OBJECTS) $(sno_farconnect_la_DEPENDENCIES) $(EXTRA_sno_farconnect_la_DEPENDENCIES) sno_farconnect.la: $(sno_farconnect_la_OBJECTS) $(sno_farconnect_la_DEPENDENCIES) $(EXTRA_sno_farconnect_la_DEPENDENCIES)
$(AM_V_CCLD)$(LINK) -rpath $(extensiondir) $(sno_farconnect_la_OBJECTS) $(sno_farconnect_la_LIBADD) $(LIBS) $(AM_V_CCLD)$(LINK) -rpath $(extensiondir) $(sno_farconnect_la_OBJECTS) $(sno_farconnect_la_LIBADD) $(LIBS)
@ -936,6 +945,7 @@ distclean-compile:
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/no_oper_invis.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/no_oper_invis.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/override.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/override.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/restrict-unauthenticated.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/restrict-unauthenticated.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_channelcreate.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_farconnect.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_farconnect.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_globalkline.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_globalkline.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_globaloper.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sno_globaloper.Plo@am__quote@

View file

@ -0,0 +1,57 @@
/*
* Channel creation notices
*
*/
#include "stdinc.h"
#include "modules.h"
#include "client.h"
#include "hook.h"
#include "ircd.h"
#include "send.h"
#include "s_conf.h"
#include "snomask.h"
#include "ratbox_lib.h"
static int _modinit(void);
static void _moddeinit(void);
static void h_scc_channel_join(void *);
mapi_hfn_list_av1 scc_hfnlist[] = {
{ "channel_join", (hookfn) h_scc_channel_join },
{ NULL, NULL }
};
DECLARE_MODULE_AV1(sno_channelcreate, _modinit, _moddeinit, NULL, NULL, scc_hfnlist, "$Revision: 639 $");
static int
_modinit(void)
{
/* add the snomask to the available slot */
snomask_modes['l'] = find_snomask_slot();
return 0;
}
static void
_moddeinit(void)
{
/* disable the snomask and remove it from the available list */
snomask_modes['l'] = 0;
}
static void
h_scc_channel_join(void *vdata)
{
hook_data_channel_activity *data = (hook_data_channel_activity *)vdata;
struct Channel *chptr = data->chptr;
struct Client *source_p = data->client;
/* If they just joined a channel, and it only has one member, then they just created it. */
if(rb_dlink_list_length(&chptr->members) == 1 && is_chanop(find_channel_membership(chptr, source_p)))
{
sendto_realops_snomask(snomask_modes['l'], L_NETWIDE, "%s is creating new channel %s",
source_p->name, chptr->chname);
}
}