X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=include%2Fsnomasks.h;h=d4bd8a22c9e1ef8d95ab0b369f6eda12b37e56af;hb=b7904e23726dfa497d276e193827c2e8685443eb;hp=e3318f23a8f34686267080c7f6f17e2fae1dc2c0;hpb=f1271614679843191bb247c0db2716acb5ac0e4b;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/include/snomasks.h b/include/snomasks.h index e3318f23a..d4bd8a22c 100644 --- a/include/snomasks.h +++ b/include/snomasks.h @@ -14,7 +14,7 @@ #ifndef __SNOMASKS_H__ #define __SNOMASKS_H__ -class Snomask +class Snomask : public Extensible { private: InspIRCd *ServerInstance; @@ -24,14 +24,12 @@ class Snomask std::string Description; std::string LastMessage; unsigned int Count; + bool LocalOnly; // whether or not messages are netwide /** Create a new Snomask */ - Snomask(InspIRCd* Instance, char snomask, const std::string &description) + Snomask(InspIRCd* Instance, char snomask, const std::string &description, bool local) : ServerInstance(Instance), MySnomask(snomask), Description(description), LastMessage(""), Count(0), LocalOnly(local) { - ServerInstance = Instance; - MySnomask = snomask; - Description = description; } /** Sends a message to all opers with this snomask. @@ -80,10 +78,11 @@ class CoreExport SnomaskManager : public Extensible * their list, and users may add this letter to their list. * @param description The descriptive text sent along with any * server notices, at the start of the notice, e.g. "GLOBOPS". + * @param local Whether or not messages should be locally broadcast only (default off) * @return True if the snomask was enabled, false if it already * exists. */ - bool EnableSnomask(char letter, const std::string &description); + bool EnableSnomask(char letter, const std::string &description, bool local = false); /** Disable a snomask. * @param letter The snomask letter to disable. @@ -92,6 +91,13 @@ class CoreExport SnomaskManager : public Extensible */ bool DisableSnomask(char letter); + /** Set the local only message state of a given snomask. + * This is used by remote stuff to prevent endless recursion in sending + * XXX this is currently a really shit way to do it, as it effectively + * bypasses snomask compression! + */ + bool SetLocalOnly(char letter, bool local); + /** Write to all users with a given snomask. * @param letter The snomask letter to write to * @param text The text to send to the users @@ -103,7 +109,7 @@ class CoreExport SnomaskManager : public Extensible * @param text A format string containing text to send * @param ... Format arguments */ - void WriteToSnoMask(char letter, const char* text, ...); + void WriteToSnoMask(char letter, const char* text, ...) CUSTOM_PRINTF(3, 4); /** Called once per 5 seconds from the mainloop, this flushes any cached * snotices. The way the caching works is as follows: