]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - include/users.h
irc::tokenstream is a token parser which using std::string and std::vector builds...
[user/henk/code/inspircd.git] / include / users.h
index 25db5eb081eff30a95c60e4ca85c42a188764ce3..30fa937fb1792dae9b5bdebae1eb0352fee5928f 100644 (file)
@@ -43,6 +43,15 @@ enum ClassTypes {
        CC_DENY  = 1
 };
 
+/** RFC1459 channel modes
+ *  */
+enum UserModes {
+       UM_SERVERNOTICE = 's'-65,
+       UM_WALLOPS = 'w'-65,
+       UM_INVISIBLE = 'i'-65,
+       UM_OPERATOR = 'o'-65,
+};
+
 /** Holds a channel name to which a user has been invited.
  */
 class Invited : public classbase
@@ -150,27 +159,27 @@ class userrec : public connection
         */
        char fullname[MAXGECOS+1];
        
-       /** The user's mode string.
-        * This may contain any of the following RFC characters: o, w, s, i
-        * Your module may define other mode characters as it sees fit.
-        * it is limited to length 54, as there can only be a maximum of 52
-        * user modes (26 upper, 26 lower case) a null terminating char, and
-        * an optional + character.
+       /** The user's mode list.
+        * This is NOT a null terminated string! In the 1.1 version of InspIRCd
+        * this is an array of values in a similar way to channel modes.
+        * A value of 1 in field (modeletter-65) indicates that the mode is
+        * set, for example, to work out if mode +s is set, we  check the field
+        * userrec::modes['s'-65] != 0.
+        * The following RFC characters o, w, s, i have constants defined via an
+        * enum, such as UM_SERVERNOTICE and UM_OPETATOR.
         */
-       char modes[54];
+       char modes[64];
 
-       /** This contains a bitmask of the RFC modes +swi,
-        * which can be used for fast lookup when iterating all the users.
-        * It is maintained by the mode parser and matches the character
-        * modes stored in 'modes'.
+       /** What snomasks are set on this user.
+        * This functions the same as the above modes.
         */
-       char modebits;
-       
+       char snomasks[64];
+
        UserChanList chans;
        
        /** The server the user is connected to.
         */
-       char* server;
+       const char* server;
        
        /** The user's away message.
         * If this string is empty, the user is not marked as away.
@@ -259,6 +268,26 @@ class userrec : public connection
         * e.g. through a module, then this method will ignore it and return the true hostname.
         */
        virtual char* GetFullRealHost();
+
+       /*
+        * Create a displayable mode string for this users umodes
+        */
+       const char* FormatNoticeMasks();
+
+       bool userrec::ProcessNoticeMasks(const char *sm);
+
+       bool IsNoticeMaskSet(unsigned char sm);
+
+       void SetNoticeMask(unsigned char sm, bool value);
+
+       /*
+        * Create a displayable mode string for this users umodes
+        */
+       const char* FormatModes();
+
+       bool IsModeSet(unsigned char m);
+
+       void SetMode(unsigned char m, bool value);
        
        /** Returns true if a user is invited to a channel.
         */
@@ -369,13 +398,13 @@ class userrec : public connection
 
 /** Used to hold WHOWAS information
  */
-class WhoWasGroup
+class WhoWasGroup : public classbase
 {
  public:
        char* host;
        char* dhost;
        char* ident;
-       char* server;
+       const char* server;
        char* gecos;
        time_t signon;