From 5d7f2399620281dde1f4f85e1812aac9f18c96f9 Mon Sep 17 00:00:00 2001 From: Christopher Speller Date: Thu, 1 Sep 2016 17:05:20 -0400 Subject: Adding LDAP test connection button. Reordering LDAP settings. (#3912) --- webapp/components/admin_console/admin_settings.jsx | 13 ++ webapp/components/admin_console/admin_sidebar.jsx | 2 +- webapp/components/admin_console/ldap_settings.jsx | 84 +++++++------ .../components/admin_console/ldap_test_button.jsx | 139 +++++++++++++++++++++ 4 files changed, 198 insertions(+), 40 deletions(-) create mode 100644 webapp/components/admin_console/ldap_test_button.jsx (limited to 'webapp/components') diff --git a/webapp/components/admin_console/admin_settings.jsx b/webapp/components/admin_console/admin_settings.jsx index 8601722eb..9975a3975 100644 --- a/webapp/components/admin_console/admin_settings.jsx +++ b/webapp/components/admin_console/admin_settings.jsx @@ -21,6 +21,7 @@ export default class AdminSettings extends React.Component { this.handleChange = this.handleChange.bind(this); this.handleSubmit = this.handleSubmit.bind(this); + this.doSubmit = this.doSubmit.bind(this); this.state = Object.assign(this.getStateFromConfig(props.config), { saveNeeded: false, @@ -39,6 +40,10 @@ export default class AdminSettings extends React.Component { handleSubmit(e) { e.preventDefault(); + this.doSubmit(); + } + + doSubmit(callback) { this.setState({ saving: true, serverError: null @@ -59,12 +64,20 @@ export default class AdminSettings extends React.Component { saveNeeded: false, saving: false }); + + if (callback) { + callback(); + } }, (err) => { this.setState({ saving: false, serverError: err.message }); + + if (callback) { + callback(); + } } ); } diff --git a/webapp/components/admin_console/admin_sidebar.jsx b/webapp/components/admin_console/admin_sidebar.jsx index 4fcfe2731..0b107e19a 100644 --- a/webapp/components/admin_console/admin_sidebar.jsx +++ b/webapp/components/admin_console/admin_sidebar.jsx @@ -207,7 +207,7 @@ export default class AdminSidebar extends React.Component { title={ } /> diff --git a/webapp/components/admin_console/ldap_settings.jsx b/webapp/components/admin_console/ldap_settings.jsx index 23728870e..3d93ae6d8 100644 --- a/webapp/components/admin_console/ldap_settings.jsx +++ b/webapp/components/admin_console/ldap_settings.jsx @@ -8,6 +8,7 @@ import SettingsGroup from './settings_group.jsx'; import TextSetting from './text_setting.jsx'; import SyncNowButton from './sync_now_button.jsx'; +import LdapTestButton from './ldap_test_button.jsx'; import * as Utils from 'utils/utils.jsx'; @@ -76,7 +77,7 @@ export default class LdapSettings extends AdminSettings {

); @@ -150,6 +151,23 @@ export default class LdapSettings extends AdminSettings { onChange={this.handleChange} disabled={!this.state.enable} /> + + } + helpText={ + + } + value={this.state.skipCertificateVerification} + onChange={this.handleChange} + /> } + placeholder={Utils.localizeMessage('admin.ldap.loginNameEx', 'Ex "LDAP Username"')} helpText={ } - value={this.state.syncIntervalMinutes} + value={this.state.loginFieldName} onChange={this.handleChange} disabled={!this.state.enable} /> - - } - helpText={ - - } - value={this.state.skipCertificateVerification} - onChange={this.handleChange} - /> } - placeholder={Utils.localizeMessage('admin.ldap.queryEx', 'Ex "60"')} helpText={ } - value={this.state.queryTimeout} + value={this.state.syncIntervalMinutes} onChange={this.handleChange} disabled={!this.state.enable} /> @@ -397,7 +398,7 @@ export default class LdapSettings extends AdminSettings { label={ } placeholder={Utils.localizeMessage('admin.ldap.maxPageSizeEx', 'Ex "2000"')} @@ -412,27 +413,32 @@ export default class LdapSettings extends AdminSettings { disabled={!this.state.enable} /> } - placeholder={Utils.localizeMessage('admin.ldap.loginNameEx', 'Ex "LDAP Username"')} + placeholder={Utils.localizeMessage('admin.ldap.queryEx', 'Ex "60"')} helpText={ } - value={this.state.loginFieldName} + value={this.state.queryTimeout} onChange={this.handleChange} disabled={!this.state.enable} /> + ); } diff --git a/webapp/components/admin_console/ldap_test_button.jsx b/webapp/components/admin_console/ldap_test_button.jsx new file mode 100644 index 000000000..fbe348158 --- /dev/null +++ b/webapp/components/admin_console/ldap_test_button.jsx @@ -0,0 +1,139 @@ +// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +import React from 'react'; + +import Client from 'client/web_client.jsx'; +import * as Utils from 'utils/utils.jsx'; + +import {FormattedMessage, FormattedHTMLMessage} from 'react-intl'; + +export default class LdapTestButton extends React.Component { + static get propTypes() { + return { + disabled: React.PropTypes.bool, + submitFunction: React.PropTypes.func, + saveNeeded: React.PropTypes.bool + }; + } + constructor(props) { + super(props); + + this.handleLdapTest = this.handleLdapTest.bind(this); + + this.state = { + buisy: false, + fail: null, + success: false + }; + } + + handleLdapTest(e) { + e.preventDefault(); + + this.setState({ + buisy: true, + fail: null, + success: false + }); + + const doRequest = () => { //eslint-disable-line func-style + Client.ldapTest( + () => { + this.setState({ + buisy: false, + success: true + }); + }, + (err) => { + this.setState({ + buisy: false, + fail: err.message + }); + } + ); + }; + + // If we need to run the save function then run it with our request function as callback + if (this.props.saveNeeded) { + this.props.submitFunction(doRequest); + } else { + doRequest(); + } + } + + render() { + let message = null; + if (this.state.fail) { + message = ( +
+ + +
+ ); + } else if (this.state.success) { + message = ( +
+ + +
+ ); + } + + let helpText = ( + + ); + + let contents = null; + if (this.state.loading) { + contents = ( + + + {Utils.localizeMessage('admin.reload.loading', ' Loading...')} + + ); + } else { + contents = ( + + ); + } + + return ( +
+
+
+ + {message} +
+
+ {helpText} +
+
+
+ ); + } +} -- cgit v1.2.3-1-g7c22