X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_spanningtree%2Fservercommand.h;h=156b405e4f74f82b3aa3be10cdc16d3ed85a14ac;hb=a8b146419b2aae36da25b7202292528efd3158a9;hp=4311dd7b7f9af79bb5f53c1f7b5fcbfcad904fd2;hpb=b14ebbccf08ec34a73e1ba271e67da80d9fe805c;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_spanningtree/servercommand.h b/src/modules/m_spanningtree/servercommand.h index 4311dd7b7..156b405e4 100644 --- a/src/modules/m_spanningtree/servercommand.h +++ b/src/modules/m_spanningtree/servercommand.h @@ -19,6 +19,11 @@ #pragma once +#include "utils.h" +#include "treeserver.h" + +/** Base class for server-to-server commands that may have a (remote) user source or server source. + */ class ServerCommand : public CommandBase { public: @@ -28,6 +33,44 @@ class ServerCommand : public CommandBase virtual RouteDescriptor GetRouting(User* user, const std::vector& parameters); }; +/** Base class for server-to-server command handlers which are only valid if their source is a user. + * When a server sends a command of this type and the source is a server (sid), the link is aborted. + */ +template +class UserOnlyServerCommand : public ServerCommand +{ + public: + UserOnlyServerCommand(Module* Creator, const std::string& Name, unsigned int MinPara = 0, unsigned int MaxPara = 0) + : ServerCommand(Creator, Name, MinPara, MaxPara) { } + + CmdResult Handle(User* user, std::vector& parameters) + { + RemoteUser* remoteuser = IS_REMOTE(user); + if (!remoteuser) + return CMD_INVALID; + return static_cast(this)->HandleRemote(remoteuser, parameters); + } +}; + +/** Base class for server-to-server command handlers which are only valid if their source is a server. + * When a server sends a command of this type and the source is a user (uuid), the link is aborted. + */ +template +class ServerOnlyServerCommand : public ServerCommand +{ + public: + ServerOnlyServerCommand(Module* Creator, const std::string& Name, unsigned int MinPara = 0, unsigned int MaxPara = 0) + : ServerCommand(Creator, Name, MinPara, MaxPara) { } + + CmdResult Handle(User* user, std::vector& parameters) + { + if (!IS_SERVER(user)) + return CMD_INVALID; + TreeServer* server = TreeServer::Get(user); + return static_cast(this)->HandleServer(server, parameters); + } +}; + class ServerCommandManager { typedef TR1NS::unordered_map ServerCommandMap;