X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodes%2Fumode_n.cpp;h=db386a32b06f24f6f3f25fa08f81e7ec725eb8e2;hb=525eeb51a52ca9dbd001f0897222f6e5a3dccfb1;hp=6c1b380f3f98ed5c1ead913983d6edf0e66a1180;hpb=2816a3ff87c3c15848dfe7f71391a454992ecefe;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modes/umode_n.cpp b/src/modes/umode_n.cpp index 6c1b380f3..db386a32b 100644 --- a/src/modes/umode_n.cpp +++ b/src/modes/umode_n.cpp @@ -1,26 +1,58 @@ +/* +------------------------------------+ + * | Inspire Internet Relay Chat Daemon | + * +------------------------------------+ + * + * InspIRCd: (C) 2002-2008 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits + * + * This program is free but copyrighted software; see + * the file COPYING for details. + * + * --------------------------------------------------- + */ + #include "inspircd.h" #include "mode.h" #include "channels.h" #include "users.h" #include "modes/umode_n.h" -ModeUserServerNoticeMask::ModeUserServerNoticeMask() : ModeHandler('n', 1, 0, false, MODETYPE_USER, true) +ModeUserServerNoticeMask::ModeUserServerNoticeMask(InspIRCd* Instance) : ModeHandler(Instance, 'n', 1, 0, false, MODETYPE_USER, true) { } -ModeAction ModeUserServerNoticeMask::OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) +ModeAction ModeUserServerNoticeMask::OnModeChange(User* source, User* dest, Channel*, std::string ¶meter, bool adding, bool servermode) { /* Only opers can change other users modes */ if ((source != dest) && (!*source->oper)) return MODEACTION_DENY; - /* Set the bitfields */ - if (dest->modes[UM_SERVERNOTICE] != adding) + /* Set the array fields */ + if (adding) { - dest->modes[UM_SERVERNOTICE] = adding; + /* Fix for bug #310 reported by Smartys */ + if (!dest->modes[UM_SNOMASK]) + memset(dest->snomasks, 0, sizeof(dest->snomasks)); + + parameter = dest->ProcessNoticeMasks(parameter.c_str()); + dest->modes[UM_SNOMASK] = true; + if (!dest->modes[UM_SERVERNOTICE]) + { + const char* newmodes[] = { dest->nick, "+s" }; + ServerInstance->Modes->Process(newmodes, 2, source, true); + } return MODEACTION_ALLOW; } + else + { + if (dest->modes[UM_SNOMASK] != false) + { + dest->modes[UM_SNOMASK] = false; + return MODEACTION_ALLOW; + } + } /* Allow the change */ return MODEACTION_DENY; } +