]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/main.h
SQuit all servers when a shutdown happens.
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / main.h
index 5d6fd5d99e29039aeea99eaf7b74905406fd6434..3a61927b480c843cba969bef2ee6873a45dea59e 100644 (file)
 #include "modules/dns.h"
 #include "modules/ssl.h"
 #include "modules/stats.h"
+#include "modules/ctctags.h"
+#include "modules/server.h"
 #include "servercommand.h"
 #include "commands.h"
 #include "protocolinterface.h"
 
-/** If you make a change which breaks the protocol, increment this.
- * If you  completely change the protocol, completely change the number.
+/** An enumeration of all known protocol versions.
  *
- * IMPORTANT: If you make changes, document your changes here, without fail:
- * https://docs.inspircd.org/developer/spanningtree/
- *
- * Failure to document your protocol changes will result in a painfully
- * painful death by pain. You have been warned.
+ * If you introduce new protocol versions please document them here:
+ * https://docs.inspircd.org/spanningtree/changes
  */
-const unsigned int ProtocolVersion = 1205;
-const unsigned int MinCompatProtocol = 1202;
+enum ProtocolVersion
+{
+       /** The linking protocol version introduced in InspIRCd v2.0. */
+       PROTO_INSPIRCD_20 = 1202,
+
+       /** The linking protocol version introduced in InspIRCd v2.1 alpha 0. */
+       PROTO_INSPIRCD_21_A0 = 1203,
+
+       /** The linking protocol version introduced in InspIRCd v2.1 beta 2. */
+       PROTO_INSPIRCD_21_B2 = 1204,
+
+       /** The linking protocol version introduced in InspIRCd v3.0. */
+       PROTO_INSPIRCD_30 = 1205,
+
+       /** The oldest version of the protocol that we support. */
+       PROTO_OLDEST = PROTO_INSPIRCD_20,
+
+       /** The newest version of the protocol that we support. */
+       PROTO_NEWEST = PROTO_INSPIRCD_30
+};
 
 /** Forward declarations
  */
@@ -58,6 +74,7 @@ class ModuleSpanningTree
        : public Module
        , public Away::EventListener
        , public Stats::EventListener
+       , public CTCTags::EventListener
 {
        /** Client to server commands, registered in the core
         */
@@ -77,9 +94,17 @@ class ModuleSpanningTree
         */
        SpanningTreeProtocolInterface protocolinterface;
 
-       /** Event provider for our events
-        */
-       Events::ModuleEventProvider eventprov;
+       /** Event provider for our broadcast events. */
+       Events::ModuleEventProvider broadcasteventprov;
+
+       /** Event provider for our link events. */
+       Events::ModuleEventProvider linkeventprov;
+
+       /** Event provider for our message events. */
+       Events::ModuleEventProvider messageeventprov;
+
+       /** Event provider for our sync events. */
+       Events::ModuleEventProvider synceventprov;
 
        /** API for accessing user SSL certificates. */
        UserCertificateAPI sslapi;
@@ -142,7 +167,17 @@ class ModuleSpanningTree
         */
        ModResult HandleConnect(const CommandBase::Params& parameters, User* user);
 
-       const Events::ModuleEventProvider& GetEventProvider() const { return eventprov; }
+       /** Retrieves the event provider for broadcast events. */
+       const Events::ModuleEventProvider& GetBroadcastEventProvider() const { return broadcasteventprov; }
+
+       /** Retrieves the event provider for link events. */
+       const Events::ModuleEventProvider& GetLinkEventProvider() const { return linkeventprov; }
+
+       /** Retrieves the event provider for message events. */
+       const Events::ModuleEventProvider& GetMessageEventProvider() const { return messageeventprov; }
+
+       /** Retrieves the event provider for sync events. */
+       const Events::ModuleEventProvider& GetSyncEventProvider() const { return synceventprov; }
 
        /**
         ** *** MODULE EVENTS ***
@@ -155,6 +190,7 @@ class ModuleSpanningTree
        ModResult OnPreTopicChange(User* user, Channel* chan, const std::string& topic) CXX11_OVERRIDE;
        void OnPostTopicChange(User* user, Channel* chan, const std::string &topic) CXX11_OVERRIDE;
        void OnUserPostMessage(User* user, const MessageTarget& target, const MessageDetails& details) CXX11_OVERRIDE;
+       void OnUserPostTagMessage(User* user, const MessageTarget& target, const CTCTags::TagMessageDetails& details) CXX11_OVERRIDE;
        void OnBackgroundTimer(time_t curtime) CXX11_OVERRIDE;
        void OnUserJoin(Membership* memb, bool sync, bool created, CUList& excepts) CXX11_OVERRIDE;
        void OnChangeHost(User* user, const std::string &newhost) CXX11_OVERRIDE;
@@ -176,6 +212,7 @@ class ModuleSpanningTree
        void OnUnloadModule(Module* mod) CXX11_OVERRIDE;
        ModResult OnAcceptConnection(int newsock, ListenSocket* from, irc::sockets::sockaddrs* client, irc::sockets::sockaddrs* server) CXX11_OVERRIDE;
        void OnMode(User* source, User* u, Channel* c, const Modes::ChangeList& modes, ModeParser::ModeProcessFlag processflags) CXX11_OVERRIDE;
+       void OnShutdown(const std::string& reason) CXX11_OVERRIDE;
        CullResult cull() CXX11_OVERRIDE;
        ~ModuleSpanningTree();
        Version GetVersion() CXX11_OVERRIDE;