Findings resource is now real data from the DB instead of mock data.

This commit is contained in:
Shay Nehmad 2019-08-12 18:21:55 +03:00
parent 2eb34821f8
commit 47375efe42
2 changed files with 33 additions and 40 deletions

View File

@ -1,9 +1,12 @@
import httplib import httplib
import json
import flask_restful import flask_restful
from flask import jsonify from flask import jsonify
from common.data.zero_trust_consts import TESTS_MAP, EXPLANATION_KEY, PILLARS_KEY
from monkey_island.cc.auth import jwt_required from monkey_island.cc.auth import jwt_required
from monkey_island.cc.models.finding import Finding
from monkey_island.cc.services.reporting.report import ReportService from monkey_island.cc.services.reporting.report import ReportService
ZERO_TRUST_REPORT_TYPE = "zero_trust" ZERO_TRUST_REPORT_TYPE = "zero_trust"
@ -35,37 +38,25 @@ class Report(flask_restful.Resource):
def get_all_findings(): def get_all_findings():
return [ all_findings = Finding.objects()
{ enriched_findings = [get_enriched_finding(f) for f in all_findings]
"test": "Monkey 8 found a machine with no AV software active.", return enriched_findings
"conclusive": False,
"pillars": ["Devices"],
"events": [ def get_events_as_dict(events):
{ return [json.loads(event.to_json()) for event in events]
"timestamp": "2019-08-01 14:48:46.112000",
"title": "Monkey performed an action",
"type": "MonkeyAction", def get_enriched_finding(finding):
"message": "log1" test_info = TESTS_MAP[finding.test]
}, { enriched_finding = {
"timestamp": "2019-08-01 14:48:42.112000", # TODO add test explanation per status.
"title": "Analysis", "test": test_info[EXPLANATION_KEY],
"type": "IslandAction", "pillars": test_info[PILLARS_KEY],
"message": "log2" "status": finding.status,
}] "events": get_events_as_dict(finding.events)
}, }
{ return enriched_finding
"test": "Monkey 6 successfully exploited machine XXX with shellshock.",
"conclusive": True,
"pillars": ["Devices", "Networks"],
"events": [
{
"timestamp": "2019-08-01 14:48:46.112000",
"title": "Analysis",
"type": "MonkeyAction",
"message": "log3"
}]
}
]
def get_recommendations_status(): def get_recommendations_status():

View File

@ -2,8 +2,9 @@ import React, {Component} from "react";
import {Timeline, TimelineEvent} from "react-event-timeline"; import {Timeline, TimelineEvent} from "react-event-timeline";
const eventTypeToIcon = { const eventTypeToIcon = {
"MonkeyAction": "fa fa-exclamation-circle fa-2x icon-warning", "monkey_local": "fa fa-exclamation-circle fa-2x icon-warning",
"IslandAction": "fa fa-server fa-2x icon-info", "monkey_network": "fa fa-exclamation-circle fa-2x icon-warning",
"island": "fa fa-server fa-2x icon-info",
null: "fa fa-question-circle fa-2x icon-info", null: "fa fa-question-circle fa-2x icon-info",
}; };
@ -13,15 +14,16 @@ export class EventsTimeline extends Component {
<div> <div>
<Timeline> <Timeline>
{ {
this.props["events"].map(event => ( this.props["events"].map(event => {
<TimelineEvent const event_time = new Date(event.timestamp['$date']).toString();
key={event.timestamp} return (<TimelineEvent
createdAt={event.timestamp} key={event.timestamp['$date']}
createdAt={event_time}
title={event.title} title={event.title}
icon={<i className={eventTypeToIcon[event.type]} />}> icon={<i className={eventTypeToIcon[event.event_type]} />}>
{event.message} {event.message}
</TimelineEvent> </TimelineEvent>)
)) })
} }
</Timeline> </Timeline>
</div> </div>