use of org.codice.alliance.nsili.common.UCO.Edge in project alliance by codice.
the class DAGConverter method convertDAG.
public MetacardImpl convertDAG(DAG dag, boolean swapCoordinates, String logSourceId) {
MetacardImpl metacard = null;
sourceId = logSourceId;
String metadata;
// Need to have at least 2 nodes and an edge for anything useful
if (dag.nodes != null && dag.edges != null) {
Map<Integer, Node> nodeMap = ResultDAGConverter.createNodeMap(dag.nodes);
DirectedAcyclicGraph<Node, Edge> graph = getNodeEdgeDirectedAcyclicGraph(dag, nodeMap);
metacard = parseGraph(graph, swapCoordinates);
metacard.setSourceId(sourceId);
metadata = dagToXML(dag);
metacard.setMetadata(metadata);
}
return metacard;
}
use of org.codice.alliance.nsili.common.UCO.Edge in project alliance by codice.
the class DAGConverter method getNodeEdgeDirectedAcyclicGraph.
private static DirectedAcyclicGraph<Node, Edge> getNodeEdgeDirectedAcyclicGraph(DAG dag, Map<Integer, Node> nodeMap) {
DirectedAcyclicGraph<Node, Edge> graph = new DirectedAcyclicGraph<>(Edge.class);
for (Node node : dag.nodes) {
graph.addVertex(node);
}
for (Edge edge : dag.edges) {
Node node1 = nodeMap.get(edge.start_node);
Node node2 = nodeMap.get(edge.end_node);
if (node1 != null && node2 != null) {
graph.addEdge(node1, node2);
}
}
return graph;
}
use of org.codice.alliance.nsili.common.UCO.Edge in project alliance by codice.
the class DAGConverterTest method testRecordNodePresent.
@Test
public void testRecordNodePresent() {
DAG dag = new DAG();
DirectedAcyclicGraph<Node, Edge> graph = new DirectedAcyclicGraph<>(Edge.class);
// Create invalid root node
Node rootNode = createRootNode();
graph.addVertex(rootNode);
Node recordNode = new Node(0, NodeType.RECORD_NODE, NsiliConstants.NSIL_CARD, orb.create_any());
graph.addVertex(recordNode);
graph.addEdge(rootNode, recordNode);
NsiliCommonUtils.setUCOEdgeIds(graph);
NsiliCommonUtils.setUCOEdges(rootNode, graph);
dag.edges = NsiliCommonUtils.getEdgeArrayFromGraph(graph);
dag.nodes = NsiliCommonUtils.getNodeArrayFromGraph(graph);
MetacardImpl metacard = dagConverter.convertDAG(dag, false, SOURCE_ID);
assertThat(metacard.getTitle(), nullValue());
}
use of org.codice.alliance.nsili.common.UCO.Edge in project alliance by codice.
the class DAGConverterTest method testReportViewConversion.
/**
* Test the Message View DAG to Metacard
*
* <p>NSIL_PRODUCT NSIL_APPROVAL NSIL_CARD NSIL_FILE NSIL_METADATASECURITY NSIL_RELATED_FILE
* NSIL_SECURITY NSIL_PART NSIL_SECURITY NSIL_COMMON NSIL_COVERAGE NSIL_EXPLOITATION_INFO
* NSIL_REPORT NSIL_ASSOCIATION NSIL_RELATION NSIL_SOURCE NSIL_CARD NSIL_DESTINATION NSIL_CARD
*/
@Test
public void testReportViewConversion() {
DAG dag = new DAG();
DirectedAcyclicGraph<Node, Edge> graph = new DirectedAcyclicGraph<>(Edge.class);
Node productNode = createRootNode();
graph.addVertex(productNode);
addCardNode(graph, productNode);
addFileNode(graph, productNode);
addMetadataSecurity(graph, productNode);
addSecurityNode(graph, productNode);
addReportPart(graph, productNode);
graph.addVertex(productNode);
NsiliCommonUtils.setUCOEdgeIds(graph);
NsiliCommonUtils.setUCOEdges(productNode, graph);
dag.edges = NsiliCommonUtils.getEdgeArrayFromGraph(graph);
dag.nodes = NsiliCommonUtils.getNodeArrayFromGraph(graph);
MetacardImpl metacard = dagConverter.convertDAG(dag, false, SOURCE_ID);
if (SHOULD_PRINT_CARD) {
File file = new File("/tmp/output-report.txt");
if (file.exists()) {
file.delete();
}
try (PrintStream outStream = new PrintStream(file)) {
printMetacard(metacard, outStream);
} catch (IOException ioe) {
// Ignore the error
}
}
// Check top-level meta-card attributes
assertThat(metacard.getTitle(), is(FILE_TITLE));
assertThat(metacard.getId(), is(CARD_ID));
assertThat(metacard.getCreatedDate(), notNullValue());
assertThat(metacard.getEffectiveDate(), notNullValue());
assertThat(metacard.getModifiedDate(), is(cal.getTime()));
assertThat(metacard.getDescription(), is(COM_DESCRIPTION_ABSTRACT));
assertThat(metacard.getLocation(), is(WKT_LOCATION));
assertThat(metacard.getAttribute(Core.RESOURCE_URI).getValue().toString(), is(FILE_PRODUCT_URL));
checkCommonAttributes(metacard);
checkExploitationInfoAttributes(metacard);
checkReportAttributes(metacard);
checkSecurityAttributes(metacard);
checkCoverageAttributes(metacard);
}
use of org.codice.alliance.nsili.common.UCO.Edge in project alliance by codice.
the class DAGConverterTest method testVideoViewConversion.
/**
* Test the Message View DAG to Metacard
*
* <p>NSIL_PRODUCT NSIL_APPROVAL NSIL_CARD NSIL_FILE NSIL_STREAM NSIL_METADATASECURITY
* NSIL_RELATED_FILE NSIL_SECURITY NSIL_PART NSIL_SECURITY NSIL_COMMON NSIL_COVERAGE
* NSIL_EXPLOITATION_INFO NSIL_VIDEO NSIL_ASSOCIATION NSIL_RELATION NSIL_SOURCE NSIL_CARD
* NSIL_DESTINATION NSIL_CARD
*/
@Test
public void testVideoViewConversion() {
DAG dag = new DAG();
DirectedAcyclicGraph<Node, Edge> graph = new DirectedAcyclicGraph<>(Edge.class);
Node productNode = createRootNode();
graph.addVertex(productNode);
addCardNode(graph, productNode);
addStreamNode(graph, productNode);
addMetadataSecurity(graph, productNode);
addSecurityNode(graph, productNode);
addVideoPart(graph, productNode);
graph.addVertex(productNode);
NsiliCommonUtils.setUCOEdgeIds(graph);
NsiliCommonUtils.setUCOEdges(productNode, graph);
dag.edges = NsiliCommonUtils.getEdgeArrayFromGraph(graph);
dag.nodes = NsiliCommonUtils.getNodeArrayFromGraph(graph);
MetacardImpl metacard = dagConverter.convertDAG(dag, false, SOURCE_ID);
if (SHOULD_PRINT_CARD) {
File file = new File("/tmp/output-video.txt");
if (file.exists()) {
file.delete();
}
try (PrintStream outStream = new PrintStream(file)) {
printMetacard(metacard, outStream);
} catch (IOException ioe) {
// Ignore the error
}
}
// Check top-level meta-card attributes
assertThat(metacard.getId(), is(CARD_ID));
assertThat(metacard.getCreatedDate(), notNullValue());
assertThat(metacard.getEffectiveDate(), notNullValue());
assertThat(metacard.getModifiedDate(), is(cal.getTime()));
assertThat(metacard.getDescription(), is(COM_DESCRIPTION_ABSTRACT));
assertThat(metacard.getLocation(), is(WKT_LOCATION));
assertThat(metacard.getAttribute(Core.RESOURCE_URI).getValue().toString(), is(STREAM_SOURCE_URL));
checkCommonAttributes(metacard);
checkExploitationInfoAttributes(metacard);
checkStreamAttributes(metacard);
checkVideoAttributes(metacard);
checkSecurityAttributes(metacard);
checkCoverageAttributes(metacard);
}
Aggregations