#include "channels.h"
#include "modules.h"
#include "helperfuncs.h"
-#include "message.h"
#include <vector>
-
+#include "inspircd.h"
+
extern time_t TIME;
/* $ModDesc: A module overriding /list, and making it safe - stop those sendq problems. */
+
+extern InspIRCd* ServerInstance;
class ModuleSecureList : public Module
{
private:
Server *Srv;
- ListTimer* MyTimer;
public:
ModuleSecureList(Server* Me) : Module::Module(Me)
{
Srv = Me;
-
- MyTimer = new ListTimer(1,Srv);
- Srv->AddTimer(MyTimer);
}
virtual ~ModuleSecureList()
* OnPreCommand()
* Intercept the LIST command.
*/
- virtual int OnPreCommand(const std::string &command, char **parameters, int pcnt, userrec *user, bool validated)
+ virtual int OnPreCommand(const std::string &command, const char** parameters, int pcnt, userrec *user, bool validated)
{
/* If the command doesnt appear to be valid, we dont want to mess with it. */
if (!validated)
if ((command == "LIST") && (TIME < (user->signon+60)) && (!*user->oper))
{
- WriteServ(user->fd,"NOTICE %s :*** You cannot list within the first minute of connecting. Please try again later.",user->nick);
+ user->WriteServ("NOTICE %s :*** You cannot list within the first minute of connecting. Please try again later.",user->nick);
/* Some crap clients (read: mIRC, various java chat applets) muck up if they don't
* receive these numerics whenever they send LIST, so give them an empty LIST to mull over.
*/
- WriteServ(u->fd,"321 %s Channel :Users Name",user->nick);
- WriteServ(u->fd,"323 %s :End of channel list.",user->nick);
+ user->WriteServ("321 %s Channel :Users Name",user->nick);
+ user->WriteServ("323 %s :End of channel list.",user->nick);
return 1;
}
return 0;
virtual Priority Prioritize()
{
- return Srv->PriorityBefore("m_safelist.so");
+ return (Priority)ServerInstance->PriorityBefore("m_safelist.so");
}
};