/** * hermes antispam proxy * Copyright (C) 2006, 2007 Juan José Gutiérrez de Quevedo * * 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 */ #include "UnixLogger.h" extern __thread unsigned long connection_id; extern Configfile cfg; UnixLogger::UnixLogger() { openlog("hermes",LOG_NDELAY,LOG_MAIL); } UnixLogger::~UnixLogger() { closelog(); } void UnixLogger::addMessage(string file,int line,int loglevel,string logmessage) { string message; int sloglevel; //the syslog loglevel is not the same as the hermes log level value if(loglevel<=cfg.getLogLevel()) { sloglevel = LOG_INFO; 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; } message=file+":"+Utils::inttostr(line)+" [" + Utils::inttostr(connection_id) + "] " + logmessage; if(false==cfg.getBackground()) cout << message << endl; syslog(sloglevel, "%s", message.c_str()); } }