/* */ #include "inspircd_config.h" #include "base.h" #include #include #include #ifndef __CHANNELS_H__ #define __CHANNELS_H__ /** Holds an entry for a ban list, exemption list, or invite list. * This class contains a single element in a channel list, such as a banlist. */ class HostItem : public classbase { public: time_t set_time; char set_by[NICKMAX]; char data[MAXBUF]; HostItem() { /* stub */ } virtual ~HostItem() { /* stub */ } }; // banlist is inherited from HostList mainly for readability // reasons only /** A subclass of HostItem designed to hold channel bans (+b) */ class BanItem : public HostItem { }; // same with this... /** A subclass of HostItem designed to hold channel exempts (+e) */ class ExemptItem : public HostItem { }; // and this... /** A subclass of HostItem designed to hold channel invites (+I) */ class InviteItem : public HostItem { }; /** Holds a custom parameter to a module-defined channel mode * e.g. for +L this would hold the channel name. */ class ModeParameter : public classbase { public: char mode; char parameter[MAXBUF]; char channel[CHANMAX]; }; /** Holds a complete ban list */ typedef std::vector BanList; /** Holds a complete exempt list */ typedef std::vector ExemptList; /** Holds a complete invite list */ typedef std::vector InviteList; /** Holds all relevent information for a channel. * This class represents a channel, and contains its name, modes, time created, topic, topic set time, * etc, and an instance of the BanList type. */ class chanrec : public classbase { public: /** The channels name. */ char name[CHANMAX]; /* channel name */ /** Custom modes for the channel. * Plugins may use this field in any way they see fit. */ char custom_modes[MAXMODES]; /* modes handled by modules */ /** Channel topic. * If this is an empty string, no channel topic is set. */ char topic[MAXBUF]; /** Creation time. */ time_t created; /** Time topic was set. * If no topic was ever set, this will be equal to chanrec::created */ time_t topicset; /** The last user to set the topic. * If this member is an empty string, no topic was ever set. */ char setby[NICKMAX]; /** Contains the channel user limit. * If this value is zero, there is no limit in place. */ long limit; /** Contains the channel key. * If this value is an empty string, there is no channel key in place. */ char key[32]; /** Nonzero if the mode +t is set. */ short int topiclock; /** Nonzero if the mode +n is set. */ short int noexternal; /** Nonzero if the mode +i is set. */ short int inviteonly; /** Nonzero if the mode +m is set. */ short int moderated; /** Nonzero if the mode +s is set. * This value cannot be set at the same time as chanrec::c_private */ short int secret; /** Nonzero if the mode +p is set. * This value cannot be set at the same time as chanrec::secret */ short int c_private; /** The list of all bans set on the channel. */ BanList bans; /** Sets or unsets a custom mode in the channels info */ void SetCustomMode(char mode,bool mode_on); /** Sets or unsets the parameters for a custom mode in a channels info */ void SetCustomModeParam(char mode,char* parameter,bool mode_on); /** Returns true if a custom mode is set on a channel */ bool IsCustomModeSet(char mode); /** Returns the parameter for a custom mode on a channel. * For example if "+L #foo" is set, and you pass this method * 'L', it will return '#foo'. If the mode is not set on the * channel, or the mode has no parameters associated with it, * it will return an empty string. */ std::string GetModeParameter(char mode); /** Creates a channel record and initialises it with default values */ chanrec(); virtual ~chanrec() { /* stub */ } }; /* used to hold a channel and a users modes on that channel, e.g. +v, +h, +o * needs to come AFTER struct chanrec */ #define UCMODE_OP 1 #define UCMODE_VOICE 2 #define UCMODE_HOP 4 #define UCMODE_PROTECT 8 #define UCMODE_FOUNDER 16 /** Holds a user's modes on a channel * This class associates a users privilages with a channel by creating a pointer link between * a userrec and chanrec class. The uc_modes member holds a bitmask of which privilages the user * has on the channel, such as op, voice, etc. */ class ucrec : public classbase { public: /** Contains a bitmask of the UCMODE_OP ... UCMODE_FOUNDER values. * If this value is zero, the user has no privilages upon the channel. */ long uc_modes; /** Points to the channel record where the given modes apply. * If the record is not in use, this value will be NULL. */ chanrec *channel; ucrec() { /* stub */ } virtual ~ucrec() { /* stub */ } }; #endif