Merge pull request #5448 from matrix-org/jryans/lifecycle-customisations
Add lifecycle customisation point after logout
This commit is contained in:
commit
e64b6b07c9
3 changed files with 39 additions and 18 deletions
|
@ -49,6 +49,7 @@ import {SSO_HOMESERVER_URL_KEY, SSO_ID_SERVER_URL_KEY} from "./BasePlatform";
|
||||||
import ThreepidInviteStore from "./stores/ThreepidInviteStore";
|
import ThreepidInviteStore from "./stores/ThreepidInviteStore";
|
||||||
import CountlyAnalytics from "./CountlyAnalytics";
|
import CountlyAnalytics from "./CountlyAnalytics";
|
||||||
import CallHandler from './CallHandler';
|
import CallHandler from './CallHandler';
|
||||||
|
import LifecycleCustomisations from "./customisations/Lifecycle";
|
||||||
|
|
||||||
const HOMESERVER_URL_KEY = "mx_hs_url";
|
const HOMESERVER_URL_KEY = "mx_hs_url";
|
||||||
const ID_SERVER_URL_KEY = "mx_is_url";
|
const ID_SERVER_URL_KEY = "mx_is_url";
|
||||||
|
@ -716,6 +717,7 @@ export async function onLoggedOut(): Promise<void> {
|
||||||
dis.dispatch({action: 'on_logged_out'}, true);
|
dis.dispatch({action: 'on_logged_out'}, true);
|
||||||
stopMatrixClient();
|
stopMatrixClient();
|
||||||
await clearStorage({deleteEverything: true});
|
await clearStorage({deleteEverything: true});
|
||||||
|
LifecycleCustomisations.onLoggedOutAndStorageCleared?.();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
30
src/customisations/Lifecycle.ts
Normal file
30
src/customisations/Lifecycle.ts
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
/*
|
||||||
|
Copyright 2020 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
function onLoggedOutAndStorageCleared(): void {
|
||||||
|
// E.g. redirect user or call other APIs after logout
|
||||||
|
}
|
||||||
|
|
||||||
|
// This interface summarises all available customisation points and also marks
|
||||||
|
// them all as optional. This allows customisers to only define and export the
|
||||||
|
// customisations they need while still maintaining type safety.
|
||||||
|
export interface ILifecycleCustomisations {
|
||||||
|
onLoggedOutAndStorageCleared?: typeof onLoggedOutAndStorageCleared;
|
||||||
|
}
|
||||||
|
|
||||||
|
// A real customisation module will define and export one or more of the
|
||||||
|
// customisation points that make up `ILifecycleCustomisations`.
|
||||||
|
export default {} as ILifecycleCustomisations;
|
|
@ -67,24 +67,13 @@ function setupEncryptionNeeded(kind: SetupEncryptionKind): boolean {
|
||||||
// them all as optional. This allows customisers to only define and export the
|
// them all as optional. This allows customisers to only define and export the
|
||||||
// customisations they need while still maintaining type safety.
|
// customisations they need while still maintaining type safety.
|
||||||
export interface ISecurityCustomisations {
|
export interface ISecurityCustomisations {
|
||||||
examineLoginResponse?: (
|
examineLoginResponse?: typeof examineLoginResponse;
|
||||||
response: any,
|
persistCredentials?: typeof persistCredentials;
|
||||||
credentials: IMatrixClientCreds,
|
createSecretStorageKey?: typeof createSecretStorageKey,
|
||||||
) => void;
|
getSecretStorageKey?: typeof getSecretStorageKey,
|
||||||
persistCredentials?: (
|
catchAccessSecretStorageError?: typeof catchAccessSecretStorageError,
|
||||||
credentials: IMatrixClientCreds,
|
setupEncryptionNeeded?: typeof setupEncryptionNeeded,
|
||||||
) => void;
|
getDehydrationKey?: typeof getDehydrationKey,
|
||||||
createSecretStorageKey?: () => Uint8Array,
|
|
||||||
getSecretStorageKey?: () => Uint8Array,
|
|
||||||
catchAccessSecretStorageError?: (
|
|
||||||
e: Error,
|
|
||||||
) => void,
|
|
||||||
setupEncryptionNeeded?: (
|
|
||||||
kind: SetupEncryptionKind,
|
|
||||||
) => boolean,
|
|
||||||
getDehydrationKey?: (
|
|
||||||
keyInfo: ISecretStorageKeyInfo,
|
|
||||||
) => Promise<Uint8Array>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// A real customisation module will define and export one or more of the
|
// A real customisation module will define and export one or more of the
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue