From 2d4621658d8daae931b7e44a9c3ecc6a04dcaf4f Mon Sep 17 00:00:00 2001 From: brain Date: Sat, 8 Jul 2006 16:10:34 +0000 Subject: Add support for cmode +h git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@4170 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/mode.cpp | 3 ++ src/modes/cmode_h.cpp | 113 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 116 insertions(+) create mode 100644 src/modes/cmode_h.cpp (limited to 'src') diff --git a/src/mode.cpp b/src/mode.cpp index 62e60b3ba..c35b43131 100644 --- a/src/mode.cpp +++ b/src/mode.cpp @@ -50,6 +50,8 @@ using namespace std; #include "modes/cmode_l.h" /* +o (channel op) */ #include "modes/cmode_o.h" +/* +h (channel halfop) */ +#include "modes/cmode_h.h" extern int MODCOUNT; extern std::vector modules; @@ -611,6 +613,7 @@ ModeParser::ModeParser() /* Now listmodes */ this->AddMode(new ModeChannelBan, 'b'); this->AddMode(new ModeChannelOp, 'o'); + this->AddMode(new ModeChannelHalfOp, 'h'); /* TODO: Modes +v, +h */ } diff --git a/src/modes/cmode_h.cpp b/src/modes/cmode_h.cpp new file mode 100644 index 000000000..2c96b4224 --- /dev/null +++ b/src/modes/cmode_h.cpp @@ -0,0 +1,113 @@ +#include +#include +#include "inspircd_config.h" +#include "configreader.h" +#include "hash_map.h" +#include "inspircd.h" +#include "mode.h" +#include "channels.h" +#include "users.h" +#include "helperfuncs.h" +#include "message.h" +#include "commands.h" +#include "modules.h" +#include "inspstring.h" +#include "hashcomp.h" +#include "modes/cmode_h.h" + +extern InspIRCd* ServerInstance; +extern ServerConfig* Config; +extern std::vector modules; +extern std::vector factory; +extern int MODCOUNT; +extern time_t TIME; + +ModeChannelHalfOp::ModeChannelHalfOp() : ModeHandler('h', 1, 1, true, MODETYPE_CHANNEL, false) +{ +} + +ModeAction ModeChannelHalfOp::OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) +{ + /* If halfops are not enabled in the conf, we don't execute + * anything in this class at all. + */ + if (!Config->AllowHalfop) + { + parameter = ""; + return MODEACTION_DENY; + } + + int status = cstatus(source, channel); + + /* Call the correct method depending on wether we're adding or removing the mode */ + if (adding) + { + parameter = this->AddHalfOp(source, parameter.c_str(), channel, status); + } + else + { + parameter = this->DelHalfOp(source, parameter.c_str(), channel, status); + } + /* If the method above 'ate' the parameter by reducing it to an empty string, then + * it won't matter wether we return ALLOW or DENY here, as an empty string overrides + * the return value and is always MODEACTION_DENY if the mode is supposed to have + * a parameter. + */ + return MODEACTION_ALLOW; +} + +std::string ModeChannelHalfOp::AddHalfOp(userrec *user,const char* dest,chanrec *chan,int status) +{ + userrec *d = ModeParser::SanityChecks(user,dest,chan,status); + + if (d) + { + if (IS_LOCAL(user)) + { + int MOD_RESULT = 0; + FOREACH_RESULT(I_OnAccessCheck,OnAccessCheck(user,d,chan,AC_HALFOP)); + + if (MOD_RESULT == ACR_DENY) + return ""; + if (MOD_RESULT == ACR_DEFAULT) + { + if ((status < STATUS_OP) && (!is_uline(user->server))) + { + WriteServ(user->fd,"482 %s %s :You're not a channel operator",user->nick, chan->name); + return ""; + } + } + } + + return ModeParser::Grant(d,chan,UCMODE_HOP); + } + return ""; +} + +std::string ModeChannelHalfOp::DelHalfOp(userrec *user,const char *dest,chanrec *chan,int status) +{ + userrec *d = ModeParser::SanityChecks(user,dest,chan,status); + + if (d) + { + if (IS_LOCAL(user)) + { + int MOD_RESULT = 0; + FOREACH_RESULT(I_OnAccessCheck,OnAccessCheck(user,d,chan,AC_DEHALFOP)); + + if (MOD_RESULT == ACR_DENY) + return ""; + if (MOD_RESULT == ACR_DEFAULT) + { + if ((user != d) && ((status < STATUS_OP) && (!is_uline(user->server)))) + { + WriteServ(user->fd,"482 %s %s :You are not a channel operator",user->nick, chan->name); + return ""; + } + } + } + + return ModeParser::Revoke(d,chan,UCMODE_HOP); + } + return ""; +} -- cgit v1.2.3