1 /* +------------------------------------+
2 * | Inspire Internet Relay Chat Daemon |
3 * +------------------------------------+
5 * InspIRCd: (C) 2002-2008 InspIRCd Development Team
6 * See: http://www.inspircd.org/wiki/index.php/Credits
8 * This program is free but copyrighted software; see
9 * the file COPYING for details.
11 * ---------------------------------------------------
16 class ChannelLogStream : public LogStream
22 ChannelLogStream(InspIRCd *Instance, int loglevel, const std::string &chan) : LogStream(Instance, loglevel), channel(chan)
26 virtual void OnLog(int loglevel, const std::string &type, const std::string &msg)
28 Channel *c = ServerInstance->FindChan(channel);
29 static bool Logging = false;
31 printf("I got called\n");
32 if (loglevel < this->loglvl)
40 Logging = true; // this avoids (rare chance) loops with logging server IO on networks
42 snprintf(buf, MAXBUF, "\2%s\2: %s", type.c_str(), msg.c_str());
44 c->WriteChannelWithServ(ServerInstance->Config->ServerName, "PRIVMSG %s :%s", c->name, buf);
45 ServerInstance->PI->SendChannelPrivmsg(c, 0, buf);
51 /* $ModDesc: Logs output to a channel instead of / as well as a file. */
53 class ModuleChanLog : public Module
56 std::vector<ChannelLogStream*> cls;
58 ModuleChanLog(InspIRCd* Me) : Module(Me)
60 Implementation eventlist[] = { I_OnRehash };
61 ServerInstance->Modules->Attach(eventlist, this, 1);
66 virtual ~ModuleChanLog()
68 std::vector<ChannelLogStream*>::iterator i;
69 while ((i = cls.begin()) != cls.end())
71 ServerInstance->Logs->DelLogStream(*i);
76 virtual void OnRehash(User *user, const std::string ¶meter)
78 ConfigReader Conf(ServerInstance);
80 /* Since the CloseLogs prior to this hook just wiped out our logstreams for us, we just need to wipe the vector. */
81 std::vector<ChannelLogStream*>().swap(cls);
82 int index, max = Conf.Enumerate("log");
85 for (index = 0; index < max; ++index)
87 std::string method = Conf.ReadValue("log", "method", index);
90 //if (method != "file")
93 std::string type = Conf.ReadValue("log", "type", index);
94 std::string level = Conf.ReadValue("log", "level", index);
95 int loglevel = DEFAULT;
100 ServerInstance->Config->debugging = true;
102 else if (level == "verbose")
106 else if (level == "default")
110 else if (level == "sparse")
114 else if (level == "none")
119 std::string target = Conf.ReadValue("log", "target", index);
121 printf("looking at tag with method: %s type: %s level: %s target: %s", method.c_str(), type.c_str(), level.c_str(), target.c_str());
123 ChannelLogStream* c = new ChannelLogStream(ServerInstance, loglevel, target);
124 ServerInstance->Logs->AddLogTypes(type, c, true);
129 virtual Version GetVersion()
131 return Version(1,2,0,1,VF_VENDOR,API_VERSION);
136 MODULE_INIT(ModuleChanLog)