diff options
author | Adam <Adam@Anope.org> | 2010-05-25 00:57:25 -0500 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-06-18 21:04:07 -0400 |
commit | 4a2b9ebcf38d6c0a2860b966421b3af125438488 (patch) | |
tree | e4af4e59fd29352138db0fb0ff614d50233850b8 /src/core/os_oline.cpp | |
parent | 2fba686904e6f78ebab35df171c5757afeebf05d (diff) |
Renamed all of source files from .c to .cpp
Diffstat (limited to 'src/core/os_oline.cpp')
-rw-r--r-- | src/core/os_oline.cpp | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/src/core/os_oline.cpp b/src/core/os_oline.cpp new file mode 100644 index 000000000..f02484352 --- /dev/null +++ b/src/core/os_oline.cpp @@ -0,0 +1,86 @@ +/* OperServ core functions + * + * (C) 2003-2010 Anope Team + * Contact us at team@anope.org + * + * Please read COPYING and README for further details. + * + * Based on the original code of Epona by Lara. + * Based on the original code of Services by Andy Church. + * + * + */ +/*************************************************************************/ + +#include "module.h" + +class CommandOSOLine : public Command +{ + public: + CommandOSOLine() : Command("OLINE", 2, 2, "operserv/oline") + { + } + + CommandReturn Execute(User *u, const std::vector<ci::string> ¶ms) + { + const char *nick = params[0].c_str(); + const char *flag = params[1].c_str(); + User *u2 = NULL; + + /* let's check whether the user is online */ + if (!(u2 = finduser(nick))) + notice_lang(Config.s_OperServ, u, NICK_X_NOT_IN_USE, nick); + else if (u2 && flag[0] == '+') + { + ircdproto->SendSVSO(Config.s_OperServ, nick, flag); + u2->SetMode(OperServ, UMODE_OPER); + notice_lang(Config.s_OperServ, u2, OPER_OLINE_IRCOP); + notice_lang(Config.s_OperServ, u, OPER_OLINE_SUCCESS, flag, nick); + ircdproto->SendGlobops(OperServ, "\2%s\2 used OLINE for %s", u->nick.c_str(), nick); + } + else if (u2 && flag[0] == '-') + { + ircdproto->SendSVSO(Config.s_OperServ, nick, flag); + notice_lang(Config.s_OperServ, u, OPER_OLINE_SUCCESS, flag, nick); + ircdproto->SendGlobops(OperServ, "\2%s\2 used OLINE for %s", u->nick.c_str(), nick); + } + else + this->OnSyntaxError(u, ""); + return MOD_CONT; + } + + bool OnHelp(User *u, const ci::string &subcommand) + { + notice_help(Config.s_OperServ, u, OPER_HELP_OLINE); + return true; + } + + void OnSyntaxError(User *u, const ci::string &subcommand) + { + syntax_error(Config.s_OperServ, u, "OLINE", OPER_OLINE_SYNTAX); + } +}; + +class OSOLine : public Module +{ + public: + OSOLine(const std::string &modname, const std::string &creator) : Module(modname, creator) + { + this->SetAuthor("Anope"); + this->SetVersion(VERSION_STRING); + this->SetType(CORE); + + this->AddCommand(OperServ, new CommandOSOLine()); + + if (!ircd->omode) + throw ModuleException("Your IRCd does not support OMODE."); + + ModuleManager::Attach(I_OnOperServHelp, this); + } + void OnOperServHelp(User *u) + { + notice_lang(Config.s_OperServ, u, OPER_HELP_CMD_OLINE); + } +}; + +MODULE_INIT(OSOLine) |