2008-12-14 20:12:48 +01:00
|
|
|
/**
|
|
|
|
* hermes antispam proxy
|
|
|
|
* Copyright (C) 2006, 2007 Juan José Gutiérrez de Quevedo <juanjo@gutierrezdequevedo.com>
|
|
|
|
*
|
|
|
|
* 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; version 2 of the License
|
|
|
|
*
|
|
|
|
* 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, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* @author Juan José Gutiérrez de Quevedo <juanjo@gutierrezdequevedo.com>
|
|
|
|
*/
|
|
|
|
#include "UnixLogger.h"
|
|
|
|
|
2011-01-08 02:29:17 +01:00
|
|
|
extern __thread unsigned long connection_id;
|
|
|
|
extern Configfile cfg;
|
|
|
|
|
2008-12-14 20:12:48 +01:00
|
|
|
UnixLogger::UnixLogger()
|
|
|
|
{
|
|
|
|
openlog("hermes",LOG_NDELAY,LOG_MAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
UnixLogger::~UnixLogger()
|
|
|
|
{
|
|
|
|
closelog();
|
|
|
|
}
|
|
|
|
|
2011-01-08 02:29:17 +01:00
|
|
|
void UnixLogger::addMessage(string file,int line,int loglevel,string logmessage)
|
2008-12-14 20:12:48 +01:00
|
|
|
{
|
2011-01-08 02:29:17 +01:00
|
|
|
string message;
|
2011-06-27 13:28:14 +02:00
|
|
|
int sloglevel; //the syslog loglevel is not the same as the hermes log level value
|
2011-01-08 02:29:17 +01:00
|
|
|
|
2011-03-17 21:48:44 +01:00
|
|
|
if(loglevel<=cfg.getLogLevel())
|
|
|
|
{
|
2011-06-27 13:28:14 +02:00
|
|
|
switch(loglevel)
|
|
|
|
{
|
|
|
|
case HERMES_LOG_INFO: sloglevel=LOG_INFO;break;
|
|
|
|
case HERMES_LOG_ERR: sloglevel=LOG_ERR;break;
|
|
|
|
case HERMES_LOG_DEBUG: sloglevel=LOG_DEBUG;
|
|
|
|
}
|
2011-03-17 21:48:44 +01:00
|
|
|
message=file+":"+Utils::inttostr(line)+" [" + Utils::inttostr(connection_id) + "] " + logmessage;
|
|
|
|
if(false==cfg.getBackground())
|
|
|
|
cout << message << endl;
|
2011-06-27 13:28:14 +02:00
|
|
|
syslog(sloglevel,message.c_str());
|
2011-03-17 21:48:44 +01:00
|
|
|
}
|
2008-12-14 20:12:48 +01:00
|
|
|
}
|