From 104320aa6ad0dc576b425bf4e74f5a673ea2bc4a Mon Sep 17 00:00:00 2001 From: Itay Mizeretz Date: Sun, 17 Sep 2017 18:54:35 +0300 Subject: [PATCH] Fix bug in displaying edge --- monkey_island/cc/resources/telemetry.py | 5 +++-- monkey_island/cc/services/edge.py | 1 + .../cc/ui/src/components/pages/MapPage.js | 15 ++++++++++++--- 3 files changed, 16 insertions(+), 5 deletions(-) diff --git a/monkey_island/cc/resources/telemetry.py b/monkey_island/cc/resources/telemetry.py index 760b72003..4db48e010 100644 --- a/monkey_island/cc/resources/telemetry.py +++ b/monkey_island/cc/resources/telemetry.py @@ -122,7 +122,7 @@ class Telemetry(flask_restful.Resource): def process_scan_telemetry(self, telemetry_json): edge = self.get_edge_by_scan_or_exploit_telemetry(telemetry_json) data = telemetry_json['data']['machine'] - data.pop("ip_addr") + ip_address = data.pop("ip_addr") new_scan = \ { "timestamp": telemetry_json["timestamp"], @@ -131,7 +131,8 @@ class Telemetry(flask_restful.Resource): } mongo.db.edge.update( {"_id": edge["_id"]}, - {"$push": {"scans": new_scan}} + {"$push": {"scans": new_scan}, + "$set": {"ip_address": ip_address}} ) node = mongo.db.node.find_one({"_id": edge["to"]}) diff --git a/monkey_island/cc/services/edge.py b/monkey_island/cc/services/edge.py index 7f93205f4..320c197fc 100644 --- a/monkey_island/cc/services/edge.py +++ b/monkey_island/cc/services/edge.py @@ -60,6 +60,7 @@ class EdgeService: "id": edge["_id"], "from": edge["from"], "to": edge["to"], + "ip_address": edge["ip_address"], "services": services, "os": os, "exploits": exploits diff --git a/monkey_island/cc/ui/src/components/pages/MapPage.js b/monkey_island/cc/ui/src/components/pages/MapPage.js index 57d88eba7..2f99e24fe 100644 --- a/monkey_island/cc/ui/src/components/pages/MapPage.js +++ b/monkey_island/cc/ui/src/components/pages/MapPage.js @@ -69,9 +69,18 @@ class MapPageComponent extends React.Component { .then(res => this.setState({selected: res, selectedType: 'node'})); } else if (event.edges.length === 1) { - fetch('/api/netmap/edge?id='+event.edges[0]) - .then(res => res.json()) - .then(res => this.setState({selected: res.edge, selectedType: 'edge'})); + let edgeGroup = this.state.graph.edges.filter( + function(edge) { + return edge['id'] === event.edges[0]; + })[0]['group']; + if (edgeGroup == 'island') { + console.log('selection cleared.'); // eslint-disable-line no-console + this.setState({selected: null, selectedType: null}); + } else { + fetch('/api/netmap/edge?id='+event.edges[0]) + .then(res => res.json()) + .then(res => this.setState({selected: res.edge, selectedType: 'edge'})); + } } else { console.log('selection cleared.'); // eslint-disable-line no-console