X-Git-Url: https://gerrit.onap.org/r/gitweb?p=dmaap%2Fdatarouter.git;a=blobdiff_plain;f=datarouter-node%2Fsrc%2Fmain%2Fjava%2Forg%2Fonap%2Fdmaap%2Fdatarouter%2Fnode%2FIsFrom.java;h=534b2b356ebea9ec474ad43a1b3fc11418849a71;hp=7e3b4bff959ef287a1d769ba00fd6918f1c5b687;hb=5e6a9f65049e8e8d39e8dcab227e5d75b328b173;hpb=1841cb5d8da7b21996f8faad9d24f858e6ce8a41 diff --git a/datarouter-node/src/main/java/org/onap/dmaap/datarouter/node/IsFrom.java b/datarouter-node/src/main/java/org/onap/dmaap/datarouter/node/IsFrom.java index 7e3b4bff..534b2b35 100644 --- a/datarouter-node/src/main/java/org/onap/dmaap/datarouter/node/IsFrom.java +++ b/datarouter-node/src/main/java/org/onap/dmaap/datarouter/node/IsFrom.java @@ -24,6 +24,10 @@ package org.onap.dmaap.datarouter.node; +import com.att.eelf.configuration.EELFLogger; +import com.att.eelf.configuration.EELFManager; + +import java.io.IOException; import java.util.*; import java.net.*; @@ -34,6 +38,7 @@ public class IsFrom { private long nextcheck; private String[] ips; private String fqdn; + private static EELFLogger logger = EELFManager.getInstance().getLogger(IsFrom.class); /** * Configure the JVM DNS cache to have a 10 second TTL. This needs to be called very very early or it won't have any effect. @@ -59,22 +64,37 @@ public class IsFrom { long now = System.currentTimeMillis(); if (now > nextcheck) { nextcheck = now + 10000; - Vector v = new Vector(); + ArrayList hostAddrArray = new ArrayList<>(); try { InetAddress[] addrs = InetAddress.getAllByName(fqdn); - for (InetAddress a : addrs) { - v.add(a.getHostAddress()); + for (InetAddress addr : addrs) { + hostAddrArray.add(addr.getHostAddress()); } - } catch (Exception e) { + } catch (UnknownHostException e) { + logger.error("IsFrom: UnknownHostEx: " + e.toString(), e); + } + ips = hostAddrArray.toArray(new String[0]); + logger.info("IsFrom: DNS ENTRIES FOR FQDN " + fqdn + " : " + Arrays.toString(ips)); + } + for (String ipAddr : ips) { + if (ipAddr.equals(ip)) { + return true; } - ips = v.toArray(new String[v.size()]); } - for (String s : ips) { - if (s.equals(ip)) { - return (true); + return false; + } + + synchronized boolean isReachable(String ip) { + try { + if (InetAddress.getByName(ip).isReachable(1000)) { + return true; } + } catch (UnknownHostException e) { + logger.error("IsFrom: UnknownHostEx: " + e.toString(), e); + } catch (IOException e) { + logger.error("IsFrom: Failed to parse IP : " + ip + " : " + e.toString(), e); } - return (false); + return false; } /**