Fix most printing format issues

Improve CSS
Shorten lines
This commit is contained in:
Itay Mizeretz 2017-11-28 17:16:58 +02:00
parent 881cf5e793
commit 88ea57dc88
2 changed files with 104 additions and 40 deletions

View File

@ -3,10 +3,10 @@ import {Col} from 'react-bootstrap';
import BreachedServers from 'components/report-components/BreachedServers'; import BreachedServers from 'components/report-components/BreachedServers';
import ScannedServers from 'components/report-components/ScannedServers'; import ScannedServers from 'components/report-components/ScannedServers';
import {ReactiveGraph} from 'components/reactive-graph/ReactiveGraph'; import {ReactiveGraph} from 'components/reactive-graph/ReactiveGraph';
import {options, edgeGroupToColor} from 'components/map/MapOptions'; import {edgeGroupToColor, options} from 'components/map/MapOptions';
import StolenPasswords from 'components/report-components/StolenPasswords'; import StolenPasswords from 'components/report-components/StolenPasswords';
import ScannedBreachedChart from 'components/report-components/ScannedBreachedChart'; import ScannedBreachedChart from 'components/report-components/ScannedBreachedChart';
import CollapsibleWellComponent from "../report-components/CollapsibleWell"; import CollapsibleWellComponent from 'components/report-components/CollapsibleWell';
class ReportPageComponent extends React.Component { class ReportPageComponent extends React.Component {
@ -338,13 +338,16 @@ class ReportPageComponent extends React.Component {
} else { } else {
content = content =
( (
<div> <div className="report-page">
<div id="overview"> <div id="overview">
<h1> <h1>
Overview Executive Summary
</h1> </h1>
<p> <p>
The first monkey run was started on <span className="label label-info">{this.state.report.overview.monkey_start_time}</span>. After <span className="label label-info">{this.state.report.overview.monkey_duration}</span>, all monkeys finished propagation attempts. The first monkey run was started on <span
className="label label-info">{this.state.report.overview.monkey_start_time}</span>. After <span
className="label label-info">{this.state.report.overview.monkey_duration}</span>, all monkeys finished
propagation attempts.
</p> </p>
<p> <p>
A full report of the Monkeys activities follows. A full report of the Monkeys activities follows.
@ -358,14 +361,31 @@ class ReportPageComponent extends React.Component {
<h3> <h3>
Immediate Threats Immediate Threats
</h3> </h3>
During this simulated attack the Monkey uncovered <span className="label label-warning">{this.state.report.overview.issues.filter(function(x){return x===true;}).length} issues</span>, detailed below. The security issues uncovered include: During this simulated attack the Monkey uncovered <span
<ul className="report"> className="label label-warning">{this.state.report.overview.issues.filter(function (x) {
{this.state.report.overview.issues[this.Issue.WEAK_PASSWORD] ? <li className="report">Users with weak passwords.</li> : null} return x === true;
{this.state.report.overview.issues[this.Issue.STOLEN_CREDS] ?<li className="report">Stolen passwords/hashes were used to exploit other machines.</li> : null} }).length} issues</span>, detailed below. The security issues uncovered include:
{this.state.report.overview.issues[this.Issue.ELASTIC] ? <li className="report">Elastic Search servers not patched for <a href="https://www.cvedetails.com/cve/cve-2015-1427" className="report">CVE-2015-1427</a>.</li> : null} <ul>
{this.state.report.overview.issues[this.Issue.SAMBACRY] ? <li className="report">Samba servers not patched for SambaCry (<a href="https://www.samba.org/samba/security/CVE-2017-7494.html" className="report">CVE-2017-7494</a>).</li> : null} {this.state.report.overview.issues[this.Issue.WEAK_PASSWORD] ?
{this.state.report.overview.issues[this.Issue.SHELLSHOCK] ? <li className="report">Machines not patched for the Shellshock (<a href="https://www.cvedetails.com/cve/CVE-2014-6271" className="report">CVE-2014-6271</a>).</li> : null} <li>Users with weak passwords.</li> : null}
{this.state.report.overview.issues[this.Issue.CONFICKER] ? <li className="report">Machines not patched for the Conficker (<a href="https://docs.microsoft.com/en-us/security-updates/SecurityBulletins/2008/ms08-067" className="report">MS08-067</a>).</li> : null} {this.state.report.overview.issues[this.Issue.STOLEN_CREDS] ?
<li>Stolen passwords/hashes were used to exploit other machines.</li> : null}
{this.state.report.overview.issues[this.Issue.ELASTIC] ?
<li>Elastic Search servers not patched for <a
href="https://www.cvedetails.com/cve/cve-2015-1427">CVE-2015-1427</a>.
</li> : null}
{this.state.report.overview.issues[this.Issue.SAMBACRY] ?
<li>Samba servers not patched for SambaCry (<a
href="https://www.samba.org/samba/security/CVE-2017-7494.html"
>CVE-2017-7494</a>).</li> : null}
{this.state.report.overview.issues[this.Issue.SHELLSHOCK] ?
<li>Machines not patched for the Shellshock (<a
href="https://www.cvedetails.com/cve/CVE-2014-6271">CVE-2014-6271</a>).
</li> : null}
{this.state.report.overview.issues[this.Issue.CONFICKER] ?
<li>Machines not patched for the Conficker (<a
href="https://docs.microsoft.com/en-us/security-updates/SecurityBulletins/2008/ms08-067"
>MS08-067</a>).</li> : null}
</ul> </ul>
</div> </div>
<div> <div>
@ -373,9 +393,13 @@ class ReportPageComponent extends React.Component {
Security Issues Security Issues
</h3> </h3>
The monkey uncovered the following possible set of issues: The monkey uncovered the following possible set of issues:
<ul className="report"> <ul>
{this.state.report.overview.warnings[this.Warning.CROSS_SEGMENT] ? <li className="report">Possible cross segment traffic. Infected machines could communicate with the Monkey Island despite crossing segment boundaries using unused ports.</li> : null} {this.state.report.overview.warnings[this.Warning.CROSS_SEGMENT] ?
{this.state.report.overview.warnings[this.Warning.TUNNEL] ? <li className="report">Lack of Micro-segmentation, machines successfully tunneled monkey activity using unused ports.</li> : null} <li>Possible cross segment traffic. Infected machines could communicate with the
Monkey Island despite crossing segment boundaries using unused ports.</li> : null}
{this.state.report.overview.warnings[this.Warning.TUNNEL] ?
<li>Lack of Micro-segmentation, machines successfully tunneled monkey activity
using unused ports.</li> : null}
</ul> </ul>
</div> </div>
</div> </div>
@ -394,33 +418,38 @@ class ReportPageComponent extends React.Component {
<div> <div>
<Col lg={10}> <Col lg={10}>
<p> <p>
The Monkey discovered <span className="label label-info">{this.state.report.glance.scanned.length}</span> machines and successfully breached <span className="label label-warning">{this.state.report.glance.exploited.length}</span> of them. The Monkey discovered <span
<br /> className="label label-info">{this.state.report.glance.scanned.length}</span> machines and
In addition, while attempting to exploit additional hosts , security software installed in the network should have picked up the attack attempts and logged them. successfully breached <span
<br /> className="label label-warning">{this.state.report.glance.exploited.length}</span> of them.
<br/>
In addition, while attempting to exploit additional hosts , security software installed in the
network should have picked up the attack attempts and logged them.
<br/>
Detailed recommendations in the <a href="#recommendations">next part of the report</a>. Detailed recommendations in the <a href="#recommendations">next part of the report</a>.
</p> </p>
</Col> </Col>
<Col lg={2}> <Col lg={2}>
<div style={{marginBottom: '20px'}}> <div style={{marginBottom: '20px'}}>
<ScannedBreachedChart scanned={this.state.report.glance.scanned.length} exploited={this.state.report.glance.exploited.length} /> <ScannedBreachedChart scanned={this.state.report.glance.scanned.length}
exploited={this.state.report.glance.exploited.length}/>
</div> </div>
</Col> </Col>
</div> </div>
<p> <p>
From the attacker's point of view, the network looks like this: From the attacker's point of view, the network looks like this:
</p> </p>
<div style={{height: '80vh'}}> <div style={{position: 'relative', height: '80vh'}}>
<ReactiveGraph graph={this.state.graph} options={options} /> <ReactiveGraph graph={this.state.graph} options={options}/>
</div> </div>
<div style={{marginBottom: '20px'}}> <div style={{marginBottom: '20px'}}>
<BreachedServers data={this.state.report.glance.exploited} /> <BreachedServers data={this.state.report.glance.exploited}/>
</div> </div>
<div style={{marginBottom: '20px'}}> <div style={{marginBottom: '20px'}}>
<ScannedServers data={this.state.report.glance.scanned} /> <ScannedServers data={this.state.report.glance.scanned}/>
</div> </div>
<div> <div>
<StolenPasswords data={this.state.report.glance.stolen_creds} /> <StolenPasswords data={this.state.report.glance.stolen_creds}/>
</div> </div>
</div> </div>
</div> </div>

View File

@ -49,19 +49,10 @@ body {
padding-left: 0px; padding-left: 0px;
} }
ul.report {
list-style: disc;
padding-left: 40px;
}
li { li {
overflow: auto; overflow: auto;
} }
li.report {
overflow: visible;
}
li .number { li .number {
color: #666; color: #666;
display: inline-block; display: inline-block;
@ -76,11 +67,6 @@ body {
margin: 0.1em 0; margin: 0.1em 0;
} }
li a.report {
display: inline;
padding: 0em;
}
li a:hover { li a:hover {
color: #000; color: #000;
background: #e9e9e9; background: #e9e9e9;
@ -378,3 +364,52 @@ body {
padding: 15px; padding: 15px;
} }
} }
/* Report page */
.report-page {
font-size: 1.2em;
border: 1px solid #fff;
padding: 2em;
-webkit-box-shadow: 1px 1px 7px -1px #ccc;
box-shadow: 1px 1px 7px -1px #ccc;
}
.report-page h1 {
margin-top: 30px;
}
.report-page h3 {
margin-top: 20px;
}
.report-page h4 {
margin-top: 20px;
}
.report-page ul {
list-style: disc;
padding-left: 40px;
}
.report-page li {
overflow: visible;
}
.report-page li a {
display: inline;
padding: 0em;
}
/* Print report styling */
@media print {
.sidebar {
display: none;
}
.pie-chart {
width: 100px;
}
}