Merge pull request #4270 from matrix-org/dbkr/wait_for_upgrade_to_complete

Wait for SSSS upgrade to complete
pull/21833/head
David Baker 2020-03-26 12:04:52 +00:00 committed by GitHub
commit 091e094759
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 4 deletions

View File

@ -169,7 +169,7 @@ export default class DeviceListener {
key: THIS_DEVICE_TOAST_KEY, key: THIS_DEVICE_TOAST_KEY,
title: _t("Encryption upgrade available"), title: _t("Encryption upgrade available"),
icon: "verification_warning", icon: "verification_warning",
props: {kind: 'upgrade_encryption'}, props: {kind: 'upgrade_ssss'},
component: sdk.getComponent("toasts.SetupEncryptionToast"), component: sdk.getComponent("toasts.SetupEncryptionToast"),
}); });
} else { } else {

View File

@ -16,9 +16,10 @@ limitations under the License.
import React from 'react'; import React from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import Modal from '../../../Modal';
import { MatrixClientPeg } from '../../../MatrixClientPeg';
import * as sdk from "../../../index"; import * as sdk from "../../../index";
import { _t } from '../../../languageHandler'; import { _t } from '../../../languageHandler';
import Modal from '../../../Modal';
import DeviceListener from '../../../DeviceListener'; import DeviceListener from '../../../DeviceListener';
import SetupEncryptionDialog from "../dialogs/SetupEncryptionDialog"; import SetupEncryptionDialog from "../dialogs/SetupEncryptionDialog";
import { accessSecretStorage } from '../../../CrossSigningManager'; import { accessSecretStorage } from '../../../CrossSigningManager';
@ -26,19 +27,49 @@ import { accessSecretStorage } from '../../../CrossSigningManager';
export default class SetupEncryptionToast extends React.PureComponent { export default class SetupEncryptionToast extends React.PureComponent {
static propTypes = { static propTypes = {
toastKey: PropTypes.string.isRequired, toastKey: PropTypes.string.isRequired,
kind: PropTypes.oneOf(['set_up_encryption', 'verify_this_session', 'upgrade_encryption']).isRequired, kind: PropTypes.oneOf([
'set_up_encryption',
'verify_this_session',
'upgrade_encryption',
'upgrade_ssss',
]).isRequired,
}; };
_onLaterClick = () => { _onLaterClick = () => {
DeviceListener.sharedInstance().dismissEncryptionSetup(); DeviceListener.sharedInstance().dismissEncryptionSetup();
}; };
async _waitForCompletion() {
if (this.props.kind === 'upgrade_ssss') {
return new Promise(resolve => {
const recheck = async () => {
const needsUpgrade = await MatrixClientPeg.get().secretStorageKeyNeedsUpgrade();
if (!needsUpgrade) {
MatrixClientPeg.get().removeListener('accountData', recheck);
resolve();
}
};
MatrixClientPeg.get().on('accountData', recheck);
recheck();
});
} else {
return;
}
}
_onSetupClick = async () => { _onSetupClick = async () => {
if (this.props.kind === "verify_this_session") { if (this.props.kind === "verify_this_session") {
Modal.createTrackedDialog('Verify session', 'Verify session', SetupEncryptionDialog, Modal.createTrackedDialog('Verify session', 'Verify session', SetupEncryptionDialog,
{}, null, /* priority = */ false, /* static = */ true); {}, null, /* priority = */ false, /* static = */ true);
} else { } else {
accessSecretStorage(); const Spinner = sdk.getComponent("elements.Spinner");
const modal = Modal.createDialog(Spinner, null, 'mx_Dialog_spinner');
try {
await accessSecretStorage();
await this._waitForCompletion();
} finally {
modal.close();
}
} }
}; };
@ -46,6 +77,7 @@ export default class SetupEncryptionToast extends React.PureComponent {
switch (this.props.kind) { switch (this.props.kind) {
case 'set_up_encryption': case 'set_up_encryption':
case 'upgrade_encryption': case 'upgrade_encryption':
case 'upgrade_ssss':
return _t('Verify yourself & others to keep your chats safe'); return _t('Verify yourself & others to keep your chats safe');
case 'verify_this_session': case 'verify_this_session':
return _t('Other users may not trust it'); return _t('Other users may not trust it');
@ -56,6 +88,7 @@ export default class SetupEncryptionToast extends React.PureComponent {
switch (this.props.kind) { switch (this.props.kind) {
case 'set_up_encryption': case 'set_up_encryption':
case 'upgrade_encryption': case 'upgrade_encryption':
case 'upgrade_ssss':
return _t('Upgrade'); return _t('Upgrade');
case 'verify_this_session': case 'verify_this_session':
return _t('Verify'); return _t('Verify');