summaryrefslogtreecommitdiffstats
path: root/webapp/components/admin_console/elasticsearch_settings.jsx
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2017-08-01 13:11:29 +0100
committerGitHub <noreply@github.com>2017-08-01 13:11:29 +0100
commit00e8b6621a7ddf13222144d4acf80421204a23cc (patch)
tree0e6b967eeb813d99c0f07cdcedc3638d76d61144 /webapp/components/admin_console/elasticsearch_settings.jsx
parent25a2013890c7e07b4621fa9b18342e7f35363049 (diff)
downloadchat-00e8b6621a7ddf13222144d4acf80421204a23cc.tar.gz
chat-00e8b6621a7ddf13222144d4acf80421204a23cc.tar.bz2
chat-00e8b6621a7ddf13222144d4acf80421204a23cc.zip
PLT-6595 (Client): Elasticsearch indexing system console UI (#6991)
* PLT-6595: System Console for Elasticsearch Job Management. * Fixing UI issues * Fixing colors * ESLint Fixes. * Update test snapshots. * Fixing cancel button * Fix review comments. * Config capitalisation. * Review fixes.
Diffstat (limited to 'webapp/components/admin_console/elasticsearch_settings.jsx')
-rw-r--r--webapp/components/admin_console/elasticsearch_settings.jsx63
1 files changed, 58 insertions, 5 deletions
diff --git a/webapp/components/admin_console/elasticsearch_settings.jsx b/webapp/components/admin_console/elasticsearch_settings.jsx
index 43a0baf37..b245ad0dc 100644
--- a/webapp/components/admin_console/elasticsearch_settings.jsx
+++ b/webapp/components/admin_console/elasticsearch_settings.jsx
@@ -6,12 +6,13 @@ import React from 'react';
import * as Utils from 'utils/utils.jsx';
import AdminSettings from './admin_settings.jsx';
-import {elasticsearchTest} from 'actions/admin_actions.jsx';
+import {elasticsearchTest, elasticsearchPurgeIndexes} from 'actions/admin_actions.jsx';
import BooleanSetting from './boolean_setting.jsx';
import {FormattedMessage} from 'react-intl';
import SettingsGroup from './settings_group.jsx';
import TextSetting from './text_setting.jsx';
import RequestButton from './request_button/request_button.jsx';
+import ElasticsearchStatus from './elasticsearch_status';
export default class ElasticsearchSettings extends AdminSettings {
constructor(props) {
@@ -21,6 +22,7 @@ export default class ElasticsearchSettings extends AdminSettings {
this.doTestConfig = this.doTestConfig.bind(this);
this.handleChange = this.handleChange.bind(this);
+ this.handleSaved = this.handleSaved.bind(this);
this.renderSettings = this.renderSettings.bind(this);
}
@@ -45,7 +47,8 @@ export default class ElasticsearchSettings extends AdminSettings {
enableIndexing: config.ElasticsearchSettings.EnableIndexing,
enableSearching: config.ElasticsearchSettings.EnableSearching,
configTested: true,
- canSave: true
+ canSave: true,
+ canPurgeAndIndex: config.ElasticsearchSettings.EnableIndexing
};
}
@@ -70,9 +73,21 @@ export default class ElasticsearchSettings extends AdminSettings {
});
}
+ if (id !== 'enableSearching') {
+ this.setState({
+ canPurgeAndIndex: false
+ });
+ }
+
super.handleChange(id, value);
}
+ handleSaved() {
+ this.setState({
+ canPurgeAndIndex: this.state.enableIndexing
+ });
+ }
+
canSave() {
return this.state.canSave;
}
@@ -89,6 +104,7 @@ export default class ElasticsearchSettings extends AdminSettings {
canSave: true
});
success();
+ this.doSubmit();
},
(err) => {
this.setState({
@@ -135,7 +151,7 @@ export default class ElasticsearchSettings extends AdminSettings {
values={{
documentationLink: (
<a
- href='http://www.mattermost.com'
+ href='https://about.mattermost.com/default-elasticsearch-documentation/'
rel='noopener noreferrer'
target='_blank'
>
@@ -167,7 +183,7 @@ export default class ElasticsearchSettings extends AdminSettings {
values={{
documentationLink: (
<a
- href='http://www.mattermost.com'
+ href='https://about.mattermost.com/default-elasticsearch-server-setup/'
rel='noopener noreferrer'
target='_blank'
>
@@ -245,7 +261,7 @@ export default class ElasticsearchSettings extends AdminSettings {
helpText={
<FormattedMessage
id='admin.elasticsearch.testHelpText'
- defaultMessage='Tests if the Mattermost server can connect to the Elasticsearch server specified. Testing the connection does not save the configuration. See log file for more detailed error messages.'
+ defaultMessage='Tests if the Mattermost server can connect to the Elasticsearch server specified. Testing the connection only saves the configuration if the test is successful. See log file for more detailed error messages.'
/>
}
buttonText={
@@ -254,8 +270,45 @@ export default class ElasticsearchSettings extends AdminSettings {
defaultMessage='Test Connection'
/>
}
+ successMessage={{
+ id: 'admin.elasticsearch.testConfigSuccess',
+ defaultMessage: 'Test successful. Configuration saved.'
+ }}
disabled={!this.state.enableIndexing}
/>
+ <ElasticsearchStatus
+ isConfigured={this.state.canPurgeAndIndex}
+ />
+ <RequestButton
+ requestAction={elasticsearchPurgeIndexes}
+ helpText={
+ <FormattedMessage
+ id='admin.elasticsearch.purgeIndexesHelpText'
+ defaultMessage='Purging will entirely remove the index on the Elasticsearch server. Search results may be incomplete until a bulk index of the existing post database is rebuilt.'
+ />
+ }
+ buttonText={
+ <FormattedMessage
+ id='admin.elasticsearch.purgeIndexesButton'
+ defaultMessage='Purge Index'
+ />
+ }
+ successMessage={{
+ id: 'admin.elasticsearch.purgeIndexesButton.success',
+ defaultMessage: 'Indexes purged successfully.'
+ }}
+ errorMessage={{
+ id: 'admin.elasticsearch.purgeIndexesButton.error',
+ defaultMessage: 'Failed to purge indexes: {error}'
+ }}
+ disabled={!this.state.canPurgeAndIndex}
+ label={(
+ <FormattedMessage
+ id='admin.elasticsearch.purgeIndexesButton.label'
+ defaultMessage='Purge Indexes:'
+ />
+ )}
+ />
<BooleanSetting
id='enableSearching'
label={