/* * This file is part of blabouncer (https://www.blatech.co.uk/l_bratch/blabouncer). * Copyright (C) 2019 Luke Bratch <luke@bratch.co.uk>. * * Blabouncer 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, version 3. * * Blabouncer 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 blabouncer. If not, see <http://www.gnu.org/licenses/>. */ #ifndef LOGGING_H_INCLUDED #define LOGGING_H_INCLUDED #include <stdio.h> #include <string.h> #include <time.h> #include <limits.h> #include <sys/stat.h> #include <ctype.h> #include "functions.h" #define MAXTOKENS 100 #define MAXDATASIZE 513 // max number of bytes we can get at once (RFC2812 says 512, plus one for null terminator) #define MAXCHAR 1000 #define SOURCE_SERVER 0 #define SOURCE_CLIENT 1 #define LOG_PRIVMSG 0 #define LOG_JOINPART 1 #define LOG_TOPIC 2 #define LOG_NETWORK 3 #define LOG_QUIT 4 #define LOG_NICK 5 #define LOG_MODE 6 #define DEBUG_CRIT 0 #define DEBUG_SOME 1 #define DEBUG_FULL 2 // Write the line 'str' to the relevant log file such as // '#channel.log' or 'nickname.log'. 'ircdstate->ircnick' // is our own nick and is used to determine which log file // to write to if the type is LOG_PRIVMSG. // 'basedir' is the directory in which the 'logs' directory // will be created in which logs are to be written. // // If LOG_PRIVMSG then it expects a string in the format: // :from!bar@baz PRIVMSG to :hello world // // LOG_PRIVMSG is also used for NOTICEs. // // If LOG_JOINPART then it expects a string in the format: // :nick!bar@baz JOIN :#channel // or // :nick!bar@baz PART #channel // // If LOG_TOPIC then it expects a string in the format: // :nick!bar@baz TOPIC #channel :bla bla bla // // If LOG_NETWORK then it just logs the string verbatim in // a file named 'ircdstate->ircdname'.log. // // If LOG_QUIT then it expects a string in the format: // channelname :nick!bar@baz QUIT :bla bla bla // 'channelname' probably has to be prepended manually by the // caller since it doesn't feature in the raw message from // the IRCd. We need it in logline() to log to the relevant // channel log file. The caller probably has to call logline() // multiple times for each channel the nick was in. // // If LOG_NICK then it expects a string in the format: // channelname :oldnick!bar@baz NICK :newnick // Same manual 'channelname' prepending as LOG_QUIT above. // // If LOG_MODE then it expects a string in the format: // :nick!bar@baz MODE #channel foo bar [foo bar...] // // With the ":foo!bar@baz "prefix being important for all // types. // // Returns 1 on success or 0 on failure. int logline(char *str, struct ircdstate *ircdstate, char *basedir, int type); #endif