]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_chancreate.cpp
Allow commands to optionally route themselves using ENCAP
[user/henk/code/inspircd.git] / src / modules / m_chancreate.cpp
index 8633ddc059f5869e337422fee48530751c75e373..c37ffd6906f200399f7a82d6210a40b61374bd9e 100644 (file)
@@ -2,8 +2,8 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd: (C) 2002-2008 InspIRCd Development Team
- * See: http://www.inspircd.org/wiki/index.php/Credits
+ *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ * See: http://wiki.inspircd.org/Credits
  *
  * This program is free but copyrighted software; see
  *            the file COPYING for details.
@@ -23,25 +23,32 @@ class ModuleChanCreate : public Module
                : Module(Me)
        {
                ServerInstance->SNO->EnableSnomask('j', "CHANCREATE");
+               ServerInstance->SNO->EnableSnomask('J', "REMOTECHANCREATE");
                Implementation eventlist[] = { I_OnUserJoin };
                ServerInstance->Modules->Attach(eventlist, this, 1);
        }
-       
+
        virtual ~ModuleChanCreate()
        {
                ServerInstance->SNO->DisableSnomask('j');
+               ServerInstance->SNO->DisableSnomask('J');
        }
-       
+
        virtual Version GetVersion()
        {
-               return Version(1,2,0,0,VF_VENDOR,API_VERSION);
+               return Version("$Id$",VF_VENDOR,API_VERSION);
        }
 
-       
-       virtual void OnUserJoin(User* user, Channel* channel, bool sync, bool &silent)
+
+       virtual void OnUserJoin(User* user, Channel* channel, bool sync, bool &silent, bool created)
        {
-               if (channel->GetUserCounter() == 1)
-                       ServerInstance->SNO->WriteToSnoMask('j', "Channel %s created by %s!%s@%s", channel->name.c_str(), user->nick.c_str(), user->ident.c_str(), user->host.c_str());
+               if (created)
+               {
+                       if (IS_LOCAL(user))
+                               ServerInstance->SNO->WriteToSnoMask('j', "Channel %s created by %s!%s@%s", channel->name.c_str(), user->nick.c_str(), user->ident.c_str(), user->host.c_str());
+                       else
+                               ServerInstance->SNO->WriteToSnoMask('J', "Channel %s created by %s!%s@%s", channel->name.c_str(), user->nick.c_str(), user->ident.c_str(), user->host.c_str());
+               }
        }
 };