forked from p34709852/monkey
Merge branch 'develop' into release/1.8.2
This commit is contained in:
commit
ca87ff1330
|
@ -13,6 +13,8 @@ import {Link} from 'react-router-dom';
|
||||||
import AuthComponent from '../AuthComponent';
|
import AuthComponent from '../AuthComponent';
|
||||||
import AwsRunTable from '../run-monkey/AwsRunTable';
|
import AwsRunTable from '../run-monkey/AwsRunTable';
|
||||||
|
|
||||||
|
import MissingBinariesModal from '../ui-components/MissingBinariesModal';
|
||||||
|
|
||||||
import '../../styles/MonkeyRunPage.scss';
|
import '../../styles/MonkeyRunPage.scss';
|
||||||
|
|
||||||
const loading_css_override = css`
|
const loading_css_override = css`
|
||||||
|
@ -40,8 +42,12 @@ class RunMonkeyPageComponent extends AuthComponent {
|
||||||
awsMachines: [],
|
awsMachines: [],
|
||||||
isLoadingAws: true,
|
isLoadingAws: true,
|
||||||
isErrorWhileCollectingAwsMachines: false,
|
isErrorWhileCollectingAwsMachines: false,
|
||||||
awsMachineCollectionErrorMsg: ''
|
awsMachineCollectionErrorMsg: '',
|
||||||
|
showModal: false,
|
||||||
|
errorDetails: ''
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.closeModal = this.closeModal.bind(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
|
@ -130,6 +136,13 @@ class RunMonkeyPageComponent extends AuthComponent {
|
||||||
runningOnIslandState: 'installing'
|
runningOnIslandState: 'installing'
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
/* If Monkey binaries are missing, change the state accordingly */
|
||||||
|
if (res['error_text'].startsWith('Copy file failed')) {
|
||||||
|
this.setState({
|
||||||
|
showModal: true,
|
||||||
|
errorDetails: res['error_text']}
|
||||||
|
);
|
||||||
|
}
|
||||||
this.setState({
|
this.setState({
|
||||||
runningOnIslandState: 'not_running'
|
runningOnIslandState: 'not_running'
|
||||||
});
|
});
|
||||||
|
@ -285,6 +298,12 @@ class RunMonkeyPageComponent extends AuthComponent {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
closeModal = () => {
|
||||||
|
this.setState({
|
||||||
|
showModal: false
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Col xs={12} lg={8}>
|
<Col xs={12} lg={8}>
|
||||||
|
@ -296,11 +315,14 @@ class RunMonkeyPageComponent extends AuthComponent {
|
||||||
<p>
|
<p>
|
||||||
<button onClick={this.runLocalMonkey}
|
<button onClick={this.runLocalMonkey}
|
||||||
className="btn btn-default btn-lg center-block"
|
className="btn btn-default btn-lg center-block"
|
||||||
disabled={this.state.runningOnIslandState !== 'not_running'}
|
disabled={this.state.runningOnIslandState !== 'not_running'}>
|
||||||
>
|
|
||||||
Run on Monkey Island Server
|
Run on Monkey Island Server
|
||||||
{RunMonkeyPageComponent.renderIconByState(this.state.runningOnIslandState)}
|
{RunMonkeyPageComponent.renderIconByState(this.state.runningOnIslandState)}
|
||||||
</button>
|
</button>
|
||||||
|
<MissingBinariesModal
|
||||||
|
showModal = {this.state.showModal}
|
||||||
|
onClose = {this.closeModal}
|
||||||
|
errorDetails = {this.state.errorDetails}/>
|
||||||
{
|
{
|
||||||
// TODO: implement button functionality
|
// TODO: implement button functionality
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
import {Modal} from 'react-bootstrap';
|
||||||
|
import React from 'react';
|
||||||
|
import {GridLoader} from 'react-spinners';
|
||||||
|
|
||||||
|
|
||||||
|
class MissingBinariesModal extends React.PureComponent {
|
||||||
|
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
|
||||||
|
this.state = {
|
||||||
|
showModal: this.props.showModal,
|
||||||
|
errorDetails: this.props.errorDetails
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
componentDidUpdate(prevProps) {
|
||||||
|
if (this.props !== prevProps) {
|
||||||
|
this.setState({
|
||||||
|
showModal: this.props.showModal,
|
||||||
|
errorDetails: this.props.errorDetails
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
render = () => {
|
||||||
|
return (
|
||||||
|
<Modal show={this.state.showModal} onHide={() => this.props.onClose()}>
|
||||||
|
<Modal.Body>
|
||||||
|
<h3>
|
||||||
|
<div className='text-center'>Uh oh...</div>
|
||||||
|
</h3>
|
||||||
|
<div style={{'marginTop': '1em', 'marginBottom': '1em'}}>
|
||||||
|
<p className="alert alert-warning">
|
||||||
|
<i className="glyphicon glyphicon-info-sign" style={{'marginRight': '5px'}}/>
|
||||||
|
Some Monkey binaries are not found where they should be...<br/>
|
||||||
|
You can download the files from <a href="https://github.com/guardicore/monkey/releases/latest" target="blank">here</a>,
|
||||||
|
at the bottommost section titled "Assets", and place them under the directory <code>monkey/monkey_island/cc/binaries</code>.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<h4>
|
||||||
|
Error Details
|
||||||
|
</h4>
|
||||||
|
<div style={{'marginTop': '1em', 'marginBottom': '1em'}}>
|
||||||
|
<pre>
|
||||||
|
{this.state.errorDetails}
|
||||||
|
</pre>
|
||||||
|
</div>
|
||||||
|
<div className='text-center'>
|
||||||
|
<button type='button' className='btn btn-success btn-lg' style={{margin: '5px'}}
|
||||||
|
onClick={() => this.props.onClose()}>
|
||||||
|
Dismiss
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</Modal.Body>
|
||||||
|
</Modal>
|
||||||
|
)
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export default MissingBinariesModal;
|
|
@ -56,7 +56,7 @@ class StartOverModal extends React.PureComponent {
|
||||||
Reset environment
|
Reset environment
|
||||||
</button>
|
</button>
|
||||||
<button type='button' className='btn btn-success btn-lg' style={{margin: '5px'}}
|
<button type='button' className='btn btn-success btn-lg' style={{margin: '5px'}}
|
||||||
onClick={() => this.setState({showCleanDialog: false})}>
|
onClick={() => {this.props.onClose(); this.setState({showCleanDialog: false})}}>
|
||||||
Cancel
|
Cancel
|
||||||
</button>
|
</button>
|
||||||
</div>)
|
</div>)
|
||||||
|
|
Loading…
Reference in New Issue