diff --git a/monkey/monkey_island/cc/ui/src/components/Main.js b/monkey/monkey_island/cc/ui/src/components/Main.js index 07f9638d6..e219af8e6 100644 --- a/monkey/monkey_island/cc/ui/src/components/Main.js +++ b/monkey/monkey_island/cc/ui/src/components/Main.js @@ -1,10 +1,8 @@ import React from 'react'; -import {BrowserRouter as Router, NavLink, Redirect, Route, Switch} from 'react-router-dom'; +import {BrowserRouter as Router, Redirect, Route, Switch} from 'react-router-dom'; import {Col, Grid, Row} from 'react-bootstrap'; -import {FontAwesomeIcon} from '@fortawesome/react-fontawesome' -import {faCheck} from '@fortawesome/free-solid-svg-icons/faCheck' -import {faUndo} from '@fortawesome/free-solid-svg-icons/faUndo' +import SideNavComponent from 'components/SideNavComponent'; import RunServerPage from 'components/pages/RunServerPage'; import ConfigurePage from 'components/pages/ConfigurePage'; import RunMonkeyPage from 'components/pages/RunMonkeyPage'; @@ -25,12 +23,8 @@ import 'react-data-components/css/table-twbs.css'; import 'styles/App.css'; import 'react-toggle/style.css'; import 'react-table/react-table.css'; -import VersionComponent from './side-menu/VersionComponent'; - -import logoImage from '../images/monkey-icon.svg'; -import infectionMonkeyImage from '../images/infection-monkey.svg'; -import guardicoreLogoImage from '../images/guardicore-logo.png'; import notificationIcon from '../images/notification-logo-512x512.png'; +import {StandardLayoutComponent} from "./layouts/StandardLayoutComponent"; const reportZeroTrustRoute = '/report/zeroTrust'; @@ -44,7 +38,7 @@ class AppComponent extends AuthComponent { }); } - if (!res){ + if (!res) { this.auth.needsRegistration() .then(result => { this.setState({ @@ -80,7 +74,7 @@ class AppComponent extends AuthComponent { case true: return page_component; case false: - switch (this.state.needsRegistration){ + switch (this.state.needsRegistration) { case true: return case false: @@ -110,7 +104,6 @@ class AppComponent extends AuthComponent { constructor(props) { super(props); this.state = { - removePBAfiles: false, completedSteps: { run_server: true, run_monkey: false, @@ -122,11 +115,6 @@ class AppComponent extends AuthComponent { }; } - // Sets the property that indicates if we need to remove PBA files from state or not - setRemovePBAfiles = (rmFiles) => { - this.setState({removePBAfiles: rmFiles}); - }; - componentDidMount() { this.updateStatus(); this.interval = setInterval(this.updateStatus, 10000); @@ -141,96 +129,50 @@ class AppComponent extends AuthComponent { - -
- logo - Infection Monkey -
- -
    -
  • - - 1. - Run Monkey Island Server - {this.state.completedSteps.run_server ? - - : ''} - -
  • -
  • - - 2. - Run Monkey - {this.state.completedSteps.run_monkey ? - - : ''} - -
  • -
  • - - 3. - Infection Map - {this.state.completedSteps.infection_done ? - - : ''} - -
  • -
  • - { - return (location.pathname === '/report/attack' - || location.pathname === '/report/zeroTrust' - || location.pathname === '/report/security') - }}> - 4. - Security Reports - {this.state.completedSteps.report_done ? - - : ''} - -
  • -
  • - - - Start Over - -
  • -
- -
-
    -
  • Configuration
  • -
  • Log
  • -
- -
-
- Powered by - - GuardiCore - -
-
- License -
- - - ()}/> ()}/> - {this.renderRoute('/', , true)} - {this.renderRoute('/configure', )} - {this.renderRoute('/run-monkey', )} - {this.renderRoute('/infection/map', )} - {this.renderRoute('/infection/telemetry', )} - {this.renderRoute('/start-over', )} + {this.renderRoute('/', + , + true)} + {this.renderRoute('/configure', + )} + {this.renderRoute('/run-monkey', + )} + {this.renderRoute('/infection/map', + )} + {this.renderRoute('/infection/telemetry', + )} + {this.renderRoute('/start-over', + )} {this.redirectTo('/report', '/report/security')} - {this.renderRoute('/report/security', )} - {this.renderRoute('/report/attack', )} - {this.renderRoute('/report/zeroTrust', )} - {this.renderRoute('/license', )} + {this.renderRoute('/report/security', + )} + {this.renderRoute('/report/attack', + )} + {this.renderRoute('/report/zeroTrust', + )} + {this.renderRoute('/license', + )} diff --git a/monkey/monkey_island/cc/ui/src/components/SideNavComponent.js b/monkey/monkey_island/cc/ui/src/components/SideNavComponent.js new file mode 100644 index 000000000..d4365ac9e --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/SideNavComponent.js @@ -0,0 +1,94 @@ +import logoImage from "../images/monkey-icon.svg"; +import infectionMonkeyImage from "../images/infection-monkey.svg"; +import {NavLink} from "react-router-dom"; +import {FontAwesomeIcon} from "@fortawesome/react-fontawesome"; +import {faCheck} from "@fortawesome/free-solid-svg-icons/faCheck"; +import {faUndo} from "@fortawesome/free-solid-svg-icons/faUndo"; +import guardicoreLogoImage from "../images/guardicore-logo.png"; +import VersionComponent from "./side-menu/VersionComponent"; +import {Col} from "react-bootstrap"; +import React from "react"; + + +class SideNavComponent extends React.Component { + + render() { + return ( + +
+ logo + Infection Monkey +
+ +
    +
  • + + 1. + Run Monkey Island Server + {this.props.completedSteps.run_server ? + + : ''} + +
  • +
  • + + 2. + Run Monkey + {this.props.completedSteps.run_monkey ? + + : ''} + +
  • +
  • + + 3. + Infection Map + {this.props.completedSteps.infection_done ? + + : ''} + +
  • +
  • + { + return (location.pathname === '/report/attack' + || location.pathname === '/report/zeroTrust' + || location.pathname === '/report/security') + }}> + 4. + Security Reports + {this.props.completedSteps.report_done ? + + : ''} + +
  • +
  • + + + Start Over + +
  • +
+ +
+
    +
  • Configuration
  • +
  • Log
  • +
+ +
+
+ Powered by + + GuardiCore + +
+
+ License +
+ + ) + } +} + +export default SideNavComponent; diff --git a/monkey/monkey_island/cc/ui/src/components/layouts/StandardLayoutComponent.js b/monkey/monkey_island/cc/ui/src/components/layouts/StandardLayoutComponent.js new file mode 100644 index 000000000..3cf217ed4 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/layouts/StandardLayoutComponent.js @@ -0,0 +1,12 @@ +import React from "react" +import {Route} from "react-router-dom" +import SideNavComponent from "../SideNavComponent" + +export const StandardLayoutComponent = ({component: Component, ...rest}) => ( + ( + <> + + + + )}/> +)