/*******************************************************************************
* 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.rtc.utils;
import java.util.Date;
import java.util.Iterator;
import org.opennms.core.utils.ThreadCategory;
import org.opennms.netmgt.EventConstants;
import org.opennms.netmgt.rtc.DataManager;
import org.opennms.netmgt.rtc.RTCManager;
import org.opennms.netmgt.rtc.datablock.RTCCategory;
import org.opennms.netmgt.xml.rtc.EuiLevel;
import org.opennms.netmgt.xml.rtc.Header;
import org.opennms.netmgt.xml.rtc.Node;
/**
* This takes an object of type 'RTCCategory' and creates an XML
* (bytearray)stream of the format to be sent to the user using classes
* generated by castor
*
* @author <A HREF="mailto:sowmya@opennms.org">Sowmya Nataraj </A>
* @author <A HREF="http://www.opennms.org">OpenNMS.org </A>
* @author <A HREF="mailto:sowmya@opennms.org">Sowmya Nataraj </A>
* @author <A HREF="http://www.opennms.org">OpenNMS.org </A>
* @see org.opennms.netmgt.rtc.datablock.RTCCategory
* @see org.opennms.netmgt.xml.rtc.EuiLevel
* @version $Id: $
*/
public class EuiLevelMapper extends Object {
/**
* The header to be sent out for the availability xml(rtceui.xsd)
*/
private Header m_header;
/**
* Constructor
*/
public EuiLevelMapper() {
m_header = new Header();
m_header.setVer("1.9a");
m_header.setMstation("");
}
/**
* Convert the 'RTCCategory' object to a 'EuiLevel' object and marshall to
* XML
*
* @param rtcCat
* the RTCCategory to be converted
* @return a {@link org.opennms.netmgt.xml.rtc.EuiLevel} object.
*/
public EuiLevel convertToEuiLevelXML(RTCCategory rtcCat) {
// current time
Date curDate = new Date();
long curTime = curDate.getTime();
// get the rolling window
long rWindow = RTCManager.getRollingWindow();
ThreadCategory log = ThreadCategory.getInstance(EuiLevelMapper.class);
if (log.isDebugEnabled()) {
log.debug("curdate: " + curDate);
}
// create the data
EuiLevel level = new EuiLevel();
// set created in m_header and add to level
m_header.setCreated(EventConstants.formatToString(curDate));
level.setHeader(m_header);
org.opennms.netmgt.xml.rtc.Category levelCat = new org.opennms.netmgt.xml.rtc.Category();
// get a handle to data
DataManager rtcDataMgr = RTCManager.getDataManager();
synchronized (rtcDataMgr) {
// category label
levelCat.setCatlabel(rtcCat.getLabel());
// value for this category
levelCat.setCatvalue(rtcDataMgr.getValue(rtcCat.getLabel(), curTime, rWindow));
// nodes in this category
Iterator<Long> nodeIter = rtcCat.getNodes().iterator();
while (nodeIter.hasNext()) {
Long rtcNodeid = nodeIter.next();
long nodeID = rtcNodeid.longValue();
Node levelNode = new Node();
levelNode.setNodeid(nodeID);
// value for this node for this category
levelNode.setNodevalue(rtcDataMgr.getValue(nodeID, rtcCat.getLabel(), curTime, rWindow));
// node service count
levelNode.setNodesvccount(rtcDataMgr.getServiceCount(nodeID, rtcCat.getLabel()));
// node service down count
levelNode.setNodesvcdowncount(rtcDataMgr.getServiceDownCount(nodeID, rtcCat.getLabel()));
// add the node
levelCat.addNode(levelNode);
}
}
// add category
level.addCategory(levelCat);
return level;
}
}