mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* Create MFA setup page and remove MFA setup from account settings modal * Add enforce MFA to system console and force redirect * Lockdown mfa required API routes, add localization, other changes * Minor fixes * Fix typo * Fix some unit tests * Fix more unit tests * Minor fix * Updating UI for MFA screen (#4670) * Updating UI for MFA screen * Updating styles for MFA page * Add the ability to switch between email/sso with MFA enabled * Added mfa change email * Minor UI updates for MFA enforcement * Fix unit test * Fix client unit test * Allow switching email to ldap and back when MFA is enabled * Fix unit test * Revert config.json
127 lines
3.6 KiB
JavaScript
127 lines
3.6 KiB
JavaScript
// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import Client from './client.jsx';
|
|
|
|
import TeamStore from 'stores/team_store.jsx';
|
|
import BrowserStore from 'stores/browser_store.jsx';
|
|
|
|
import * as GlobalActions from 'actions/global_actions.jsx';
|
|
import {reconnect} from 'actions/websocket_actions.jsx';
|
|
|
|
import request from 'superagent';
|
|
|
|
const HTTP_UNAUTHORIZED = 401;
|
|
|
|
class WebClientClass extends Client {
|
|
constructor() {
|
|
super();
|
|
this.enableLogErrorsToConsole(true);
|
|
this.hasInternetConnection = true;
|
|
TeamStore.addChangeListener(this.onTeamStoreChanged.bind(this));
|
|
}
|
|
|
|
onTeamStoreChanged() {
|
|
this.setTeamId(TeamStore.getCurrentId());
|
|
}
|
|
|
|
track(category, action, label, property, value) {
|
|
if (global.window && global.window.analytics) {
|
|
global.window.analytics.track(action, {category, label, property, value});
|
|
}
|
|
}
|
|
|
|
trackPage() {
|
|
if (global.window && global.window.analytics) {
|
|
global.window.analytics.page();
|
|
}
|
|
}
|
|
|
|
handleError(err, res) {
|
|
if (res.body.id === 'api.context.mfa_required.app_error') {
|
|
window.location.reload();
|
|
return;
|
|
}
|
|
|
|
if (err.status === HTTP_UNAUTHORIZED && res.req.url !== '/api/v3/users/login') {
|
|
GlobalActions.emitUserLoggedOutEvent('/login');
|
|
}
|
|
|
|
if (err.status == null) {
|
|
this.hasInternetConnection = false;
|
|
}
|
|
}
|
|
|
|
handleSuccess = (res) => { // eslint-disable-line no-unused-vars
|
|
if (res && !this.hasInternetConnection) {
|
|
reconnect();
|
|
this.hasInternetConnection = true;
|
|
}
|
|
}
|
|
|
|
// not sure why but super.login doesn't work if using an () => arrow functions.
|
|
// I think this might be a webpack issue.
|
|
webLogin(loginId, password, token, success, error) {
|
|
this.login(
|
|
loginId,
|
|
password,
|
|
token,
|
|
(data) => {
|
|
this.track('api', 'api_users_login_success', '', 'login_id', loginId);
|
|
BrowserStore.signalLogin();
|
|
|
|
if (success) {
|
|
success(data);
|
|
}
|
|
},
|
|
(err) => {
|
|
this.track('api', 'api_users_login_fail', '', 'login_id', loginId);
|
|
if (error) {
|
|
error(err);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
webLoginByLdap(loginId, password, token, success, error) {
|
|
this.loginByLdap(
|
|
loginId,
|
|
password,
|
|
token,
|
|
(data) => {
|
|
this.track('api', 'api_users_login_success', '', 'login_id', loginId);
|
|
BrowserStore.signalLogin();
|
|
|
|
if (success) {
|
|
success(data);
|
|
}
|
|
},
|
|
(err) => {
|
|
this.track('api', 'api_users_login_fail', '', 'login_id', loginId);
|
|
if (error) {
|
|
error(err);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
getYoutubeVideoInfo(googleKey, videoId, success, error) {
|
|
request.get('https://www.googleapis.com/youtube/v3/videos').
|
|
query({part: 'snippet', id: videoId, key: googleKey}).
|
|
end((err, res) => {
|
|
if (err) {
|
|
return error(err);
|
|
}
|
|
|
|
if (!res.body) {
|
|
console.error('Missing response body for getYoutubeVideoInfo'); // eslint-disable-line no-console
|
|
}
|
|
|
|
return success(res.body);
|
|
});
|
|
}
|
|
}
|
|
|
|
var WebClient = new WebClientClass();
|
|
export default WebClient;
|