use of org.opennms.netmgt.config.discovery.IncludeRange in project opennms by OpenNMS.
the class DiscoveryIntegrationIT method testDiscoveryTaskExecutor.
@Test
public void testDiscoveryTaskExecutor() throws Exception {
// Add a range of localhost IP addresses to ping
IncludeRange range = new IncludeRange();
//range.setBegin("127.0.5.1");
//range.setEnd("127.0.5.254");
range.setBegin("192.168.99.1");
range.setEnd("192.168.99.100");
range.setTimeout(5000l);
range.setRetries(0);
DiscoveryConfiguration config = new DiscoveryConfiguration();
config.setInitialSleepTime(0l);
// 100 addresses at 10 per second should take at least 10 seconds
config.setPacketsPerSecond(10d);
config.clearIncludeRanges();
config.addIncludeRange(range);
// Anticipate newSuspect events for all of the addresses
EventAnticipator anticipator = m_eventIpcManager.getEventAnticipator();
StreamSupport.stream(new DiscoveryConfigFactory(config).getConfiguredAddresses().spliterator(), false).forEach(addr -> {
System.out.println("ANTICIPATING: " + str(addr.getAddress()));
Event event = new Event();
event.setUei(EventConstants.NEW_SUSPECT_INTERFACE_EVENT_UEI);
event.setInterfaceAddress(addr.getAddress());
anticipator.anticipateEvent(event);
});
Date beforeTime = new Date();
// Invoke a one-time scan via the DiscoveryTaskExecutor service
m_taskExecutor.handleDiscoveryTask(config);
Date afterTime = new Date();
// Make sure that this call returns quickly as an async. call
long timespan = (afterTime.getTime() - beforeTime.getTime());
System.out.println("Task executor invocation took " + timespan + "ms");
assertTrue("Timespan was not less than 8 seconds: " + timespan, timespan < 8000L);
anticipator.waitForAnticipated(60000);
anticipator.verifyAnticipated();
}
use of org.opennms.netmgt.config.discovery.IncludeRange in project opennms by OpenNMS.
the class RangeChunkerTest method testRangeChunker.
@Test
public void testRangeChunker() throws Exception {
DiscoveryConfiguration config = new DiscoveryConfiguration();
IncludeRange range = new IncludeRange();
range.setBegin("10.1.0.1");
range.setEnd("10.1.4.254");
range.setForeignSource("Routers");
range.setLocation("Raleigh");
range.setRetries(2);
range.setTimeout(500l);
IncludeUrl url = new IncludeUrl();
url.setUrl("file:src/test/resources/included_ip_addresses");
url.setForeignSource("Switches");
url.setLocation("Durham");
url.setRetries(1);
url.setTimeout(5000l);
ExcludeRange excludes = new ExcludeRange();
excludes.setBegin("10.1.3.0");
excludes.setEnd("10.1.5.0");
ExcludeRange excludes2 = new ExcludeRange();
excludes2.setBegin("10.1.1.100");
excludes2.setEnd("10.1.1.150");
Specific specific = new Specific();
specific.setAddress("10.1.3.5");
specific.setForeignSource("Gateway");
specific.setLocation("Co-lo");
specific.setRetries(5);
specific.setTimeout(1000l);
Specific specific2 = new Specific();
specific2.setAddress("10.1.2.5");
specific2.setForeignSource("Routers");
specific2.setLocation("Raleigh");
specific2.setRetries(5);
specific2.setTimeout(1000l);
config.addExcludeRange(excludes);
config.addExcludeRange(excludes2);
config.addIncludeRange(range);
config.addIncludeUrl(url);
config.addSpecific(specific);
config.addSpecific(specific2);
config.setChunkSize(100);
config.setForeignSource("Datacenter");
config.setLocation("RDU");
printJobs(new RangeChunker(ipAddressFilter).chunk(config));
}
use of org.opennms.netmgt.config.discovery.IncludeRange in project opennms by OpenNMS.
the class DiscoveryConfigFactory method getRanges.
/**
* <p>getRanges</p>
*
* @return a {@link java.util.List} object.
*/
@Override
public List<IPPollRange> getRanges() {
final List<IPPollRange> includes = new LinkedList<IPPollRange>();
getReadLock().lock();
try {
Long defaultTimeout = getConfiguration().getTimeout().orElse(DEFAULT_TIMEOUT);
Integer defaultRetries = getConfiguration().getRetries().orElse(DEFAULT_RETRIES);
for (final IncludeRange ir : getConfiguration().getIncludeRanges()) {
// Validate IP range; if invalid, then log and discard this range
try {
InetAddressUtils.toIpAddrBytes(ir.getBegin());
} catch (Throwable e) {
LOG.warn("Begin address of discovery range is invalid, discarding: {}", ir.getBegin());
continue;
}
try {
InetAddressUtils.toIpAddrBytes(ir.getEnd());
} catch (Throwable e) {
LOG.warn("End address of discovery range is invalid, discarding: {}", ir.getEnd());
continue;
}
long timeout = ir.getTimeout().orElse(defaultTimeout);
int retries = ir.getRetries().orElse(defaultRetries);
try {
includes.add(new IPPollRange(ir.getForeignSource().orElse(null), ir.getLocation().orElse(null), ir.getBegin(), ir.getEnd(), timeout, retries));
} catch (final UnknownHostException uhE) {
LOG.warn("Failed to convert address range ({}, {})", ir.getBegin(), ir.getEnd(), uhE);
}
}
return includes;
} finally {
getReadLock().unlock();
}
}
use of org.opennms.netmgt.config.discovery.IncludeRange in project opennms by OpenNMS.
the class DiscoveryConfigFactory method getForeignSource.
@Override
public String getForeignSource(InetAddress address) {
getReadLock().lock();
try {
LOG.debug("Looking for matching foreign source specific IP or IP range with address: {}...", address);
List<Specific> specificCollection = getConfiguration().getSpecifics();
for (Specific specific : specificCollection) {
String ipAddr = specific.getAddress();
if (ipAddr.equals(InetAddressUtils.str(address))) {
String foreignSource = specific.getForeignSource().orElse(null);
LOG.debug("Matched foreign source {} matching address: {} against specific {}.", foreignSource, address, ipAddr);
return foreignSource;
}
}
final byte[] laddr = address.getAddress();
List<IncludeRange> includeRangeCollection = getConfiguration().getIncludeRanges();
for (IncludeRange range : includeRangeCollection) {
if (InetAddressUtils.isInetAddressInRange(laddr, range.getBegin(), range.getEnd())) {
String foreignSource = range.getForeignSource().orElse(null);
LOG.debug("Found foreign source {} with address {} in the range begin: {} and end: {}.", foreignSource, address, range.getBegin(), range.getEnd());
return foreignSource;
}
}
List<IncludeUrl> includeUrlCollection = getConfiguration().getIncludeUrls();
for (IncludeUrl includeUrl : includeUrlCollection) {
String ipAddr = includeUrl.getUrl().orElse("");
if (ipAddr.equals(InetAddressUtils.str(address))) {
String foreignSource = includeUrl.getForeignSource().orElse(null);
LOG.debug("Matched foreign source {} matching address: {} in specified URL.", foreignSource, address);
return foreignSource;
}
}
return getConfiguration().getForeignSource().orElse(null);
} finally {
getReadLock().unlock();
}
}
use of org.opennms.netmgt.config.discovery.IncludeRange in project opennms by OpenNMS.
the class ActionDiscoveryServlet method doPost.
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
LOG.info("Loading Discovery configuration.");
HttpSession sess = request.getSession(true);
DiscoveryConfiguration config = (DiscoveryConfiguration) sess.getAttribute(ATTRIBUTE_DISCOVERY_CONFIGURATION);
if (config == null) {
config = getDiscoveryConfig();
sess.setAttribute(ATTRIBUTE_DISCOVERY_CONFIGURATION, config);
}
//Update general settings from the incoming request parameters
config = GeneralSettingsLoader.load(request, config);
String action = request.getParameter("action");
LOG.debug("action: {}", action);
//add a Specific
if (action.equals(addSpecificAction)) {
LOG.debug("Adding Specific");
String ipAddr = request.getParameter("specificipaddress");
String timeout = request.getParameter("specifictimeout");
String retries = request.getParameter("specificretries");
String foreignSource = request.getParameter("specificforeignsource");
String location = request.getParameter("specificlocation");
Specific newSpecific = new Specific();
newSpecific.setAddress(ipAddr);
if (timeout != null && !"".equals(timeout.trim()) && !timeout.equals(String.valueOf(config.getTimeout().orElse(null)))) {
newSpecific.setTimeout(WebSecurityUtils.safeParseLong(timeout));
}
if (retries != null && !"".equals(retries.trim()) && !retries.equals(String.valueOf(config.getRetries().orElse(null)))) {
newSpecific.setRetries(WebSecurityUtils.safeParseInt(retries));
}
if (foreignSource != null && !"".equals(foreignSource.trim()) && !foreignSource.equals(config.getForeignSource().orElse(null))) {
newSpecific.setForeignSource(foreignSource);
}
if (location != null && !"".equals(location.trim()) && !location.equals(config.getLocation().orElse(MonitoringLocationDao.DEFAULT_MONITORING_LOCATION_ID))) {
newSpecific.setLocation(location);
}
config.addSpecific(newSpecific);
}
//remove 'Specific' from configuration
if (action.equals(removeSpecificAction)) {
LOG.debug("Removing Specific");
String specificIndex = request.getParameter("index");
int index = WebSecurityUtils.safeParseInt(specificIndex);
final int index1 = index;
Specific spec = config.getSpecifics().get(index1);
boolean result = config.removeSpecific(spec);
LOG.debug("Removing Specific result = {}", result);
}
//add an 'Include Range'
if (action.equals(addIncludeRangeAction)) {
LOG.debug("Adding Include Range");
String ipAddrBase = request.getParameter("irbase");
String ipAddrEnd = request.getParameter("irend");
String timeout = request.getParameter("irtimeout");
String retries = request.getParameter("irretries");
String foreignSource = request.getParameter("irforeignsource");
String location = request.getParameter("irlocation");
IncludeRange newIR = new IncludeRange();
newIR.setBegin(ipAddrBase);
newIR.setEnd(ipAddrEnd);
if (timeout != null && !"".equals(timeout.trim()) && !timeout.equals(String.valueOf(config.getTimeout().orElse(null)))) {
newIR.setTimeout(WebSecurityUtils.safeParseLong(timeout));
}
if (retries != null && !"".equals(retries.trim()) && !retries.equals(String.valueOf(config.getRetries().orElse(null)))) {
newIR.setRetries(WebSecurityUtils.safeParseInt(retries));
}
if (foreignSource != null && !"".equals(foreignSource.trim()) && !foreignSource.equals(config.getForeignSource().orElse(null))) {
newIR.setForeignSource(foreignSource);
}
if (location != null && !"".equals(location.trim()) && !location.equals(config.getLocation().orElse(MonitoringLocationDao.DEFAULT_MONITORING_LOCATION_ID))) {
newIR.setLocation(location);
}
config.addIncludeRange(newIR);
}
//remove 'Include Range' from configuration
if (action.equals(removeIncludeRangeAction)) {
LOG.debug("Removing Include Range");
String specificIndex = request.getParameter("index");
int index = WebSecurityUtils.safeParseInt(specificIndex);
final int index1 = index;
IncludeRange ir = config.getIncludeRanges().get(index1);
boolean result = config.removeIncludeRange(ir);
LOG.debug("Removing Include Range result = {}", result);
}
//add an 'Include URL'
if (action.equals(addIncludeUrlAction)) {
LOG.debug("Adding Include URL");
String url = request.getParameter("iuurl");
String timeout = request.getParameter("iutimeout");
String retries = request.getParameter("iuretries");
String foreignSource = request.getParameter("iuforeignsource");
String location = request.getParameter("iulocation");
IncludeUrl iu = new IncludeUrl();
iu.setUrl(url);
if (timeout != null && !"".equals(timeout.trim()) && !timeout.equals(String.valueOf(config.getTimeout().orElse(null)))) {
iu.setTimeout(WebSecurityUtils.safeParseLong(timeout));
}
if (retries != null && !"".equals(retries.trim()) && !retries.equals(String.valueOf(config.getRetries().orElse(null)))) {
iu.setRetries(WebSecurityUtils.safeParseInt(retries));
}
if (foreignSource != null && !"".equals(foreignSource.trim()) && !foreignSource.equals(config.getForeignSource().orElse(null))) {
iu.setForeignSource(foreignSource);
}
if (location != null && !"".equals(location.trim()) && !location.equals(config.getLocation().orElse(MonitoringLocationDao.DEFAULT_MONITORING_LOCATION_ID))) {
iu.setLocation(location);
}
config.addIncludeUrl(iu);
}
//remove 'Include URL' from configuration
if (action.equals(removeIncludeUrlAction)) {
LOG.debug("Removing Include URL");
String specificIndex = request.getParameter("index");
int index = WebSecurityUtils.safeParseInt(specificIndex);
final int index1 = index;
IncludeUrl iu = config.getIncludeUrls().get(index1);
boolean result = config.removeIncludeUrl(iu);
LOG.debug("Removing Include URL result = {}", result);
}
//add an 'Exclude Range'
if (action.equals(addExcludeRangeAction)) {
LOG.debug("Adding Exclude Range");
String ipAddrBegin = request.getParameter("erbegin");
String ipAddrEnd = request.getParameter("erend");
ExcludeRange newER = new ExcludeRange();
newER.setBegin(ipAddrBegin);
newER.setEnd(ipAddrEnd);
config.addExcludeRange(newER);
}
//remove 'Exclude Range' from configuration
if (action.equals(removeExcludeRangeAction)) {
LOG.debug("Removing Exclude Range");
String specificIndex = request.getParameter("index");
int index = WebSecurityUtils.safeParseInt(specificIndex);
final int index1 = index;
ExcludeRange er = config.getExcludeRanges().get(index1);
boolean result = config.removeExcludeRange(er);
LOG.debug("Removing Exclude Range result = {}", result);
}
//save configuration and restart discovery service
if (action.equals(saveAndRestartAction)) {
DiscoveryConfigFactory dcf = null;
try {
StringWriter configString = new StringWriter();
JaxbUtils.marshal(config, configString);
LOG.debug(configString.toString().trim());
dcf = DiscoveryConfigFactory.getInstance();
dcf.saveConfiguration(config);
} catch (Throwable ex) {
LOG.error("Error while saving configuration. {}", ex);
throw new ServletException(ex);
}
EventProxy proxy = null;
try {
proxy = Util.createEventProxy();
} catch (Throwable me) {
LOG.error(me.getMessage());
}
EventBuilder bldr = new EventBuilder(EventConstants.DISCOVERYCONFIG_CHANGED_EVENT_UEI, "ActionDiscoveryServlet");
bldr.setHost("host");
try {
proxy.send(bldr.getEvent());
} catch (Throwable me) {
LOG.error(me.getMessage());
}
LOG.info("Restart Discovery requested!");
sess.removeAttribute(ATTRIBUTE_DISCOVERY_CONFIGURATION);
response.sendRedirect(Util.calculateUrlBase(request, "admin/discovery/config-done.jsp"));
return;
}
sess.setAttribute(ATTRIBUTE_DISCOVERY_CONFIGURATION, config);
RequestDispatcher dispatcher = this.getServletContext().getRequestDispatcher("/admin/discovery/edit-config.jsp");
dispatcher.forward(request, response);
}
Aggregations