00001 /******************************************************************************* 00002 * Copyright (C) 2004 Vintela, Inc. All rights reserved. 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions are met: 00006 * 00007 * - Redistributions of source code must retain the above copyright notice, 00008 * this list of conditions and the following disclaimer. 00009 * 00010 * - Redistributions in binary form must reproduce the above copyright notice, 00011 * this list of conditions and the following disclaimer in the documentation 00012 * and/or other materials provided with the distribution. 00013 * 00014 * - Neither the name of Vintela, Inc. nor the names of its 00015 * contributors may be used to endorse or promote products derived from this 00016 * software without specific prior written permission. 00017 * 00018 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' 00019 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00020 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00021 * ARE DISCLAIMED. IN NO EVENT SHALL Vintela, Inc. OR THE CONTRIBUTORS 00022 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00023 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00024 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00025 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00026 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00027 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00028 * POSSIBILITY OF SUCH DAMAGE. 00029 *******************************************************************************/ 00030 00035 #include "OW_config.h" 00036 #include "OW_SyslogAppender.hpp" 00037 #include "OW_Logger.hpp" 00038 #include "OW_LogMessage.hpp" 00039 #include "OW_Mutex.hpp" 00040 #include "OW_MutexLock.hpp" 00041 #include <syslog.h> 00042 00043 namespace OW_NAMESPACE 00044 { 00045 00047 SyslogAppender::SyslogAppender(const StringArray& components, 00048 const StringArray& categories, 00049 const String& pattern) 00050 : LogAppender(components, categories, pattern) 00051 { 00052 if (!calledOpenLog) 00053 { 00054 openlog( OW_PACKAGE_PREFIX"openwbem", LOG_CONS, LOG_DAEMON ); 00055 calledOpenLog = true; 00056 } 00057 } 00058 00060 SyslogAppender::~SyslogAppender() {} 00061 00063 namespace 00064 { 00065 Mutex syslogGuard; 00066 } 00067 void 00068 SyslogAppender::doProcessLogMessage(const String& formattedMessage, const LogMessage& message) const 00069 { 00070 int syslogPriority; 00071 if (message.category == Logger::STR_FATAL_CATEGORY) 00072 { 00073 syslogPriority = LOG_CRIT; 00074 } 00075 else if (message.category == Logger::STR_ERROR_CATEGORY) 00076 { 00077 syslogPriority = LOG_ERR; 00078 } 00079 else if (message.category == Logger::STR_INFO_CATEGORY) 00080 { 00081 syslogPriority = LOG_INFO; 00082 } 00083 else if (message.category == Logger::STR_DEBUG_CATEGORY) 00084 { 00085 syslogPriority = LOG_DEBUG; 00086 } 00087 else 00088 { 00089 syslogPriority = LOG_INFO; 00090 } 00091 00092 StringArray a = formattedMessage.tokenize("\n"); 00093 MutexLock lock(syslogGuard); 00094 for (size_t i = 0; i < a.size(); ++i) 00095 { 00096 syslog( syslogPriority, "%s", a[i].c_str() ); 00097 } 00098 } 00099 00101 bool SyslogAppender::calledOpenLog = false; 00102 const String SyslogAppender::STR_DEFAULT_MESSAGE_PATTERN("[%t]%m"); 00103 00104 00105 } // end namespace OW_NAMESPACE 00106 00107 00108 00109