+/* EventLogger.c - NeonServ v5.6
+ * Copyright (C) 2011-2012 Philipp Kreil (pk910)
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
#include "EventLogger.h"
#include "modcmd.h"
#include "UserNode.h"
#include "ChanNode.h"
#include "DBHelper.h"
+#include "log.h"
static struct Event *first_event = NULL, *last_event = NULL;
-struct Event *createEvent(struct ClientSocket *client, struct UserNode *user, struct ChanNode *chan, char *command, char **args, int argc, int flags) {
+struct Event *createEvent(struct ClientSocket *client, struct UserNode *user, struct ChanNode *chan, struct cmd_binding *command, char **args, int argc, int flags) {
struct Event *event = malloc(sizeof(*event));
if (!event)
{
- perror("malloc() failed");
+ printf_log("main", LOG_ERROR, "%s:%d malloc() failed", __FILE__, __LINE__);
return NULL;
}
event->client = client;
event->user = user;
event->chan = chan;
event->event_time = time(0);
- event->command = strdup(command);
+ event->command = command;
char arguments[MAXLEN];
int argpos = 0;
int i;
void logEvent(struct Event *event) {
char fullcmd[MAXLEN];
- sprintf(fullcmd, "%s %s", event->command, event->arguments);
+ sprintf(fullcmd, "%s %s", event->command->func->name, event->arguments);
if((event->flags & CMDFLAG_LOG) && event->chan) {
char *auth = ((event->user->flags & USERFLAG_ISAUTHED) ? event->user->auth : "*");
loadChannelSettings(event->chan);
if((event->chan->flags & CHANFLAG_CHAN_REGISTERED))
printf_mysql_query("INSERT INTO `godlog` (`godlog_cid`, `godlog_uid`, `godlog_time`, `godlog_cmd`) VALUES ('%d', '%d', UNIX_TIMESTAMP(), '%s')", event->chan->channel_id, userid, escape_string(fullcmd));
}
+ printf_log("main", LOG_OVERRIDE, "[%s:%s (%s)] %s", (event->chan ? event->chan->name : "*"), event->user->nick, auth, fullcmd);
}
}
if(last->next == NULL) break;
last_event = last;
}
- free(event->command);
free(event->arguments);
free(event);
}