/*******************************************************************************
* 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.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import org.opennms.netmgt.config.DataSourceFactory;
/**
* This class represents a singular instance that is used to map trap IP
* addresses to known nodes.
*
* @author <a href="mailto:joed@opennms.org">Johan Edstrom</a>
* @author <a href="mailto:weave@oculan.com">Brian Weaver </a>
* @author <a href="mailto:tarus@opennms.org">Tarus Balog </a>
* @author <a href="http://www.opennms.org/">OpenNMS </a>
*/
final class SyslogdIPMgr {
/**
* The SQL statement used to extract the list of currently known IP
* addresses and their node IDs from the IP Interface table.
*/
private final static String IP_LOAD_SQL = "SELECT ipAddr, nodeid FROM ipInterface";
/**
* A Map of IP addresses and node IDs
*/
private static Map<String,Long> m_knownips = new ConcurrentHashMap<String,Long>();
/**
* Clears and synchronizes the internal known IP address cache with the
* current information contained in the database. To synchronize the cache
* the method opens a new connection to the database, loads the address,
* and then closes it's connection.
*
* @throws java.sql.SQLException
* Thrown if the connection cannot be created or a database
* error occurs.
*/
static synchronized void dataSourceSync() throws SQLException {
java.sql.Connection c = null;
Statement s = null;
try {
// Get database connection
c = DataSourceFactory.getInstance().getConnection();
// Run with it
//
// c.setReadOnly(true);
s = c.createStatement();
final ResultSet rs = s.executeQuery(IP_LOAD_SQL);
if (rs != null) {
m_knownips.clear();
while (rs.next()) {
m_knownips.put(rs.getString(1), rs.getLong(2));
}
rs.close();
}
} finally {
if (s != null) {
try {
s.close();
} catch (final SQLException sqlE) {
}
}
if (c != null) {
try {
c.close();
} catch (final SQLException sqlE) {
}
}
}
}
/**
* Returns the nodeid for the IP Address
*
* @param addr The IP Address to query.
* @return The node ID of the IP Address if known.
*/
static synchronized long getNodeId(final String addr) {
if (addr == null) {
return -1;
}
return longValue(m_knownips.get(addr));
}
/**
* Sets the IP Address and Node ID in the Map.
*
* @param addr The IP Address to add.
* @param nodeid The Node ID to add.
* @return The nodeid if it existed in the map.
*/
static long setNodeId(final String addr, final long nodeid) {
if (addr == null || nodeid == -1)
return -1;
return longValue(m_knownips.put(addr, nodeid));
}
/**
* Removes an address from the node ID map.
*
* @param addr The address to remove from the node ID map.
* @return The nodeid that was in the map.
*/
static long removeNodeId(final String addr) {
if (addr == null)
return -1;
return longValue(m_knownips.remove(addr));
}
private static long longValue(final Long result) {
return (result == null ? -1 : result);
}
} // end SyslodIPMgr