Implement the missing queries
This commit is contained in:
parent
687df96022
commit
cdb36b39d2
|
@ -4,9 +4,11 @@ import java.util.List;
|
|||
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientGraphNoTx;
|
||||
|
||||
import de.hsh.inform.orientdb_project.model.EthernetFrameModel;
|
||||
import de.hsh.inform.orientdb_project.model.HostModel;
|
||||
import de.hsh.inform.orientdb_project.model.TcpConnectionModel;
|
||||
import de.hsh.inform.orientdb_project.orientdb.OrientDbHelperService;
|
||||
import de.hsh.inform.orientdb_project.repository.EthernetFrameRepository;
|
||||
import de.hsh.inform.orientdb_project.repository.HostRepository;
|
||||
import de.hsh.inform.orientdb_project.repository.TcpConnectionRepository;
|
||||
import de.hsh.inform.orientdb_project.util.ConfigPropertiesReader;
|
||||
|
@ -36,6 +38,18 @@ public class Main {
|
|||
System.out.println(hm);
|
||||
}
|
||||
|
||||
for(HostModel hm : hr.findAllByConnectionsToOutsideHosts()) {
|
||||
System.out.println(hm);
|
||||
}
|
||||
|
||||
EthernetFrameRepository efr = new EthernetFrameRepository(odhs.getDatabaseDocument());
|
||||
List<EthernetFrameModel> efrbyteResult = efr.findAllByRawData(new byte[] {
|
||||
(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF
|
||||
});
|
||||
for(EthernetFrameModel em : efrbyteResult) {
|
||||
System.out.println(em);
|
||||
}
|
||||
|
||||
// Done
|
||||
odhs.close();
|
||||
}
|
||||
|
|
|
@ -3,6 +3,7 @@ package de.hsh.inform.orientdb_project.model;
|
|||
import org.pcap4j.packet.EthernetPacket;
|
||||
|
||||
import com.orientechnologies.orient.core.metadata.schema.OType;
|
||||
import com.orientechnologies.orient.core.record.impl.ODocument;
|
||||
import com.tinkerpop.blueprints.Vertex;
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientGraphNoTx;
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientVertexType;
|
||||
|
@ -47,14 +48,14 @@ public class EthernetFrameModel {
|
|||
this.microseconds = ms;
|
||||
}
|
||||
|
||||
public EthernetFrameModel(Vertex v) {
|
||||
this.ts = v.getProperty("timestamp");
|
||||
this.ms = v.getProperty("microseconds");
|
||||
this.sourceMac = v.getProperty("sourceMac");
|
||||
this.targetMac = v.getProperty("targetMac");
|
||||
this.rawData = v.getProperty("rawData");
|
||||
this.size = v.getProperty("size");
|
||||
this.payloadSize = v.getProperty("payloadSize");
|
||||
public EthernetFrameModel(ODocument doc) {
|
||||
this.ts = doc.field("timestamp");
|
||||
this.ms = doc.field("microseconds");
|
||||
this.sourceMac = doc.field("sourceMac");
|
||||
this.targetMac = doc.field("targetMac");
|
||||
this.rawData = doc.field("rawData");
|
||||
this.size = doc.field("size");
|
||||
this.payloadSize = doc.field("payloadSize");
|
||||
this.timestamp = ts;
|
||||
this.microseconds = ms;
|
||||
}
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
package de.hsh.inform.orientdb_project.orientdb;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.List;
|
||||
|
||||
import com.orientechnologies.orient.client.remote.OServerAdmin;
|
||||
import com.orientechnologies.orient.core.db.document.ODatabaseDocumentTx;
|
||||
import com.orientechnologies.orient.core.intent.OIntentMassiveInsert;
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientConfigurableGraph.THREAD_MODE;
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientEdgeType;
|
||||
|
@ -38,6 +38,10 @@ public class OrientDbHelperService {
|
|||
this.factory = null;
|
||||
}
|
||||
|
||||
public ODatabaseDocumentTx getDatabaseDocument() {
|
||||
return this.factory.getDatabase();
|
||||
}
|
||||
|
||||
|
||||
public OrientGraphFactory getOrientGraphFactory() {
|
||||
if(this.factory == null) {
|
||||
|
|
|
@ -3,30 +3,32 @@ package de.hsh.inform.orientdb_project.repository;
|
|||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import com.tinkerpop.blueprints.GraphQuery;
|
||||
import com.tinkerpop.blueprints.Vertex;
|
||||
import com.tinkerpop.blueprints.impls.orient.OrientGraphNoTx;
|
||||
import com.orientechnologies.orient.core.db.document.ODatabaseDocumentTx;
|
||||
import com.orientechnologies.orient.core.iterator.ORecordIteratorClass;
|
||||
import com.orientechnologies.orient.core.record.impl.ODocument;
|
||||
|
||||
import de.hsh.inform.orientdb_project.model.EthernetFrameModel;
|
||||
|
||||
public class EthernetFrameRepository {
|
||||
private OrientGraphNoTx ogf;
|
||||
private ODatabaseDocumentTx db;
|
||||
|
||||
public EthernetFrameRepository(OrientGraphNoTx ogf) {
|
||||
this.ogf = ogf;
|
||||
public EthernetFrameRepository(ODatabaseDocumentTx oDatabaseDocumentTx) {
|
||||
this.db = oDatabaseDocumentTx;
|
||||
}
|
||||
|
||||
public List<EthernetFrameModel> findAllByRawData(byte[] content) {
|
||||
GraphQuery gq = this.ogf.query();
|
||||
gq = gq.has("@class", "EthernetFrame");
|
||||
// TODO
|
||||
return this.getListFromVertices(gq.vertices());
|
||||
}
|
||||
|
||||
private List<EthernetFrameModel> getListFromVertices(Iterable<Vertex> vertices) {
|
||||
public List<EthernetFrameModel> findAllByRawData(byte[] needle) {
|
||||
ORecordIteratorClass<ODocument> resultIterator = db.browseClass("EthernetFrame");
|
||||
List<EthernetFrameModel> result = new ArrayList<EthernetFrameModel>();
|
||||
for(Vertex v : vertices) {
|
||||
result.add(new EthernetFrameModel(v));
|
||||
for(ODocument doc : resultIterator) {
|
||||
int found = -1;
|
||||
byte[] rawData = (byte[]) doc.field("rawData");
|
||||
// Manually compare bytes... yay! \o/
|
||||
String bigStr = new String(rawData);
|
||||
String smallStr = new String(needle);
|
||||
found = bigStr.indexOf(smallStr);
|
||||
if(found != -1) {
|
||||
result.add(new EthernetFrameModel(doc));
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
|
|
@ -29,18 +29,20 @@ public class HostRepository {
|
|||
}
|
||||
|
||||
public List<HostModel> findAllByConnectionsToOutsideHosts() {
|
||||
GraphQuery gq = this.ogf.query();
|
||||
gq = gq.has("@class", "Host");
|
||||
// TODO
|
||||
return this.getListFromVertices(gq.vertices());
|
||||
String sql = "" +
|
||||
"SELECT EXPAND(DISTINCT(out)) FROM (SELECT out('hasSourceHost') AS out FROM TcpConnection WHERE out('hasTargetHost').internal = false);";
|
||||
@SuppressWarnings("unchecked") // We know.
|
||||
Iterable<Vertex> vertices = (Iterable<Vertex>) this.ogf.command(new OCommandSQL(sql)).execute();
|
||||
return this.getListFromVertices(vertices);
|
||||
}
|
||||
|
||||
|
||||
public List<HostModel> findByIncomingConnectionOnPort(int port) {
|
||||
GraphQuery gq = this.ogf.query();
|
||||
gq = gq.has("@class", "Host");
|
||||
// TODO
|
||||
return this.getListFromVertices(gq.vertices());
|
||||
public List<HostModel> findAllByIncomingConnectionOnWellKnownPort() {
|
||||
String sql = "" +
|
||||
"SELECT EXPAND(DISTINCT(out)) FROM (SELECT out('hasTargetHost') FROM TcpConnection WHERE targetPort IN (SELECT port FROM WellKnownPort))";
|
||||
@SuppressWarnings("unchecked") // We know.
|
||||
Iterable<Vertex> vertices = (Iterable<Vertex>) this.ogf.command(new OCommandSQL(sql)).execute();
|
||||
return this.getListFromVertices(vertices);
|
||||
}
|
||||
|
||||
private List<HostModel> getListFromVertices(Iterable<Vertex> vertices) {
|
||||
|
|
Loading…
Reference in New Issue