ui: add a modal dialog that asks users to confirm unsafe options

This commit is contained in:
Mike Salvatore 2021-02-25 11:24:39 -05:00
parent bc3283c4a5
commit 510b001c2a
1 changed files with 58 additions and 1 deletions

View File

@ -34,7 +34,9 @@ class ConfigurePageComponent extends AuthComponent {
lastAction: 'none', lastAction: 'none',
sections: [], sections: [],
selectedSection: 'attack', selectedSection: 'attack',
showAttackAlert: false showAttackAlert: false,
showUnsafeOptionsConfirmation: false,
unsafeOptionsConfirmed: false
}; };
} }
@ -84,13 +86,28 @@ class ConfigurePageComponent extends AuthComponent {
}; };
onSubmit = () => { onSubmit = () => {
if (!this.canSafelySubmitConfig()) {
this.setState({showUnsafeOptionsConfirmation: true});
return;
}
if (this.state.selectedSection === 'attack') { if (this.state.selectedSection === 'attack') {
this.matrixSubmit() this.matrixSubmit()
} else { } else {
this.configSubmit() this.configSubmit()
} }
this.setState({unsafeOptionsConfirmed: false})
}; };
canSafelySubmitConfig() {
return !this.unsafeOptionsSelected() || this.state.unsafeOptionsConfirmed
}
unsafeOptionsSelected() {
return true;
}
matrixSubmit = () => { matrixSubmit = () => {
// Submit attack matrix // Submit attack matrix
this.authFetch(ATTACK_URL, this.authFetch(ATTACK_URL,
@ -201,6 +218,45 @@ class ConfigurePageComponent extends AuthComponent {
</Modal>) </Modal>)
}; };
renderUnsafeOptionsConfirmationModal = () => {
return (
<Modal show={this.state.showUnsafeOptionsConfirmation}>
<Modal.Body>
<h2>
<div className='text-center'>Warning</div>
</h2>
<p className='text-center' style={{'fontSize': '1.2em', 'marginBottom': '2em'}}>
You have selected some options which are not safe for all environments.
These options could cause some systems to become unstable or malfunction.
Are you sure you want to use the selected settings?
</p>
<div className='text-center'>
<Button type='button'
className='btn btn-success'
size='lg'
style={{margin: '5px'}}
onClick={() => {
this.setState({showUnsafeOptionsConfirmation: false})
}}>
Cancel
</Button>
<Button type='button'
className='btn btn-danger'
size='lg'
style={{margin: '5px'}}
onClick={() => {
this.setState(
{unsafeOptionsConfirmed: true, showUnsafeOptionsConfirmation: false},
() => {this.onSubmit()});
}}>
I know what I'm doing.
</Button>
</div>
</Modal.Body>
</Modal>
)
}
userChangedConfig() { userChangedConfig() {
if (JSON.stringify(this.state.configuration) === JSON.stringify(this.initialConfig)) { if (JSON.stringify(this.state.configuration) === JSON.stringify(this.initialConfig)) {
if (Object.keys(this.currentFormData).length === 0 || if (Object.keys(this.currentFormData).length === 0 ||
@ -410,6 +466,7 @@ class ConfigurePageComponent extends AuthComponent {
lg={{offset: 3, span: 8}} xl={{offset: 2, span: 8}} lg={{offset: 3, span: 8}} xl={{offset: 2, span: 8}}
className={'main'}> className={'main'}>
{this.renderAttackAlertModal()} {this.renderAttackAlertModal()}
{this.renderUnsafeOptionsConfirmationModal()}
<h1 className='page-title'>Monkey Configuration</h1> <h1 className='page-title'>Monkey Configuration</h1>
{this.renderNav()} {this.renderNav()}
{content} {content}