diff options
author | aquanight <aquanight@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-03-23 20:43:35 +0000 |
---|---|---|
committer | aquanight <aquanight@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-03-23 20:43:35 +0000 |
commit | 743c10e4ca5acd45e670b335a07b5bf3ab754ab6 (patch) | |
tree | b71daa8b64cbbcdaba191afd9709dd896be12a6b /include/users.h | |
parent | 68730d4c9701b34c962302e6410908865fb2ba28 (diff) |
Add ability to control what opertypes can set what operonly user/chan modes. This works the same way as commands, in that modes allowed by classes are added together, and * allows all.
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9176 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'include/users.h')
-rw-r--r-- | include/users.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/include/users.h b/include/users.h index d1f61932e..a12282ac9 100644 --- a/include/users.h +++ b/include/users.h @@ -18,6 +18,8 @@ #include "connection.h" #include "dns.h" +#include "mode.h" + /** Channel status for a user */ enum ChanStatus { @@ -455,6 +457,12 @@ class CoreExport User : public connection std::map<std::string, bool>* AllowedOperCommands; + /** Allowed user modes from oper classes. */ + bool AllowedUserModes[64]; + + /** Allowed channel modes from oper classes. */ + bool AllowedChanModes[64]; + public: /** Contains a pointer to the connect class a user is on from - this will be NULL for remote connections. * The pointer is guarenteed to *always* be valid. :) @@ -755,6 +763,15 @@ class CoreExport User : public connection */ bool HasPermission(const std::string &command); + /** Returns true or false if a user can set a privileged user or channel mode. + * This is done by looking up their oper type from User::oper, then referencing + * this to their oper classes, and checking the modes they can set. + * @param mode The mode the check + * @param type ModeType (MODETYPE_CHANNEL or MODETYPE_USER). + * @return True if the user can set or unset this mode. + */ + bool HasModePermission(unsigned char mode, ModeType type); + /** Calls read() to read some data for this user using their fd. * @param buffer The buffer to read into * @param size The size of data to read |