/*******************************************************************************
* This file is part of OpenNMS(R).
*
* Copyright (C) 2009-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.model.events;
import org.opennms.core.utils.LogUtils;
import org.opennms.netmgt.model.AbstractEntityVisitor;
import org.opennms.netmgt.model.OnmsIpInterface;
import org.opennms.netmgt.model.OnmsMonitoredService;
import org.opennms.netmgt.model.OnmsNode;
import org.opennms.netmgt.xml.event.Event;
public class AddEventVisitor extends AbstractEntityVisitor {
private static final String m_eventSource = "Provisiond";
private final EventForwarder m_eventForwarder;
/**
* <p>Constructor for AddEventVisitor.</p>
*
* @param eventForwarder a {@link org.opennms.netmgt.model.events.EventForwarder} object.
*/
public AddEventVisitor(EventForwarder eventForwarder) {
m_eventForwarder = eventForwarder;
}
/** {@inheritDoc} */
public void visitNode(OnmsNode node) {
LogUtils.infof(this, "Sending nodeAdded Event for %s\n", node);
m_eventForwarder.sendNow(createNodeAddedEvent(node));
}
/** {@inheritDoc} */
public void visitIpInterface(OnmsIpInterface iface) {
LogUtils.infof(this, "Sending nodeGainedInterface Event for %s\n", iface);
m_eventForwarder.sendNow(createNodeGainedInterfaceEvent(iface));
}
/** {@inheritDoc} */
public void visitMonitoredService(OnmsMonitoredService monSvc) {
LogUtils.infof(this, "Sending nodeGainedService Event for %s\n", monSvc);
m_eventForwarder.sendNow(createNodeGainedServiceEvent(monSvc));
}
/**
* <p>createNodeAddedEvent</p>
*
* @param node a {@link org.opennms.netmgt.model.OnmsNode} object.
* @return a {@link org.opennms.netmgt.xml.event.Event} object.
*/
protected Event createNodeAddedEvent(OnmsNode node) {
return EventUtils.createNodeAddedEvent(m_eventSource, node.getId(), node.getLabel(), node.getLabelSource());
}
/**
* <p>createNodeGainedInterfaceEvent</p>
*
* @param iface a {@link org.opennms.netmgt.model.OnmsIpInterface} object.
* @return a {@link org.opennms.netmgt.xml.event.Event} object.
*/
protected Event createNodeGainedInterfaceEvent(OnmsIpInterface iface) {
return EventUtils.createNodeGainedInterfaceEvent(m_eventSource, iface.getNode().getId(), iface.getIpAddress());
}
/**
* <p>createNodeGainedServiceEvent</p>
*
* @param monSvc a {@link org.opennms.netmgt.model.OnmsMonitoredService} object.
* @return a {@link org.opennms.netmgt.xml.event.Event} object.
*/
protected Event createNodeGainedServiceEvent(final OnmsMonitoredService monSvc) {
final OnmsIpInterface iface = monSvc.getIpInterface();
final OnmsNode node = iface.getNode();
LogUtils.debugf(this, "ipinterface = %s", iface);
LogUtils.debugf(this, "snmpinterface = %s", iface.getSnmpInterface());
LogUtils.debugf(this, "node = %s", node);
return EventUtils.createNodeGainedServiceEvent(m_eventSource, monSvc.getNodeId(), iface.getIpAddress(), monSvc.getServiceType().getName(), node.getLabel(), node.getLabelSource(), node.getSysName(), node.getSysDescription());
}
}