mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-15 11:31:33 +03:00
1d9d0cd7be
Turns out a lot of the typescript warnings about improper warnings were correct. TypeScript appears to be pulling in two copies of the js-sdk when we do this, which can lead to type conflicts (or worse: the wrong code entirely). We fix this at the webpack level by explicitly importing from `src`, but some alternative build structures have broken tests because of this - jest ends up pulling in the "wrong" js-sdk, breaking things.
52 lines
1.7 KiB
JavaScript
52 lines
1.7 KiB
JavaScript
/*
|
|
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 { SERVICE_TYPES } from 'matrix-js-sdk/src/service-types';
|
|
import SdkConfig from '../SdkConfig';
|
|
import {MatrixClientPeg} from '../MatrixClientPeg';
|
|
|
|
export function getDefaultIdentityServerUrl() {
|
|
return SdkConfig.get()['validated_server_config']['isUrl'];
|
|
}
|
|
|
|
export function useDefaultIdentityServer() {
|
|
const url = getDefaultIdentityServerUrl();
|
|
// Account data change will update localstorage, client, etc through dispatcher
|
|
MatrixClientPeg.get().setAccountData("m.identity_server", {
|
|
base_url: url,
|
|
});
|
|
}
|
|
|
|
export async function doesIdentityServerHaveTerms(fullUrl) {
|
|
let terms;
|
|
try {
|
|
terms = await MatrixClientPeg.get().getTerms(SERVICE_TYPES.IS, fullUrl);
|
|
} catch (e) {
|
|
console.error(e);
|
|
if (e.cors === "rejected" || e.httpStatus === 404) {
|
|
terms = null;
|
|
} else {
|
|
throw e;
|
|
}
|
|
}
|
|
|
|
return terms && terms["policies"] && (Object.keys(terms["policies"]).length > 0);
|
|
}
|
|
|
|
export function doesAccountDataHaveIdentityServer() {
|
|
const event = MatrixClientPeg.get().getAccountData("m.identity_server");
|
|
return event && event.getContent() && event.getContent()['base_url'];
|
|
}
|