summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-07-09 14:27:40 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-07-09 14:27:40 +0000
commitb720c60d2e46661f003d25d67211d5adad5c9b2b (patch)
treea6267cfba5f97b800102fe4d372a25f1545acfb1 /src
parent5cf80cf42c84f322ce8d53775ea747f8e632c402 (diff)
Fix for new API
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@4219 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src')
-rw-r--r--src/modules/m_helpop.cpp52
1 files changed, 34 insertions, 18 deletions
diff --git a/src/modules/m_helpop.cpp b/src/modules/m_helpop.cpp
index 9a7124dda..9c21201d8 100644
--- a/src/modules/m_helpop.cpp
+++ b/src/modules/m_helpop.cpp
@@ -25,12 +25,39 @@ using namespace std;
static ConfigReader *helpop;
static Server *Srv;
-void handle_helpop(char**, int, userrec*);
bool do_helpop(char**, int, userrec*);
void sendtohelpop(userrec*, int, char**);
/* $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 &parameter, 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
{
public:
@@ -169,6 +196,7 @@ class ModuleHelpop : public Module
ConfigReader *conf;
std::string h_file;
cmd_helpop* mycommand;
+ Helpop* ho;
public:
ModuleHelpop(Server* Me)
@@ -177,12 +205,8 @@ class ModuleHelpop : public Module
Srv = Me;
ReadConfig();
- if (!Srv->AddExtendedMode('h',MT_CLIENT,true,0,0))
- {
- Srv->Log(DEFAULT,"Unable to claim the +h usermode.");
- return;
- }
-
+ ho = new Helpop();
+ Srv->AddMode(ho, 'h');
mycommand = new cmd_helpop();
Srv->AddCommand(mycommand);
}
@@ -211,7 +235,7 @@ class ModuleHelpop : public Module
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 &parameter)
@@ -223,18 +247,9 @@ class ModuleHelpop : public Module
ReadConfig();
}
- virtual int OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params)
- {
- if ((modechar == 'h') && (type == MT_CLIENT))
- {
- return 1;
- }
- return 0;
- }
-
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.");
}
@@ -244,6 +259,7 @@ class ModuleHelpop : public Module
{
DELETE(conf);
DELETE(helpop);
+ DELETE(ho);
}
virtual Version GetVersion()