summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/modules/extra/m_sqllog.cpp45
1 files changed, 40 insertions, 5 deletions
diff --git a/src/modules/extra/m_sqllog.cpp b/src/modules/extra/m_sqllog.cpp
index 54fd41798..1121c8755 100644
--- a/src/modules/extra/m_sqllog.cpp
+++ b/src/modules/extra/m_sqllog.cpp
@@ -77,7 +77,7 @@ class ModuleSQLLog : public Module
long InsertNick(std::string nick)
{
long nid = -1;
- SQLRequest* query = new SQLRequest(SQL_RESULT,dbid,"SELECT id,nick FROM ircd_log_actors WHERE actor='"+nick+"'");
+ SQLRequest* query = new SQLRequest(SQL_RESULT,dbid,"SELECT id,actor FROM ircd_log_actors WHERE actor='"+nick+"'");
Request queryrequest((char*)query, this, SQLModule);
SQLResult* result = (SQLResult*)queryrequest.Send();
if (result->GetType() == SQL_OK)
@@ -87,7 +87,7 @@ class ModuleSQLLog : public Module
SQLResult* rowresult = (SQLResult*)rowquery.Send();
if (rowresult->GetType() == SQL_ROW)
{
- nid = atoi(rowresult->GetField("id"));
+ nid = atoi(rowresult->GetField("id").c_str());
delete rowresult;
}
delete rowrequest;
@@ -116,7 +116,7 @@ class ModuleSQLLog : public Module
return nid;
}
- void InsertEntry(long category,long nickid,long hostid,long sourceid,unsigned long date);
+ void InsertEntry(long category,long nickid,long hostid,long sourceid,unsigned long date)
{
char querybuffer[MAXBUF];
snprintf(querybuffer,MAXBUF,"INSERT INTO ircd_log VALUES('',%d,%d,%d,%d,%lu)",category,nickid,hostid,sourceid,date);
@@ -147,7 +147,7 @@ class ModuleSQLLog : public Module
SQLResult* rowresult = (SQLResult*)rowquery.Send();
if (rowresult->GetType() == SQL_ROW)
{
- hid = atoi(rowresult->GetField("id"));
+ hid = atoi(rowresult->GetField("id").c_str());
delete rowresult;
}
delete rowrequest;
@@ -180,7 +180,7 @@ class ModuleSQLLog : public Module
{
// is the sql module loaded? If not, we don't attempt to do anything.
if (!SQLModule)
- return false;
+ return;
long nickid = InsertNick(nick);
long sourceid = InsertNick(source);
@@ -193,6 +193,41 @@ class ModuleSQLLog : public Module
AddLogEntry(LT_OPER,user->nick,user->host,user->server);
}
+ virtual int OnKill(userrec* source, userrec* dest, std::string reason)
+ {
+ AddLogEntry(LT_KILL,user->nick,user->host,source->nick);
+ return 0;
+ }
+
+ virtual int OnMeshToken(char token,string_list params,serverrec* source,serverrec* reply, std::string tcp_host,std::string ipaddr,int port)
+ {
+ if ((token == 'U') || (token == 's') || (token == 'S'))
+ AddLogEntry(LT_SERVLINK,tcp_host,ipaddr,Srv->GetServerName());
+ return 0;
+ }
+
+ virtual int OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user)
+ {
+ if ((command == "GLINE") || (command == "KLINE") || (command == "ELINE") || (command == "ZLINE"))
+ AddLogEntry(LT_XLINE,user->nick,parameters[0],user->server);
+ return 0;
+ }
+
+ virtual void OnUserConnect(userrec* user)
+ {
+ AddLogEntry(LT_CONNECT,user->nick,user->host,user->server);
+ }
+
+ virtual void OnUserQuit(userrec* user)
+ {
+ AddLogEntry(LT_DISCONNECT,user->nick,user->host,user->server);
+ }
+
+ virtual void OnLoadModule(Module* mod,std::string name)
+ {
+ AddLogEntry(LT_LOADMODULE,name,Srv->GetServerName(),Srv->GetServerName());
+ }
+
virtual ~ModuleSQLLog()
{
delete Srv;