// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved. // See License.txt for license information. import * as Utils from 'utils/utils.jsx'; import Client from 'client/web_client.jsx'; import React from 'react'; import ReactDOM from 'react-dom'; import {FormattedMessage} from 'react-intl'; export default class EmailToLDAP extends React.Component { constructor(props) { super(props); this.submit = this.submit.bind(this); this.state = { passwordError: '', ldapError: '', ldapPasswordError: '', serverError: '' }; } submit(e) { e.preventDefault(); var state = { passwordError: '', ldapError: '', ldapPasswordError: '', serverError: '' }; const password = ReactDOM.findDOMNode(this.refs.emailpassword).value; if (!password) { state.passwordError = Utils.localizeMessage('claim.email_to_ldap.pwdError', 'Please enter your password.'); this.setState(state); return; } const ldapId = ReactDOM.findDOMNode(this.refs.ldapid).value.trim(); if (!ldapId) { state.ldapError = Utils.localizeMessage('claim.email_to_ldap.ldapIdError', 'Please enter your AD/LDAP ID.'); this.setState(state); return; } const ldapPassword = ReactDOM.findDOMNode(this.refs.ldappassword).value; if (!ldapPassword) { state.ldapPasswordError = Utils.localizeMessage('claim.email_to_ldap.ldapPasswordError', 'Please enter your AD/LDAP password.'); this.setState(state); return; } this.setState(state); Client.emailToLdap( this.props.email, password, ldapId, ldapPassword, (data) => { if (data.follow_link) { window.location.href = data.follow_link; } }, (err) => { this.setState({serverError: err.message}); } ); } render() { let serverError = null; let formClass = 'form-group'; if (this.state.serverError) { serverError =
; formClass += ' has-error'; } let passwordError = null; let passwordClass = 'form-group'; if (this.state.passwordError) { passwordError =
; passwordClass += ' has-error'; } let ldapError = null; let ldapClass = 'form-group'; if (this.state.ldapError) { ldapError =
; ldapClass += ' has-error'; } let ldapPasswordError = null; let ldapPasswordClass = 'form-group'; if (this.state.ldapPasswordError) { ldapPasswordError =
; ldapPasswordClass += ' has-error'; } let loginPlaceholder; if (global.window.mm_config.LdapLoginFieldName) { loginPlaceholder = global.window.mm_config.LdapLoginFieldName; } else { loginPlaceholder = Utils.localizeMessage('claim.email_to_ldap.ldapId', 'AD/LDAP ID'); } let passwordPlaceholder; if (global.window.mm_config.LdapPasswordFieldName) { passwordPlaceholder = global.window.mm_config.LdapPasswordFieldName; } else { passwordPlaceholder = Utils.localizeMessage('claim.email_to_ldap.ldapPwd', 'AD/LDAP Password'); } return (

{passwordError}

{ldapError}
{ldapPasswordError} {serverError}
); } } EmailToLDAP.defaultProps = { }; EmailToLDAP.propTypes = { email: React.PropTypes.string };