From aeded4708c515bcc255b2947e67f076855fead14 Mon Sep 17 00:00:00 2001 From: danieldg Date: Tue, 19 Jan 2010 04:43:19 +0000 Subject: Fix MOTD and RULES to work remotely (remove the old hacks for MOTD) git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@12301 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/commands/cmd_motd.cpp | 39 +++++++++++++++++++++++---------------- src/commands/cmd_rules.cpp | 38 +++++++++++++++++++++++--------------- 2 files changed, 46 insertions(+), 31 deletions(-) (limited to 'src/commands') diff --git a/src/commands/cmd_motd.cpp b/src/commands/cmd_motd.cpp index 0e1792320..9468eb2f3 100644 --- a/src/commands/cmd_motd.cpp +++ b/src/commands/cmd_motd.cpp @@ -13,17 +13,6 @@ #include "inspircd.h" -#ifndef __CMD_MOTD_H__ -#define __CMD_MOTD_H__ - -// include the common header files - -#include -#include -#include "inspircd.h" -#include "users.h" -#include "channels.h" - /** Handle /MOTD. These command handlers can be reloaded by the core, * and handle basic RFC1459 commands. Commands within modules work * the same way, however, they can be fully unloaded, where these @@ -42,16 +31,34 @@ class CommandMotd : public Command * @return A value from CmdResult to indicate command success or failure. */ CmdResult Handle(const std::vector& parameters, User *user); + RouteDescriptor GetRouting(User* user, const std::vector& parameters) + { + if (parameters.size() > 0) + return ROUTE_UNICAST(parameters[0]); + return ROUTE_LOCALONLY; + } }; -#endif - - /** Handle /MOTD */ -CmdResult CommandMotd::Handle (const std::vector&, User *user) +CmdResult CommandMotd::Handle (const std::vector& parameters, User *user) { - user->ShowMOTD(); + if (parameters.size() > 0 && parameters[0] != ServerInstance->Config->ServerName) + return CMD_SUCCESS; + if (!ServerInstance->Config->MOTD.size()) + { + user->SendText(":%s %03d %s :Message of the day file is missing.", + ServerInstance->Config->ServerName.c_str(), ERR_NOMOTD, user->nick.c_str()); + return CMD_SUCCESS; + } + user->SendText(":%s %03d %s :%s message of the day", ServerInstance->Config->ServerName.c_str(), + RPL_MOTDSTART, user->nick.c_str(), ServerInstance->Config->ServerName.c_str()); + + for (file_cache::iterator i = ServerInstance->Config->MOTD.begin(); i != ServerInstance->Config->MOTD.end(); i++) + user->SendText(":%s %03d %s :- %s", ServerInstance->Config->ServerName.c_str(), RPL_MOTD, user->nick.c_str(),i->c_str()); + + user->SendText(":%s %03d %s :End of message of the day.", ServerInstance->Config->ServerName.c_str(), RPL_ENDOFMOTD, user->nick.c_str()); + return CMD_SUCCESS; } diff --git a/src/commands/cmd_rules.cpp b/src/commands/cmd_rules.cpp index e01ca2a3e..78b3235fb 100644 --- a/src/commands/cmd_rules.cpp +++ b/src/commands/cmd_rules.cpp @@ -13,17 +13,6 @@ #include "inspircd.h" -#ifndef __CMD_RULES_H__ -#define __CMD_RULES_H__ - -// include the common header files - -#include -#include -#include "inspircd.h" -#include "users.h" -#include "channels.h" - /** Handle /RULES. These command handlers can be reloaded by the core, * and handle basic RFC1459 commands. Commands within modules work * the same way, however, they can be fully unloaded, where these @@ -42,14 +31,33 @@ class CommandRules : public Command * @return A value from CmdResult to indicate command success or failure. */ CmdResult Handle(const std::vector& parameters, User *user); + RouteDescriptor GetRouting(User* user, const std::vector& parameters) + { + if (parameters.size() > 0) + return ROUTE_UNICAST(parameters[0]); + return ROUTE_LOCALONLY; + } }; -#endif - - CmdResult CommandRules::Handle (const std::vector& parameters, User *user) { - user->ShowRULES(); + if (parameters.size() > 0 && parameters[0] != ServerInstance->Config->ServerName) + return CMD_SUCCESS; + + if (!ServerInstance->Config->RULES.size()) + { + user->SendText(":%s %03d %s :RULES file is missing.", + ServerInstance->Config->ServerName.c_str(), ERR_NORULES, user->nick.c_str()); + return CMD_SUCCESS; + } + user->SendText(":%s %03d %s :%s server rules:", ServerInstance->Config->ServerName.c_str(), + RPL_RULESTART, user->nick.c_str(), ServerInstance->Config->ServerName.c_str()); + + for (file_cache::iterator i = ServerInstance->Config->RULES.begin(); i != ServerInstance->Config->RULES.end(); i++) + user->SendText(":%s %03d %s :- %s", ServerInstance->Config->ServerName.c_str(), RPL_RULES, user->nick.c_str(),i->c_str()); + + user->SendText(":%s %03d %s :End of RULES command.", ServerInstance->Config->ServerName.c_str(), RPL_RULESEND, user->nick.c_str()); + return CMD_SUCCESS; } -- cgit v1.2.3