The InspIRCd Project
Home | Developers | Wiki | Forums | Bug Tracker | SVN | Download
Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members

ModuleNoCTCP Class Reference

Inheritance diagram for ModuleNoCTCP:

Inheritance graph
[legend]
Collaboration diagram for ModuleNoCTCP:

Collaboration graph
[legend]
List of all members.

Public Member Functions

 ModuleNoCTCP (InspIRCd *Me)
virtual ~ModuleNoCTCP ()
virtual Version GetVersion ()
 Returns the version number of a Module.
virtual int OnUserPreMessage (User *user, void *dest, int target_type, std::string &text, char status, CUList &exempt_list)
 Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done.
virtual int OnUserPreNotice (User *user, void *dest, int target_type, std::string &text, char status, CUList &exempt_list)
 Called whenever a user is about to NOTICE A user or a channel, before any processing is done.
virtual void On005Numeric (std::string &output)
 Called when a 005 numeric is about to be output.

Private Attributes

NoCTCPnc

Detailed Description

Definition at line 46 of file m_noctcp.cpp.


Constructor & Destructor Documentation

ModuleNoCTCP::ModuleNoCTCP InspIRCd Me  )  [inline]
 

Definition at line 53 of file m_noctcp.cpp.

References ModeParser::AddMode(), ModuleManager::Attach(), I_On005Numeric, I_OnUserPreMessage, I_OnUserPreNotice, InspIRCd::Modes, InspIRCd::Modules, nc, and Module::ServerInstance.

virtual ModuleNoCTCP::~ModuleNoCTCP  )  [inline, virtual]
 

Definition at line 64 of file m_noctcp.cpp.

References ModeParser::DelMode(), InspIRCd::Modes, nc, and Module::ServerInstance.


Member Function Documentation

virtual Version ModuleNoCTCP::GetVersion  )  [inline, virtual]
 

Returns the version number of a Module.

The method should return a Version object with its version information assigned via Version::Version

Reimplemented from Module.

Definition at line 70 of file m_noctcp.cpp.

References API_VERSION, VF_COMMON, and VF_VENDOR.

virtual void ModuleNoCTCP::On005Numeric std::string output  )  [inline, virtual]
 

Called when a 005 numeric is about to be output.

The module should modify the 005 numeric if needed to indicate its features.

Parameters:
output The 005 string to be modified if neccessary.

Reimplemented from Module.

Definition at line 106 of file m_noctcp.cpp.

References InspIRCd::AddExtBanChar(), and Module::ServerInstance.

virtual int ModuleNoCTCP::OnUserPreMessage User user,
void *  dest,
int  target_type,
std::string text,
char  status,
CUList exempt_list
[inline, virtual]
 

Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done.

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a User* otherwise you must cast it to a Channel*, this is the details of where the message is destined to be sent.

Parameters:
user The user sending the message
dest The target of the message (Channel* or User*)
target_type The type of target (TYPE_USER or TYPE_CHANNEL)
text Changeable text being sent by the user
status The status being used, e.g. PRIVMSG #chan has status== '@', 0 to send to everyone.
exempt_list A list of users not to send to. For channel messages, this will usually contain just the sender. It will be ignored for private messages.
Returns:
1 to deny the NOTICE, 0 to allow it

Reimplemented from Module.

Definition at line 75 of file m_noctcp.cpp.

References OnUserPreNotice().

virtual int ModuleNoCTCP::OnUserPreNotice User user,
void *  dest,
int  target_type,
std::string text,
char  status,
CUList exempt_list
[inline, virtual]
 

Called whenever a user is about to NOTICE A user or a channel, before any processing is done.

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a User* otherwise you must cast it to a Channel*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.

Parameters:
user The user sending the message
dest The target of the message (Channel* or User*)
target_type The type of target (TYPE_USER or TYPE_CHANNEL)
text Changeable text being sent by the user
status The status being used, e.g. PRIVMSG #chan has status== '@', 0 to send to everyone.
exempt_list A list of users not to send to. For channel notices, this will usually contain just the sender. It will be ignored for private notices.
Returns:
1 to deny the NOTICE, 0 to allow it

Reimplemented from Module.

Definition at line 80 of file m_noctcp.cpp.

References CHANOPS_EXEMPT, ERR_NOCTCPALLOWED, Channel::GetStatus(), IS_LOCAL, Channel::IsExtBanned(), Channel::IsModeSet(), Channel::name, User::nick, Module::ServerInstance, STATUS_OP, TYPE_CHANNEL, and User::WriteNumeric().

Referenced by OnUserPreMessage().


Member Data Documentation

NoCTCP* ModuleNoCTCP::nc [private]
 

Definition at line 49 of file m_noctcp.cpp.

Referenced by ModuleNoCTCP(), and ~ModuleNoCTCP().


The documentation for this class was generated from the following file: