mirror of
https://github.com/inspircd/inspircd.git
synced 2025-03-21 16:39:02 -04:00
Fix for new API
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@4219 e03df62e-2008-0410-955e-edbf42e46eb7
This commit is contained in:
parent
5cf80cf42c
commit
b720c60d2e
@ -25,12 +25,39 @@ using namespace std;
|
|||||||
static ConfigReader *helpop;
|
static ConfigReader *helpop;
|
||||||
static Server *Srv;
|
static Server *Srv;
|
||||||
|
|
||||||
void handle_helpop(char**, int, userrec*);
|
|
||||||
bool do_helpop(char**, int, userrec*);
|
bool do_helpop(char**, int, userrec*);
|
||||||
void sendtohelpop(userrec*, int, char**);
|
void sendtohelpop(userrec*, int, char**);
|
||||||
|
|
||||||
/* $ModDesc: /helpop Command, Works like Unreal helpop */
|
/* $ModDesc: /helpop Command, Works like Unreal helpop */
|
||||||
|
|
||||||
|
class Helpop : public ModeHandler
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Helpop() : ModeHandler('h', 0, 0, false, MODETYPE_USER, true) { }
|
||||||
|
|
||||||
|
ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding)
|
||||||
|
{
|
||||||
|
if (adding)
|
||||||
|
{
|
||||||
|
if (!dest->IsModeSet('h'))
|
||||||
|
{
|
||||||
|
dest->SetMode('h',true);
|
||||||
|
return MODEACTION_ALLOW;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (dest->IsModeSet('h'))
|
||||||
|
{
|
||||||
|
dest->SetMode('h',false);
|
||||||
|
return MODEACTION_ALLOW;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return MODEACTION_DENY;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
class cmd_helpop : public command_t
|
class cmd_helpop : public command_t
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -169,6 +196,7 @@ class ModuleHelpop : public Module
|
|||||||
ConfigReader *conf;
|
ConfigReader *conf;
|
||||||
std::string h_file;
|
std::string h_file;
|
||||||
cmd_helpop* mycommand;
|
cmd_helpop* mycommand;
|
||||||
|
Helpop* ho;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ModuleHelpop(Server* Me)
|
ModuleHelpop(Server* Me)
|
||||||
@ -177,12 +205,8 @@ class ModuleHelpop : public Module
|
|||||||
Srv = Me;
|
Srv = Me;
|
||||||
|
|
||||||
ReadConfig();
|
ReadConfig();
|
||||||
if (!Srv->AddExtendedMode('h',MT_CLIENT,true,0,0))
|
ho = new Helpop();
|
||||||
{
|
Srv->AddMode(ho, 'h');
|
||||||
Srv->Log(DEFAULT,"Unable to claim the +h usermode.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
mycommand = new cmd_helpop();
|
mycommand = new cmd_helpop();
|
||||||
Srv->AddCommand(mycommand);
|
Srv->AddCommand(mycommand);
|
||||||
}
|
}
|
||||||
@ -211,7 +235,7 @@ class ModuleHelpop : public Module
|
|||||||
|
|
||||||
void Implements(char* List)
|
void Implements(char* List)
|
||||||
{
|
{
|
||||||
List[I_OnRehash] = List[I_OnExtendedMode] = List[I_OnWhois] = 1;
|
List[I_OnRehash] = List[I_OnWhois] = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void OnRehash(const std::string ¶meter)
|
virtual void OnRehash(const std::string ¶meter)
|
||||||
@ -223,18 +247,9 @@ class ModuleHelpop : public Module
|
|||||||
ReadConfig();
|
ReadConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual int OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list ¶ms)
|
|
||||||
{
|
|
||||||
if ((modechar == 'h') && (type == MT_CLIENT))
|
|
||||||
{
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnWhois(userrec* src, userrec* dst)
|
virtual void OnWhois(userrec* src, userrec* dst)
|
||||||
{
|
{
|
||||||
if (dst->modes['h'-65])
|
if (dst->IsModeSet('h'))
|
||||||
{
|
{
|
||||||
Srv->SendTo(NULL,src,"310 "+std::string(src->nick)+" "+std::string(dst->nick)+" :is available for help.");
|
Srv->SendTo(NULL,src,"310 "+std::string(src->nick)+" "+std::string(dst->nick)+" :is available for help.");
|
||||||
}
|
}
|
||||||
@ -244,6 +259,7 @@ class ModuleHelpop : public Module
|
|||||||
{
|
{
|
||||||
DELETE(conf);
|
DELETE(conf);
|
||||||
DELETE(helpop);
|
DELETE(helpop);
|
||||||
|
DELETE(ho);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual Version GetVersion()
|
virtual Version GetVersion()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user