]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/commands/cmd_motd.cpp
m_callerid, m_dccallow Fix crash caused by allowing unregistered users and SIDs to...
[user/henk/code/inspircd.git] / src / commands / cmd_motd.cpp
index 0b73beb5bf03d2a630826baa4d6caadfb150526b..9a236137d7db0d098f1fc1857130ab969f0fa23c 100644 (file)
@@ -1,16 +1,23 @@
-/*       +------------------------------------+
- *       | Inspire Internet Relay Chat Daemon |
- *       +------------------------------------+
+/*
+ * InspIRCd -- Internet Relay Chat Daemon
+ *
+ *   Copyright (C) 2009-2010 Daniel De Graaf <danieldg@inspircd.org>
+ *   Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net>
  *
- *  InspIRCd: (C) 2002-2010 InspIRCd Development Team
- * See: http://wiki.inspircd.org/Credits
+ * This file is part of InspIRCd.  InspIRCd is free software: you can
+ * redistribute it and/or modify it under the terms of the GNU General Public
+ * License as published by the Free Software Foundation, version 2.
  *
- * This program is free but copyrighted software; see
- *            the file COPYING for details.
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
+ * details.
  *
- * ---------------------------------------------------
+ * You should have received a copy of the GNU General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
+
 #include "inspircd.h"
 
 /** Handle /MOTD. These command handlers can be reloaded by the core,
@@ -23,7 +30,7 @@ class CommandMotd : public Command
  public:
        /** Constructor for motd.
         */
-       CommandMotd ( Module* parent) : Command(parent,"MOTD",0,1) { syntax = "[<servername>]"; }
+       CommandMotd ( Module* parent) : Command(parent,"MOTD",0,1) { ServerInstance->ProcessedMotdEscapes = false; syntax = "[<servername>]"; }
        /** Handle command.
         * @param parameters The parameters to the comamnd
         * @param pcnt The number of parameters passed to teh command
@@ -39,56 +46,59 @@ class CommandMotd : public Command
        }
 };
 
-inline std::string replace_all(const std::string &str, const std::string &orig, const std::string &repl)
-{
-       std::string new_str = str;
-       std::string::size_type pos = new_str.find(orig), orig_length = orig.length(), repl_length = repl.length();
-       while (pos != std::string::npos)
-       {
-               new_str = new_str.substr(0, pos) + repl + new_str.substr(pos + orig_length);
-               pos = new_str.find(orig, pos + repl_length);
-       }
-       return new_str;
-}
-
 /*
  * Replace all color codes from the special[] array to actual
  * color code chars using C++ style escape sequences. You
  * can append other chars to replace if you like (such as %U
  * being underline). -- Justasic
  */
-std::string ProcessColors(const std::string &string)
+void ProcessColors(ConfigFileCache::iterator &file)
 {
-       static struct special_chars
+  static struct special_chars
+  {
+    std::string character;
+    std::string replace;
+    special_chars(const std::string &c, const std::string &r) : character(c), replace(r) { }
+  }
+  
+  special[] = {
+    special_chars("\\002", "\002"),  // Bold
+    special_chars("\\037", "\037"),  // underline
+    special_chars("\\003", "\003"),  // Color
+    special_chars("\\0017", "\017"), // Stop colors
+    special_chars("\\u", "\037"),    // Alias for underline
+    special_chars("\\b", "\002"),    // Alias for Bold
+    special_chars("\\x", "\017"),    // Alias for stop
+    special_chars("\\c", "\003"),    // Alias for color
+    special_chars("", "")
+  };
+  
+  for(file_cache::iterator it = file->second.begin(); it != file->second.end(); it++)
+  {
+    std::string ret = *it;
+    for(int i = 0; special[i].character.empty() == false; ++i)
+    {
+      std::string::size_type pos = ret.find(special[i].character);
+      if(pos != std::string::npos && ret[pos-1] == '\\' && ret[pos] == '\\')
+       continue; // Skip double slashes.
+       
+       // Replace all our characters in the array
+       while(pos != std::string::npos)
        {
-               std::string character;
-               std::string replace;
-               special_chars(const std::string &c, const std::string &r) : character(c), replace(r) { }
+         ret = ret.substr(0, pos) + special[i].replace + ret.substr(pos + special[i].character.size());
+         pos = ret.find(special[i].character, pos + special[i].replace.size());
        }
-
-       special[] = {
-               special_chars("\\002", "\002"),  // Bold
-                special_chars("\\037", "\037"),  // underline
-                special_chars("\\003", "\003"),  // Color
-               special_chars("\\0017", "\017"), // Stop colors
-               special_chars("\\u", "\037"),    // Alias for underline
-               special_chars("\\b", "\002"),    // Alias for Bold
-               special_chars("\\x", "\017"),    // Alias for stop
-               special_chars("\\c", "\003"),    // Alias for color
-                special_chars("", "")
-       };
-
-       std::string ret = string;
-       for(int i = 0; special[i].character.empty() == false; ++i)
-       {
-               std::string::size_type pos = ret.find(special[i].character);
-               if(pos != std::string::npos && ret[pos-1] == '\\' && ret[pos] == '\\')
-                       continue; // Skip double slashes.
-
-               ret = replace_all(ret, special[i].character, special[i].replace);
-       }
-       // Replace double slashes with a single slash before we return
-       return replace_all(ret, "\\\\", "\\");
+    }
+    
+    // Replace double slashes with a single slash before we return
+    std::string::size_type pos = ret.find("\\\\");
+    while(pos != std::string::npos)
+    {
+      ret = ret.substr(0, pos) + "\\" + ret.substr(pos + 2);
+      pos = ret.find("\\\\", pos + 1);
+    }
+    *it = ret;
+  }
 }
 
 /** Handle /MOTD
@@ -110,11 +120,17 @@ CmdResult CommandMotd::Handle (const std::vector<std::string>& parameters, User
                return CMD_SUCCESS;
        }
 
+       if(!ServerInstance->ProcessedMotdEscapes)
+       {
+               ProcessColors(motd);
+               ServerInstance->ProcessedMotdEscapes = true;
+       }
+
        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 = motd->second.begin(); i != motd->second.end(); i++)
-               user->SendText(":%s %03d %s :- %s", ServerInstance->Config->ServerName.c_str(), RPL_MOTD, user->nick.c_str(), ProcessColors(*i).c_str());
+               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());