Merge pull request #4270 from matrix-org/dbkr/wait_for_upgrade_to_complete
Wait for SSSS upgrade to completepull/21833/head
commit
091e094759
|
@ -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 {
|
||||||
|
|
|
@ -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');
|
||||||
|
|
Loading…
Reference in New Issue