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/messages.cpp | |
parent | 2fba686904e6f78ebab35df171c5757afeebf05d (diff) |
Renamed all of source files from .c to .cpp
Diffstat (limited to 'src/messages.cpp')
-rw-r--r-- | src/messages.cpp | 327 |
1 files changed, 327 insertions, 0 deletions
diff --git a/src/messages.cpp b/src/messages.cpp new file mode 100644 index 000000000..56351ea8f --- /dev/null +++ b/src/messages.cpp @@ -0,0 +1,327 @@ +/* Definitions of IRC message functions and list of messages. + * + * (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 "services.h" +#include "modules.h" +#include "language.h" + +/*************************************************************************/ + +int m_nickcoll(const char *user) +{ + introduce_user(user); + return MOD_CONT; +} + +/*************************************************************************/ + +int m_away(const char *source, const char *msg) +{ + User *u; + + u = finduser(source); + + if (u && msg == 0) /* un-away */ + check_memos(u); + return MOD_CONT; +} + +/*************************************************************************/ + +int m_kill(const std::string &nick, const char *msg) +{ + BotInfo *bi; + + /* Recover if someone kills us. */ + if (Config.s_BotServ && (bi = findbot(nick))) + { + introduce_user(nick); + bi->RejoinAll(); + } + else + do_kill(nick, msg); + + return MOD_CONT; +} + +/*************************************************************************/ + +int m_time(const char *source, int ac, const char **av) +{ + time_t t; + struct tm *tm; + char buf[64]; + + if (!source) { + return MOD_CONT; + } + + time(&t); + tm = localtime(&t); + strftime(buf, sizeof(buf), "%a %b %d %H:%M:%S %Y %Z", tm); + ircdproto->SendNumeric(Config.ServerName, 391, source, "%s :%s", Config.ServerName, buf); + return MOD_CONT; +} + +/*************************************************************************/ + +int m_motd(const char *source) +{ + FILE *f; + char buf[BUFSIZE]; + + if (!source) { + return MOD_CONT; + } + + f = fopen(Config.MOTDFilename, "r"); + if (f) { + ircdproto->SendNumeric(Config.ServerName, 375, source, ":- %s Message of the Day", Config.ServerName); + while (fgets(buf, sizeof(buf), f)) { + buf[strlen(buf) - 1] = 0; + ircdproto->SendNumeric(Config.ServerName, 372, source, ":- %s", buf); + } + fclose(f); + ircdproto->SendNumeric(Config.ServerName, 376, source, ":End of /MOTD command."); + } else { + ircdproto->SendNumeric(Config.ServerName, 422, source, ":- MOTD file not found! Please contact your IRC administrator."); + } + return MOD_CONT; +} + +/*************************************************************************/ + +int m_privmsg(const char *source, const std::string &receiver, const char *msg) +{ + char *target; + time_t starttime, stoptime; /* When processing started and finished */ + + BotInfo *bi; + ChannelInfo *ci; + User *u; + + if (!source || !*source || receiver.empty() || !msg) { + return MOD_CONT; + } + + u = finduser(source); + + if (!u) { + Alog() << msg << ": user record for " << source << " not found"; + /* Two lookups naughty, however, this won't happen often. -- w00t */ + if (findbot(receiver)) + { + ircdproto->SendMessage(findbot(receiver), source, "%s", getstring(USER_RECORD_NOT_FOUND)); + } + return MOD_CONT; + } + + if (receiver[0] == '#') { + if (Config.s_BotServ && (ci = cs_findchan(receiver))) { + /* Some paranoia checks */ + if (!ci->HasFlag(CI_FORBIDDEN) && ci->c && ci->bi) { + botchanmsgs(u, ci, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + } + } + } else { + /* Check if we should ignore. Operators always get through. */ + if (allow_ignore && !is_oper(u)) { + IgnoreData *ign = get_ignore(source); + if (ign) { + target = myStrGetToken(msg, ' ', 0); + Alog() << "Ignored message from " << source << " to " << receiver << " using command " << target; + delete [] target; + return MOD_CONT; + } + } + + /* If a server is specified (nick@server format), make sure it matches + * us, and strip it off. */ + std::string botname = receiver; + size_t s = receiver.find('@'); + if (s != std::string::npos) + { + ci::string servername(receiver.begin() + s + 1, receiver.end()); + botname = botname.erase(s); + if (servername != Config.ServerName) + return MOD_CONT; + } + else if (Config.UseStrictPrivMsg) { + Alog(LOG_DEBUG) << "Ignored PRIVMSG without @ from " << source; + notice_lang(receiver, u, INVALID_TARGET, receiver.c_str(), receiver.c_str(), + Config.ServerName, receiver.c_str()); + return MOD_CONT; + } + + starttime = time(NULL); + + bi = findbot(botname); + + if (bi) + { + ci::string ci_bi_nick(bi->nick.c_str()); + if (ci_bi_nick == Config.s_OperServ) + { + if (!is_oper(u) && Config.OSOpersOnly) + { + notice_lang(Config.s_OperServ, u, ACCESS_DENIED); + if (Config.WallBadOS) + ircdproto->SendGlobops(OperServ, "Denied access to %s from %s!%s@%s (non-oper)", Config.s_OperServ, u->nick.c_str(), u->GetIdent().c_str(), u->host); + } + else + operserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + } + else if (ci_bi_nick == Config.s_NickServ) + nickserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + else if (ci_bi_nick== Config.s_ChanServ) + { + if (!is_oper(u) && Config.CSOpersOnly) + notice_lang(Config.s_ChanServ, u, ACCESS_DENIED); + else + chanserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + } + else if (ci_bi_nick == Config.s_MemoServ) + memoserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + else if (Config.s_HostServ && ci_bi_nick == Config.s_HostServ) + hostserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + else if (Config.s_BotServ) + { + if (ci_bi_nick == Config.s_BotServ) + botserv(u, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + else + botmsgs(u, bi, const_cast<char *>(msg)); // XXX Unsafe cast, this needs reviewing -- CyberBotX + } + } + + /* Add to ignore list if the command took a significant amount of time. */ + if (allow_ignore) { + stoptime = time(NULL); + if (stoptime > starttime && *source && !strchr(source, '.')) + add_ignore(source, stoptime - starttime); + } + } + return MOD_CONT; +} + +/*************************************************************************/ + +int m_stats(const char *source, int ac, const char **av) +{ + User *u; + NickCore *nc; + + if (ac < 1) + return MOD_CONT; + + switch (*av[0]) { + case 'l': + u = finduser(source); + + if (u && is_oper(u)) { + + ircdproto->SendNumeric(Config.ServerName, 211, source, "Server SendBuf SentBytes SentMsgs RecvBuf RecvBytes RecvMsgs ConnTime"); + ircdproto->SendNumeric(Config.ServerName, 211, source, "%s %d %d %d %d %d %d %ld", uplink_server->host, UplinkSock->WriteBufferLen(), TotalWritten, -1, UplinkSock->ReadBufferLen(), TotalRead, -1, time(NULL) - start_time); + } + + ircdproto->SendNumeric(Config.ServerName, 219, source, "%c :End of /STATS report.", *av[0] ? *av[0] : '*'); + break; + case 'o': + case 'O': +/* Check whether the user is an operator */ + u = finduser(source); + if (u && !is_oper(u) && Config.HideStatsO) { + ircdproto->SendNumeric(Config.ServerName, 219, source, "%c :End of /STATS report.", *av[0] ? *av[0] : '*'); + } else { + std::list<std::pair<std::string, std::string> >::iterator it; + + for (it = Config.Opers.begin(); it != Config.Opers.end(); ++it) + { + std::string nick = it->first, type = it->second; + + if ((nc = findcore(nick.c_str()))) + ircdproto->SendNumeric(Config.ServerName, 243, source, "O * * %s %s 0", nick.c_str(), type.c_str()); + } + + ircdproto->SendNumeric(Config.ServerName, 219, source, "%c :End of /STATS report.", *av[0] ? *av[0] : '*'); + } + + break; + + case 'u':{ + int uptime = time(NULL) - start_time; + ircdproto->SendNumeric(Config.ServerName, 242, source, ":Services up %d day%s, %02d:%02d:%02d", uptime / 86400, uptime / 86400 == 1 ? "" : "s", + (uptime / 3600) % 24, (uptime / 60) % 60, uptime % 60); + ircdproto->SendNumeric(Config.ServerName, 250, source, ":Current users: %d (%d ops); maximum %d", usercnt, opcnt, maxusercnt); + ircdproto->SendNumeric(Config.ServerName, 219, source, "%c :End of /STATS report.", *av[0] ? *av[0] : '*'); + break; + } /* case 'u' */ + + default: + ircdproto->SendNumeric(Config.ServerName, 219, source, "%c :End of /STATS report.", *av[0] ? *av[0] : '*'); + break; + } + return MOD_CONT; +} + +/*************************************************************************/ + +int m_version(const char *source, int ac, const char **av) +{ + if (source) + ircdproto->SendNumeric(Config.ServerName, 351, source, "Anope-%s %s :%s -(%s) -- %s", version_number, Config.ServerName, ircd->name, Config.EncModuleList.begin()->c_str(), version_build); + return MOD_CONT; +} + + +/*************************************************************************/ + +int m_whois(const char *source, const char *who) +{ + if (source && who) + { + NickAlias *na; + BotInfo *bi = findbot(who); + if (bi) + { + ircdproto->SendNumeric(Config.ServerName, 311, source, "%s %s %s * :%s", bi->nick.c_str(), bi->user.c_str(), bi->host.c_str(), bi->real.c_str()); + ircdproto->SendNumeric(Config.ServerName, 307, source, "%s :is a registered nick", bi->nick.c_str()); + ircdproto->SendNumeric(Config.ServerName, 312, source, "%s %s :%s", bi->nick.c_str(), Config.ServerName, Config.ServerDesc); + ircdproto->SendNumeric(Config.ServerName, 317, source, "%s %ld %ld :seconds idle, signon time", bi->nick.c_str(), time(NULL) - bi->lastmsg, start_time); + ircdproto->SendNumeric(Config.ServerName, 318, source, "%s :End of /WHOIS list.", who); + } + else if (!ircd->svshold && (na = findnick(who)) && na->HasFlag(NS_HELD)) + { + /* We have a nick enforcer client here that we need to respond to. + * We can't just say it doesn't exist here, even tho it does for + * other servers :) -GD + */ + ircdproto->SendNumeric(Config.ServerName, 311, source, "%s %s %s * :Services Enforcer", na->nick, Config.NSEnforcerUser, Config.NSEnforcerHost); + ircdproto->SendNumeric(Config.ServerName, 312, source, "%s %s :%s", na->nick, Config.ServerName, Config.ServerDesc); + ircdproto->SendNumeric(Config.ServerName, 318, source, "%s :End of /WHOIS list.", who); + } + else + { + ircdproto->SendNumeric(Config.ServerName, 401, source, "%s :No such service.", who); + } + } + return MOD_CONT; +} + +/* *INDENT-OFF* */ +void moduleAddMsgs() +{ + Anope::AddMessage("STATS", m_stats); + Anope::AddMessage("TIME", m_time); + Anope::AddMessage("VERSION", m_version); +} + |