/*******************************************************************************
* This file is part of OpenNMS(R).
*
* Copyright (C) 2006-2011 The OpenNMS Group, Inc.
* OpenNMS(R) is Copyright (C) 1999-2011 The OpenNMS Group, Inc.
*
* OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.
*
* OpenNMS(R) 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, either version 3 of the License,
* or (at your option) any later version.
*
* OpenNMS(R) 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 OpenNMS(R). If not, see:
* http://www.gnu.org/licenses/
*
* For more information contact:
* OpenNMS(R) Licensing <license@opennms.org>
* http://www.opennms.org/
* http://www.opennms.com/
*******************************************************************************/
package org.opennms.netmgt.syslogd;
import java.io.IOException;
import java.net.DatagramSocket;
import org.opennms.core.fiber.Fiber;
import org.opennms.core.utils.InetAddressUtils;
import org.opennms.core.utils.ThreadCategory;
import org.opennms.netmgt.config.SyslogdConfig;
import org.opennms.netmgt.config.syslogd.HideMessage;
import org.opennms.netmgt.config.syslogd.UeiList;
import org.opennms.netmgt.xml.event.Event;
import org.opennms.netmgt.xml.event.EventReceipt;
/**
* This class implements the User Datagram Protocol (UDP) event receiver. When
* the an agent sends an event via UDP/IP the receiver will process the event
* and then add the UUIDs to the internal list. If the event is successfully
* processed then an event-receipt is returned to the caller.
*
* @author <a href="mailto:joed@opennms.org">Johan Edstrom</a>
* @author <a href="mailto:weave@oculan.com">Brian Weaver </a>
* @author <a href="http://www.oculan.com">Oculan Corporation </a>
*/
public final class SyslogHandler implements Fiber {
/**
* The UDP receiver thread.
*/
private SyslogReceiver m_receiver;
/**
* The Fiber's status.
*/
private volatile int m_status;
/**
* The UDP socket for receipt and transmission of packets from agents.
*/
private DatagramSocket m_dgSock;
private final String m_ForwardingRegexp;
private final int m_MatchingGroupHost;
private final int m_MatchingGroupMessage;
/**
* A collection of Strings->UEI's
*/
private final UeiList m_UeiList;
/**
* A collection of Strings we do not want to attach to the event.
*/
private final HideMessage m_HideMessages;
/**
* The UDP socket port binding.
*/
private int m_dgPort;
/**
* The IP address to bind to.
*/
private String m_dgIp;
/**
* The log prefix
*/
private String m_logPrefix;
private final String m_DiscardUei;
/**
* Set the Trapd configuration
*/
private static SyslogdConfig m_syslogdConfig;
/**
* <p>Constructor for SyslogHandler.</p>
*/
public SyslogHandler() {
m_dgSock = null;
m_dgPort = m_syslogdConfig.getSyslogPort();
m_dgIp = m_syslogdConfig.getListenAddress();
// the Matching Regexp is broken out into the config-file of syslogd
m_ForwardingRegexp = m_syslogdConfig.getForwardingRegexp();
m_MatchingGroupHost = m_syslogdConfig.getMatchingGroupHost();
m_MatchingGroupMessage = m_syslogdConfig.getMatchingGroupMessage();
m_DiscardUei = m_syslogdConfig.getDiscardUei();
m_UeiList = m_syslogdConfig.getUeiList();
m_HideMessages = m_syslogdConfig.getHideMessages();
m_status = START_PENDING;
m_dgSock = null;
m_receiver = null;
m_logPrefix = null;
}
/**
* <p>setSyslogConfig</p>
*
* @param syslogdConfig a {@link org.opennms.netmgt.config.SyslogdConfig} object.
*/
public static void setSyslogConfig(SyslogdConfig syslogdConfig) {
m_syslogdConfig = syslogdConfig;
}
/**
* <p>start</p>
*/
public synchronized void start() {
if (m_status != START_PENDING)
throw new RuntimeException("The Fiber is in an incorrect state");
m_status = STARTING;
try {
if (m_dgIp != null && m_dgIp.length() != 0) {
m_dgSock = new DatagramSocket(m_dgPort, InetAddressUtils.addr(m_dgIp));
} else {
m_dgSock = new DatagramSocket(m_dgPort);
}
m_receiver = new SyslogReceiver(m_dgSock, m_ForwardingRegexp,
m_MatchingGroupHost,
m_MatchingGroupMessage,
m_UeiList,
m_HideMessages,
m_DiscardUei);
if (m_logPrefix != null) {
m_receiver.setLogPrefix(m_logPrefix);
}
} catch (IOException e) {
throw new java.lang.reflect.UndeclaredThrowableException(e);
}
Thread rThread = new Thread(m_receiver, "Syslog Event Receiver["
+ getIpAddress() + ":" + m_dgPort + "]");
try {
rThread.start();
} catch (RuntimeException e) {
rThread.interrupt();
m_status = STOPPED;
throw e;
}
m_status = RUNNING;
}
/**
* <p>stop</p>
*/
public synchronized void stop() {
if (m_status == STOPPED)
return;
if (m_status == START_PENDING) {
m_status = STOPPED;
return;
}
m_status = STOP_PENDING;
try {
m_receiver.stop();
} catch (InterruptedException e) {
ThreadCategory log = ThreadCategory.getInstance(this.getClass());
log.warn(
"The thread was interrupted while attempting to join sub-threads",
e);
}
m_dgSock.close();
m_status = STOPPED;
}
/**
* <p>getName</p>
*
* @return a {@link java.lang.String} object.
*/
public String getName() {
return "SyslogdHandler[" + getIpAddress() + ":" + m_dgPort + "]";
}
/**
* <p>getStatus</p>
*
* @return a int.
*/
public int getStatus() {
return m_status;
}
/**
* <p>init</p>
*/
public void init() {
}
/**
* <p>destroy</p>
*/
public void destroy() {
}
/**
* <p>setPort</p>
*
* @param port a {@link java.lang.Integer} object.
*/
public void setPort(final Integer port) {
if (m_status == STARTING || m_status == RUNNING
|| m_status == STOP_PENDING)
throw new IllegalStateException("The process is already running");
m_dgPort = port;
}
/**
* <p>getPort</p>
*
* @return a {@link java.lang.Integer} object.
*/
public Integer getPort() {
return m_dgPort;
}
/**
* <p>setIpAddress</p>
*
* @param ipAddress a {@link java.lang.String} object.
* @since 1.8.1
*/
public void setIpAddress(final String ipAddress) {
m_dgIp = ipAddress;
}
/**
* <p>getIpAddress</p>
*
* @return a {@link java.lang.String} object.
* @since 1.8.1
*/
public String getIpAddress() {
if (m_dgIp == null || m_dgIp.length() == 0) {
return "0.0.0.0";
}
return m_dgIp;
}
public void setLogPrefix(String prefix) {
m_logPrefix = prefix;
}
public interface EventHandler {
public boolean processEvent(Event event);
public void receiptSent(EventReceipt receipt);
}
}