9 void handle_helpop(char**, int, userrec*);
10 bool do_helpop(char**, int, userrec*);
11 void sendtohelpop(userrec*, int, char**);
14 /* $ModDesc: /helpop Command, Works like Unreal helpop */
16 void handle_helpop(char **parameters, int pcnt, userrec *user)
19 std::string output = " ";
22 do_helpop(NULL,pcnt,user);
26 // FIX by brain: make the string lowercase, ConfigReader is
28 char* lower = parameters[0];
29 for (int t = 0; t < strlen(lower); t++)
30 lower[t] = tolower(lower[t]);
32 if (parameters[0][0] == '!')
34 // Force send to all +h users
35 sendtohelpop(user, pcnt, parameters);
36 } else if (parameters[0][0] == '?') {
37 // Force to the helpop system with no forward if not found.
38 if (do_helpop(parameters, pcnt, user) == false) {
39 // Not handled by the Database, Tell the user, and forward.
40 for (int i = 1; output != ""; i++)
42 snprintf(a,MAXBUF,"line%d",i);
43 output = helpop->ReadValue("nohelp", std::string(a), 0);
45 Srv->SendTo(NULL,user,"290 "+std::string(user->nick)+" :"+output);
49 } else if (strchr(user->modes,'o')) {
50 // Its an oper whos not using ?, send to all +h
51 sendtohelpop(user, pcnt, parameters);
53 // Check with the helpop database, if not found send to +h
54 if (do_helpop(parameters, pcnt, user) == false) {
55 // Not handled by the Database, Tell the user, and forward.
56 for (int i = 1; output != ""; i++)
58 snprintf(a,MAXBUF,"line%d",i);
59 output = helpop->ReadValue("nohelpo", std::string(a), 0);
61 Srv->SendTo(NULL,user,"290 "+std::string(user->nick)+" :"+output);
65 sendtohelpop(user, pcnt, parameters);
70 bool do_helpop(char **parameters, int pcnt, userrec *src)
73 std::string output = " "; // a fix bought to you by brain :p
76 if (!parameters) { strcpy(search, "start"); }
77 else { search = parameters[0]; }
79 if (search[0] == '?') { search++; }
81 // Make sure it exists.
82 if (helpop->ReadValue(std::string(search), "line1", 0) == "")
88 // Somethings there.. tell the person who wants to know :p
90 for (int i = 1; output != ""; i++)
92 snprintf(a,MAXBUF,"line%d",i);
93 output = helpop->ReadValue(std::string(search), std::string(a), 0);
95 Srv->SendTo(NULL,src,"290 "+std::string(src->nick)+" :"+output);
103 void sendtohelpop(userrec *src, int pcnt, char **params)
105 char* first = params[0];
106 if (first[0] == '!') { first++; }
107 std::string line = "*** HELPOPS - From "+std::string(src->nick)+": "+std::string(first)+" ";
108 for (int i = 1; i < pcnt; i++)
110 line = line + std::string(params[i]) + " ";
112 Srv->SendToModeMask("oh",WM_AND,line);
115 class ModuleHelpop : public Module
125 conf = new ConfigReader;
127 h_file = conf->ReadValue("helpop", "file", 0);
130 printf("m_helpop: Helpop file not Specified.");
134 helpop = new ConfigReader(h_file);
135 if (!helpop->Verify())
137 printf("m_helpop: Invalid Helpop File. Please Ensure it exists and is error free.");
141 if ((helpop->ReadValue("nohelp", "line1", 0) == "") ||
142 (helpop->ReadValue("nohelpo", "line1", 0) == "") ||
143 (helpop->ReadValue("start", "line1", 0) == ""))
145 printf("m_helpop: Helpop file is missing important entries. Please check the example conf.");
149 if (!Srv->AddExtendedMode('h',MT_CLIENT,true,0,0))
151 Srv->Log(DEFAULT,"Unable to clame the +h usermode.");
152 printf("m_helpop: Unable to claim the +h usermode!");
156 // Loads of comments, untill supported properly.
157 /*if (!*/Srv->AddCommand("HELPOP",handle_helpop,0,0);/*)
159 Srv->Log(DEFAULT,"Unable to claim the HELPOP command.");
160 printf("m_helpop: Unable to claim the HELPOP command.");
166 virtual bool OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list ¶ms)
168 if ((modechar == 'h') && (type == MT_CLIENT))
175 virtual void OnWhois(userrec* src, userrec* dst) {
176 if (strchr(src->modes,'h'))
178 Srv->SendTo(NULL,src,"310 "+std::string(src->nick)+" "+std::string(dst->nick)+" :is available for help.");
182 virtual void OnOper(userrec* user)
184 char* modes[2]; // only two parameters
185 modes[0] = user->nick; // first parameter is the nick
186 modes[1] = "+h"; // second parameter is the mode
187 Srv->SendMode(modes,2,user); // send these, forming the command "MODE <nick> +h"
190 virtual ~ModuleHelpop()
197 virtual Version GetVersion()
199 return Version(0,0,0,1);
203 class ModuleHelpopFactory : public ModuleFactory
206 ModuleHelpopFactory()
210 ~ModuleHelpopFactory()
214 virtual Module * CreateModule()
216 return new ModuleHelpop;
221 extern "C" void * init_module( void )
223 return new ModuleHelpopFactory;