extensions: import sno_channelcreate from ircd-seven
This commit is contained in:
parent
d610d3f344
commit
03906030a3
3 changed files with 76 additions and 8 deletions
|
@ -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 \
|
||||||
|
|
|
@ -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@
|
||||||
|
|
57
extensions/sno_channelcreate.c
Normal file
57
extensions/sno_channelcreate.c
Normal 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);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue