Move auth steps to IdentityAuthClient

pull/21833/head
J. Ryan Stinnett 2019-07-29 11:58:47 +01:00
parent 432e70e2ce
commit 4d01d6a5b1
2 changed files with 67 additions and 6 deletions

60
src/IdentityAuthClient.js Normal file
View File

@ -0,0 +1,60 @@
/*
Copyright 2019 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import MatrixClientPeg from './MatrixClientPeg';
export default class IdentityAuthClient {
constructor() {
this.accessToken = null;
}
hasCredentials() {
return this.accessToken != null; // undef or null
}
// Returns a promise that resolves to the access_token string from the IS
async getAccessToken() {
let token = this.accessToken;
if (!token) {
token = window.localStorage.getItem("mx_is_access_token");
}
if (!token) {
return this.registerForToken();
}
try {
return await this._checkToken(token);
} catch (e) {
return await this.registerForToken();
}
}
_checkToken(token) {
// TODO: Test current API token via /account endpoint
return token;
}
async registerForToken() {
const hsOpenIdToken = await MatrixClientPeg.get().getOpenIdToken();
const { access_token: isAccessToken } =
await MatrixClientPeg.get().registerWithIdentityServer(hsOpenIdToken);
await this._checkToken(isAccessToken);
this.accessToken = isAccessToken;
window.localStorage.setItem("mx_is_access_token", isAccessToken);
return isAccessToken;
}
}

View File

@ -2,6 +2,7 @@
Copyright 2015, 2016 OpenMarket Ltd
Copyright 2017, 2018, 2019 New Vector Ltd
Copyright 2019 Michael Telatynski <7t3chguy@gmail.com>
Copyright 2019 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
@ -18,13 +19,15 @@ limitations under the License.
import React from 'react';
import PropTypes from 'prop-types';
import { _t, _td } from '../../../languageHandler';
import sdk from '../../../index';
import MatrixClientPeg from '../../../MatrixClientPeg';
import Promise from 'bluebird';
import { addressTypes, getAddressType } from '../../../UserAddress.js';
import GroupStore from '../../../stores/GroupStore';
import * as Email from "../../../email";
import * as Email from '../../../email';
import IdentityAuthClient from '../../../IdentityAuthClient';
const TRUNCATE_QUERY_LIST = 40;
const QUERY_USER_DIRECTORY_DEBOUNCE_MS = 200;
@ -513,13 +516,11 @@ module.exports = React.createClass({
if (cancelled) return null;
try {
const hsAccountToken = await MatrixClientPeg.get().getOpenIdToken();
const authClient = new IdentityAuthClient();
const isAccessToken = await authClient.getAccessToken();
if (cancelled) return null;
const isAccountToken = await MatrixClientPeg.get().registerWithIdentityServer(hsAccountToken);
if (cancelled) return null;
const lookup = await MatrixClientPeg.get().lookupThreePid(medium, address, undefined, isAccountToken);
const lookup = await MatrixClientPeg.get().lookupThreePid(medium, address, undefined, isAccessToken);
if (cancelled || lookup === null || !lookup.mxid) return null;
const profile = await MatrixClientPeg.get().getProfileInfo(lookup.mxid);