All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.nesscomputing.syslog4j.impl.AbstractSyslog Maven / Gradle / Ivy

Go to download

Syslog4j provides client and server implementations of the BSD Syslog protocol (RFC 3164) and the structured syslog" protocol (RFC5424).

There is a newer version: 0.9.47-NESS-8
Show newest version
/**
 *
 * (C) Copyright 2008-2011 syslog4j.org
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the GNU Lesser General Public License
 * (LGPL) version 2.1 which accompanies this distribution, and is available at
 * http://www.gnu.org/licenses/lgpl-2.1.html
 *
 * This library 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
 * Lesser General Public License for more details.
 */
package com.nesscomputing.syslog4j.impl;

import static com.nesscomputing.syslog4j.SyslogConstants.IDENT_SUFFIX_DEFAULT;

import java.util.List;

import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger;

import com.google.common.collect.Lists;
import com.nesscomputing.syslog4j.SyslogBackLogHandlerIF;
import com.nesscomputing.syslog4j.SyslogConfigIF;
import com.nesscomputing.syslog4j.SyslogFacility;
import com.nesscomputing.syslog4j.SyslogIF;
import com.nesscomputing.syslog4j.SyslogLevel;
import com.nesscomputing.syslog4j.SyslogMessageIF;
import com.nesscomputing.syslog4j.SyslogMessageModifierIF;
import com.nesscomputing.syslog4j.SyslogMessageProcessorIF;
import com.nesscomputing.syslog4j.SyslogRuntimeException;
import com.nesscomputing.syslog4j.impl.message.processor.SyslogMessageProcessor;
import com.nesscomputing.syslog4j.impl.message.processor.structured.StructuredSyslogMessageProcessor;
import com.nesscomputing.syslog4j.impl.message.structured.StructuredSyslogMessage;
import com.nesscomputing.syslog4j.impl.message.structured.StructuredSyslogMessageIF;
import com.nesscomputing.syslog4j.util.SyslogUtility;
/**
* AbstractSyslog provides a base abstract implementation of the SyslogIF.
*
* 

Syslog4j is licensed under the Lesser GNU Public License v2.1. A copy * of the LGPL license is available in the META-INF folder in all * distributions of Syslog4j and in the base directory of the "doc" ZIP.

* * @author <[email protected]> * @version $Id: AbstractSyslog.java,v 1.29 2011/01/11 04:58:52 cvs Exp $ */ public abstract class AbstractSyslog implements SyslogIF { private static final Logger LOG = Logger.getLogger(AbstractSyslog.class); protected String syslogProtocol = null; protected AbstractSyslogConfigIF syslogConfig = null; protected SyslogMessageProcessorIF syslogMessageProcessor = null; protected SyslogMessageProcessorIF structuredSyslogMessageProcessor = null; protected Object backLogStatusSyncObject = new Object(); protected boolean backLogStatus = false; protected List notifiedBackLogHandlers = Lists.newArrayList(); protected boolean getBackLogStatus() { synchronized(this.backLogStatusSyncObject) { return this.backLogStatus; } } /** * @param backLogStatus - true if in a "down" backLog state, false if in an "up" (operational) non-backLog state */ public void setBackLogStatus(boolean backLogStatus) { if (this.backLogStatus != backLogStatus) { synchronized(this.backLogStatusSyncObject) { if (!backLogStatus) { for(int i=0; i 0 && mLength > availableLen)) { mLength = availableLen; } if (mLength <= availableLen) { byte[] data = messageProcessor.createPacketData(h,m,0,mLength); write(level,data); } else { byte[] splitBeginText = this.syslogConfig.getSplitMessageBeginText(); byte[] splitEndText = this.syslogConfig.getSplitMessageEndText(); int pos = 0; int left = mLength; while(left > 0) { boolean firstTime = (pos == 0); boolean doSplitBeginText = splitBeginText != null && !firstTime; boolean doSplitEndText = splitBeginText != null && (firstTime || (left > (availableLen - splitBeginText.length))); int actualAvailableLen = availableLen; actualAvailableLen -= (splitBeginText != null && doSplitBeginText) ? splitBeginText.length : 0; actualAvailableLen -= (splitEndText != null && doSplitEndText) ? splitEndText.length : 0; if (actualAvailableLen > left) { actualAvailableLen = left; } if (actualAvailableLen < 0) { throw new SyslogRuntimeException("Message length < 0; recommendation: increase the size of maxMessageLength"); } byte[] data = messageProcessor.createPacketData(h,m,pos,actualAvailableLen,doSplitBeginText ? splitBeginText : null,doSplitEndText ? splitEndText : null); write(level,data); pos += actualAvailableLen; left -= actualAvailableLen; } } } protected abstract void initialize() throws SyslogRuntimeException; protected abstract void write(SyslogLevel level, byte[] message) throws SyslogRuntimeException; protected String modifyMessage(SyslogLevel level, String message) { List _messageModifiers = this.syslogConfig.getMessageModifiers(); if (_messageModifiers == null || _messageModifiers.size() < 1) { return message; } String _message = message; SyslogFacility facility = this.syslogConfig.getFacility(); for(int i=0; i<_messageModifiers.size(); i++) { SyslogMessageModifierIF messageModifier = _messageModifiers.get(i); _message = messageModifier.modify(this, facility, level, _message); } return _message; } public void backLog(SyslogLevel level, String message, Throwable reasonThrowable) { backLog(level,message,reasonThrowable != null ? reasonThrowable.toString() : "UNKNOWN"); } public void backLog(SyslogLevel level, String message, String reason) { boolean status = getBackLogStatus(); if (!status) { setBackLogStatus(true); } List backLogHandlers = this.syslogConfig.getBackLogHandlers(); for(int i=0; i -1) { newWriterThread.setPriority(syslogConfig.getThreadPriority()); } syslogWriter.setThread(newWriterThread); newWriterThread.start(); return newWriterThread; } public AbstractSyslogWriter createWriter(){ Class clazz = this.syslogConfig.getSyslogWriterClass(); AbstractSyslogWriter newWriter = null; try { newWriter = clazz.newInstance(); newWriter.initialize(this); } catch (InstantiationException ie) { if (this.syslogConfig.isThrowExceptionOnInitialize()) { throw new SyslogRuntimeException(ie); } } catch (IllegalAccessException iae) { if (this.syslogConfig.isThrowExceptionOnInitialize()) { throw new SyslogRuntimeException(iae); } } return newWriter; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy