s
This commit is contained in:
parent
14a521dbed
commit
7c7602a11c
1
pom.xml
1
pom.xml
|
@ -27,7 +27,6 @@
|
|||
<artifactId>crawler</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
</project>
|
|
@ -2,6 +2,9 @@ package com.loafle.overflow.crawler.snmp;
|
|||
|
||||
import com.loafle.overflow.crawler.Crawler;
|
||||
import com.loafle.overflow.crawler.config.Config;
|
||||
import com.loafle.overflow.crawler.config.Connection;
|
||||
import com.loafle.overflow.crawler.config.Item;
|
||||
import com.loafle.overflow.crawler.config.Query;
|
||||
import com.loafle.overflow.crawler.snmp.version.SNMPv2c;
|
||||
import com.loafle.overflow.crawler.snmp.version.SNMPv3;
|
||||
import org.snmp4j.Snmp;
|
||||
|
@ -10,6 +13,8 @@ import org.snmp4j.smi.Address;
|
|||
import org.snmp4j.transport.DefaultUdpTransportMapping;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.LinkedHashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
|
@ -20,67 +25,88 @@ public class SNMPCrawler extends Crawler {
|
|||
@Override
|
||||
public Object getInternal(Config config) {
|
||||
|
||||
|
||||
Object retObj = null;
|
||||
// String targetVer = (String)config.get("version");
|
||||
// switch (targetVer) {
|
||||
// case "v2c":
|
||||
// retObj = getByV2c(config);
|
||||
// break;
|
||||
// case "v3":
|
||||
// retObj = getByV3(config);
|
||||
// break;
|
||||
// default:
|
||||
// new Exception("Unknown SNMP protocol : " + targetVer).printStackTrace();
|
||||
// }
|
||||
String targetVer = (String)config.getTarget().getAuth().get("version");
|
||||
switch (targetVer) {
|
||||
case "v2c":
|
||||
retObj = getByV2c(config);
|
||||
break;
|
||||
case "v3":
|
||||
retObj = getByV3(config);
|
||||
break;
|
||||
default:
|
||||
new Exception("Unknown SNMP protocol : " + targetVer).printStackTrace();
|
||||
}
|
||||
|
||||
return retObj;
|
||||
Map m = (Map<String, String>)retObj;
|
||||
|
||||
Map<String, String> keyMap = new LinkedHashMap<>();
|
||||
List<String> metrics = config.getItems().get(0).getMetrics();
|
||||
int i = 0;
|
||||
for (Object key : m.keySet()) {
|
||||
keyMap.put(metrics.get(i), (String)m.get(key));
|
||||
i++;
|
||||
}
|
||||
|
||||
return keyMap;
|
||||
}
|
||||
|
||||
private Object getByV2c(Config config) {
|
||||
Snmp snmp = null;
|
||||
// TransportMapping<? extends Address> transport = null;
|
||||
// try {
|
||||
// transport = new DefaultUdpTransportMapping();
|
||||
// snmp = new Snmp(transport);
|
||||
// transport.listen();
|
||||
// SNMPv2c snmpV2 = new SNMPv2c(snmp);
|
||||
//
|
||||
// String ip = (String)config.get("ip");
|
||||
// String port = (String)config.get("port");
|
||||
// String community = (String)config.get("community");
|
||||
// String[] oids = (String[])config.get("oids");
|
||||
// String method = (String)config.get("method");
|
||||
//
|
||||
// switch (method) {
|
||||
// case "validate":
|
||||
// return snmpV2.validate(ip, port, community);
|
||||
// case "get":
|
||||
// return snmpV2.get(ip, port, community, oids);
|
||||
// case "walk":
|
||||
// return snmpV2.walk(ip, port, community, oids[0]);
|
||||
// default:
|
||||
// new Exception("Unknown SNMP command : " + method).printStackTrace();
|
||||
// }
|
||||
//
|
||||
// } catch (Exception e) {
|
||||
// e.printStackTrace();
|
||||
// } finally {
|
||||
// if (snmp != null) {
|
||||
// try {
|
||||
// snmp.close();
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
// if (transport != null) {
|
||||
// try {
|
||||
// transport.close();
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
TransportMapping<? extends Address> transport = null;
|
||||
try {
|
||||
transport = new DefaultUdpTransportMapping();
|
||||
snmp = new Snmp(transport);
|
||||
transport.listen();
|
||||
SNMPv2c snmpV2 = new SNMPv2c(snmp);
|
||||
|
||||
Map<String, Object> authInfo = config.getTarget().getAuth();
|
||||
Connection connInfo = config.getTarget().getConnection();
|
||||
List<Item> items = config.getItems();
|
||||
String[] oids = new String[items.get(0).getQueries().size()];
|
||||
for (Item item : items) {
|
||||
List<Query> queries = item.getQueries();
|
||||
for (int i=0; i<queries.size();i++) {
|
||||
oids[i] = queries.get(i).getQuery();
|
||||
}
|
||||
}
|
||||
|
||||
String ip = connInfo.getIp();
|
||||
String port = connInfo.getPort();
|
||||
String community = (String)authInfo.get("community");
|
||||
return snmpV2.get(ip, port, community, oids);
|
||||
|
||||
/*
|
||||
switch (method) {
|
||||
case "validate":
|
||||
return snmpV2.validate(ip, port, community);
|
||||
case "get":
|
||||
return snmpV2.get(ip, port, community, oids);
|
||||
case "walk":
|
||||
return snmpV2.walk(ip, port, community, oids[0]);
|
||||
default:
|
||||
new Exception("Unknown SNMP command : " + method).printStackTrace();
|
||||
}
|
||||
*/
|
||||
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
} finally {
|
||||
if (snmp != null) {
|
||||
try {
|
||||
snmp.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
if (transport != null) {
|
||||
try {
|
||||
transport.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
|
@ -88,51 +114,68 @@ public class SNMPCrawler extends Crawler {
|
|||
Snmp snmp = null;
|
||||
TransportMapping<? extends Address> transport = null;
|
||||
|
||||
// try {
|
||||
// transport = new DefaultUdpTransportMapping();
|
||||
// snmp = new Snmp(transport);
|
||||
// transport.listen();
|
||||
// SNMPv3 snmpV3 = new SNMPv3(snmp);
|
||||
//
|
||||
// String ip = (String)config.get("ip");
|
||||
// String port = (String)config.get("port");
|
||||
// String user = (String)config.get("user");
|
||||
// String authType = (String)config.get("authType");
|
||||
// String authPass = (String)config.get("authPass");
|
||||
// String privType = (String)config.get("privType");
|
||||
// String privPass = (String)config.get("privPass");
|
||||
// String[] oids = (String[])config.get("oids");
|
||||
// String method = (String)config.get("method");
|
||||
//
|
||||
// switch (method) {
|
||||
// case "validate":
|
||||
// return snmpV3.validate(ip, port, user, authType, authPass, privType, privPass);
|
||||
// case "get":
|
||||
// return snmpV3.get(ip, port, user, authType, authPass, privType, privPass, oids);
|
||||
// case "walk":
|
||||
// return snmpV3.walk(ip, port, user, authType, authPass, privType, privPass, oids[0]);
|
||||
// default:
|
||||
// new Exception("Unknown SNMP command : " + method).printStackTrace();
|
||||
// }
|
||||
//
|
||||
// } catch (Exception e) {
|
||||
// new Exception("An Exception happend : " + e.getMessage()).printStackTrace();
|
||||
// } finally {
|
||||
// if (snmp != null) {
|
||||
// try {
|
||||
// snmp.close();
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
// if (transport != null) {
|
||||
// try {
|
||||
// transport.close();
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
try {
|
||||
transport = new DefaultUdpTransportMapping();
|
||||
snmp = new Snmp(transport);
|
||||
transport.listen();
|
||||
SNMPv3 snmpV3 = new SNMPv3(snmp);
|
||||
|
||||
|
||||
Map<String, Object> authInfo = config.getTarget().getAuth();
|
||||
Connection connInfo = config.getTarget().getConnection();
|
||||
List<Item> items = config.getItems();
|
||||
String[] oids = new String[items.get(0).getQueries().size()];
|
||||
for (Item item : items) {
|
||||
List<Query> queries = item.getQueries();
|
||||
for (int i=0; i<queries.size();i++) {
|
||||
oids[i] = queries.get(i).getQuery();
|
||||
}
|
||||
}
|
||||
|
||||
String ip = connInfo.getIp();
|
||||
String port = connInfo.getPort();
|
||||
String method = "get";
|
||||
|
||||
String user = (String)authInfo.get("user");
|
||||
String authType = (String)authInfo.get("authType");
|
||||
String authPass = (String)authInfo.get("authPass");
|
||||
String privType = (String)authInfo.get("privType");
|
||||
String privPass = (String)authInfo.get("privPass");
|
||||
|
||||
return snmpV3.get(ip, port, user, authType, authPass, privType, privPass, oids);
|
||||
|
||||
/*
|
||||
switch (method) {
|
||||
case "validate":
|
||||
return snmpV3.validate(ip, port, user, authType, authPass, privType, privPass);
|
||||
case "get":
|
||||
return snmpV3.get(ip, port, user, authType, authPass, privType, privPass, oids);
|
||||
case "walk":
|
||||
return snmpV3.walk(ip, port, user, authType, authPass, privType, privPass, oids[0]);
|
||||
default:
|
||||
new Exception("Unknown SNMP command : " + method).printStackTrace();
|
||||
}
|
||||
*/
|
||||
|
||||
} catch (Exception e) {
|
||||
new Exception("An Exception happend : " + e.getMessage()).printStackTrace();
|
||||
} finally {
|
||||
if (snmp != null) {
|
||||
try {
|
||||
snmp.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
if (transport != null) {
|
||||
try {
|
||||
transport.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,14 +1,14 @@
|
|||
|
||||
package com.loafle;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||
import com.loafle.overflow.crawler.config.Config;
|
||||
import com.loafle.overflow.crawler.snmp.SNMPCrawler;
|
||||
import com.sun.xml.internal.ws.api.ResourceLoader;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.io.File;
|
||||
import java.util.Map;
|
||||
import java.util.SortedSet;
|
||||
import java.util.TreeSet;
|
||||
|
||||
public class AppTest {
|
||||
|
||||
|
@ -24,41 +24,27 @@ public class AppTest {
|
|||
* loafle3 MD5 "qwer5795" : AUTHNOPRIV
|
||||
* loafle4 :NOAUTHNOPRIV
|
||||
*/
|
||||
|
||||
@Test
|
||||
public void testSNMP() {
|
||||
public void testSNMP() throws Exception {
|
||||
SNMPCrawler c = new SNMPCrawler();
|
||||
Map config = new HashMap();
|
||||
ObjectMapper mapper = new ObjectMapper();
|
||||
String p = ResourceLoader.class.getClass().getResource("/config/examplev3.json").getPath();
|
||||
Config config = mapper.readValue(new File(p),Config.class);
|
||||
|
||||
config.put("ip", "192.168.1.215");
|
||||
config.put("port", "161");
|
||||
Object result = c.getInternal(config);
|
||||
|
||||
// config.put("version", "v2c");
|
||||
// config.put("community", "public");
|
||||
// config.put("method", "get");
|
||||
// config.put("oids", new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
|
||||
|
||||
config.put("version", "v3");
|
||||
config.put("user", "loafle");
|
||||
config.put("authType", "MD5");
|
||||
config.put("authPass", "qwer5795");
|
||||
config.put("privType", "DES");
|
||||
config.put("privPass", "qweqwe123");
|
||||
config.put("method", "walk");
|
||||
config.put("oids", new String[]{"1.3.6.1.2.1.25.2.3.1.3"});
|
||||
|
||||
// Object result = c.getInternal(config);
|
||||
//
|
||||
// if(result instanceof Boolean) {
|
||||
// System.out.println("validate : " + result);
|
||||
// }else {
|
||||
// printResult((Map<String, String>)result);
|
||||
// }
|
||||
if(result instanceof Boolean) {
|
||||
System.out.println("validate : " + result);
|
||||
}else {
|
||||
printResult((Map<String, String>)result);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void printResult(Map<String, String> result) {
|
||||
for (Map.Entry<String, String> entry : result.entrySet()) {
|
||||
System.out.printf("oid: %s - value: %s\n", entry.getKey(), entry.getValue());
|
||||
System.out.printf(" %s - %s\n", entry.getKey(), entry.getValue());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
58
src/test/resources/config/examplev2.json
Normal file
58
src/test/resources/config/examplev2.json
Normal file
|
@ -0,0 +1,58 @@
|
|||
{
|
||||
"id" : "insanity",
|
||||
"target" : {
|
||||
"connection" : {
|
||||
"ip" : "192.168.1.215",
|
||||
"port" : "161",
|
||||
"ssl" : false,
|
||||
"portType" : "udp"
|
||||
},
|
||||
"auth" : {
|
||||
"community" : "public",
|
||||
"version" : "v2c"
|
||||
}
|
||||
},
|
||||
"schedule" : {
|
||||
"interval" : "10"
|
||||
},
|
||||
"crawler" : {
|
||||
"name":"snmp_crawler",
|
||||
"container":"java"
|
||||
},
|
||||
"items" : [
|
||||
{
|
||||
"metrics" : [
|
||||
"mem.total",
|
||||
"mem.free",
|
||||
"mem.shared",
|
||||
"mem.buffered",
|
||||
"mem.cached",
|
||||
"mem.totalFree",
|
||||
"swap.avaliable"
|
||||
],
|
||||
"queries":[
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.5.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.6.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.13.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.14.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.15.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.11.0"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.4.1.2021.4.4.0"
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
42
src/test/resources/config/examplev3.json
Normal file
42
src/test/resources/config/examplev3.json
Normal file
|
@ -0,0 +1,42 @@
|
|||
{
|
||||
"id" : "insanity",
|
||||
"target" : {
|
||||
"connection" : {
|
||||
"ip" : "192.168.1.215",
|
||||
"port" : "161",
|
||||
"ssl" : false,
|
||||
"portType" : "udp"
|
||||
},
|
||||
"auth" : {
|
||||
"version" : "v3",
|
||||
"user" : "loafle",
|
||||
"authType" : "MD5",
|
||||
"authPass" : "qwer5795",
|
||||
"privType" : "DES",
|
||||
"privPass" : "qweqwe123"
|
||||
}
|
||||
},
|
||||
"schedule" : {
|
||||
"interval" : "10"
|
||||
},
|
||||
"crawler" : {
|
||||
"name":"snmp_crawler",
|
||||
"container":"java"
|
||||
},
|
||||
"items" : [
|
||||
{
|
||||
"metrics" : [
|
||||
"nic[0].inoctets",
|
||||
"nic[1].inoctets"
|
||||
],
|
||||
"queries":[
|
||||
{
|
||||
"query" : "1.3.6.1.2.1.2.2.1.10.1"
|
||||
},
|
||||
{
|
||||
"query" : ".1.3.6.1.2.1.2.2.1.10.2"
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
Loading…
Reference in New Issue
Block a user