2018-12-07 00:39:59 +03:00
|
|
|
/*
|
2019-01-09 19:27:41 +03:00
|
|
|
Copyright 2018, 2019 New Vector Ltd
|
2020-01-03 16:33:32 +03:00
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
2018-12-07 00:39:59 +03:00
|
|
|
|
|
|
|
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 React from "react";
|
|
|
|
import PropTypes from "prop-types";
|
|
|
|
import sdk from "../../../index";
|
|
|
|
import { _t } from "../../../languageHandler";
|
|
|
|
import Modal from "../../../Modal";
|
2019-01-03 00:32:14 +03:00
|
|
|
import MatrixClientPeg from "../../../MatrixClientPeg";
|
2019-01-09 19:27:41 +03:00
|
|
|
import SettingsStore, {SettingLevel} from "../../../settings/SettingsStore";
|
2018-12-07 00:39:59 +03:00
|
|
|
|
|
|
|
export default class RoomRecoveryReminder extends React.PureComponent {
|
|
|
|
static propTypes = {
|
2019-01-09 19:27:41 +03:00
|
|
|
// called if the user sets the option to suppress this reminder in the future
|
|
|
|
onDontAskAgainSet: PropTypes.func,
|
|
|
|
}
|
|
|
|
|
|
|
|
static defaultProps = {
|
|
|
|
onDontAskAgainSet: function() {},
|
2018-12-07 00:39:59 +03:00
|
|
|
}
|
|
|
|
|
2019-01-03 00:32:14 +03:00
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
|
|
|
|
this.state = {
|
|
|
|
loading: true,
|
|
|
|
error: null,
|
2019-02-08 14:51:22 +03:00
|
|
|
backupInfo: null,
|
2019-02-12 19:01:38 +03:00
|
|
|
notNowClicked: false,
|
2019-01-03 00:32:14 +03:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillMount() {
|
|
|
|
this._loadBackupStatus();
|
|
|
|
}
|
|
|
|
|
|
|
|
async _loadBackupStatus() {
|
|
|
|
try {
|
|
|
|
const backupInfo = await MatrixClientPeg.get().getKeyBackupVersion();
|
2019-02-08 14:51:22 +03:00
|
|
|
this.setState({
|
|
|
|
loading: false,
|
|
|
|
backupInfo,
|
|
|
|
});
|
2019-01-03 00:32:14 +03:00
|
|
|
} catch (e) {
|
|
|
|
console.log("Unable to fetch key backup status", e);
|
|
|
|
this.setState({
|
|
|
|
loading: false,
|
|
|
|
error: e,
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
showSetupDialog = () => {
|
2019-02-08 14:51:22 +03:00
|
|
|
if (this.state.backupInfo) {
|
2019-01-03 00:32:14 +03:00
|
|
|
// A key backup exists for this account, but the creating device is not
|
2019-02-08 14:51:22 +03:00
|
|
|
// verified, so restore the backup which will give us the keys from it and
|
|
|
|
// allow us to trust it (ie. upload keys to it)
|
|
|
|
const RestoreKeyBackupDialog = sdk.getComponent('dialogs.keybackup.RestoreKeyBackupDialog');
|
2020-01-03 16:33:32 +03:00
|
|
|
Modal.createTrackedDialog(
|
|
|
|
'Restore Backup', '', RestoreKeyBackupDialog, null, null,
|
|
|
|
/* priority = */ false, /* static = */ true,
|
|
|
|
);
|
2019-02-08 14:51:22 +03:00
|
|
|
} else {
|
|
|
|
Modal.createTrackedDialogAsync("Key Backup", "Key Backup",
|
|
|
|
import("../../../async-components/views/dialogs/keybackup/CreateKeyBackupDialog"),
|
|
|
|
);
|
2019-01-03 00:32:14 +03:00
|
|
|
}
|
2018-12-07 00:39:59 +03:00
|
|
|
}
|
|
|
|
|
2019-02-12 19:01:38 +03:00
|
|
|
onOnNotNowClick = () => {
|
|
|
|
this.setState({notNowClicked: true});
|
|
|
|
}
|
|
|
|
|
2018-12-07 00:39:59 +03:00
|
|
|
onDontAskAgainClick = () => {
|
|
|
|
// When you choose "Don't ask again" from the room reminder, we show a
|
|
|
|
// dialog to confirm the choice.
|
|
|
|
Modal.createTrackedDialogAsync("Ignore Recovery Reminder", "Ignore Recovery Reminder",
|
|
|
|
import("../../../async-components/views/dialogs/keybackup/IgnoreRecoveryReminderDialog"),
|
|
|
|
{
|
2019-01-09 19:27:41 +03:00
|
|
|
onDontAskAgain: async () => {
|
|
|
|
await SettingsStore.setValue(
|
|
|
|
"showRoomRecoveryReminder",
|
|
|
|
null,
|
|
|
|
SettingLevel.ACCOUNT,
|
|
|
|
false,
|
|
|
|
);
|
|
|
|
this.props.onDontAskAgainSet();
|
2018-12-07 00:39:59 +03:00
|
|
|
},
|
|
|
|
onSetup: () => {
|
2019-01-03 00:32:14 +03:00
|
|
|
this.showSetupDialog();
|
2018-12-07 00:39:59 +03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
onSetupClick = () => {
|
2019-01-03 00:32:14 +03:00
|
|
|
this.showSetupDialog();
|
2018-12-07 00:39:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2019-02-12 19:01:38 +03:00
|
|
|
// If there was an error loading just don't display the banner: we'll try again
|
|
|
|
// next time the user switchs to the room.
|
|
|
|
if (this.state.error || this.state.loading || this.state.notNowClicked) {
|
2019-01-03 00:32:14 +03:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2018-12-07 00:39:59 +03:00
|
|
|
const AccessibleButton = sdk.getComponent("views.elements.AccessibleButton");
|
|
|
|
|
2019-02-12 19:01:38 +03:00
|
|
|
let setupCaption;
|
|
|
|
if (this.state.backupInfo) {
|
2019-04-24 13:05:27 +03:00
|
|
|
setupCaption = _t("Connect this device to Key Backup");
|
2019-01-03 00:32:14 +03:00
|
|
|
} else {
|
2019-02-12 19:01:38 +03:00
|
|
|
setupCaption = _t("Start using Key Backup");
|
2019-01-03 00:32:14 +03:00
|
|
|
}
|
|
|
|
|
2018-12-07 00:39:59 +03:00
|
|
|
return (
|
|
|
|
<div className="mx_RoomRecoveryReminder">
|
|
|
|
<div className="mx_RoomRecoveryReminder_header">{_t(
|
2019-02-12 19:01:38 +03:00
|
|
|
"Never lose encrypted messages",
|
2018-12-07 00:39:59 +03:00
|
|
|
)}</div>
|
2019-02-12 19:01:38 +03:00
|
|
|
<div className="mx_RoomRecoveryReminder_body">
|
|
|
|
<p>{_t(
|
|
|
|
"Messages in this room are secured with end-to-end " +
|
|
|
|
"encryption. Only you and the recipient(s) have the " +
|
|
|
|
"keys to read these messages.",
|
|
|
|
)}</p>
|
|
|
|
<p>{_t(
|
|
|
|
"Securely back up your keys to avoid losing them. " +
|
|
|
|
"<a>Learn more.</a>", {},
|
|
|
|
{
|
2019-02-12 20:53:00 +03:00
|
|
|
// TODO: We don't have this link yet: this will prevent the translators
|
2019-02-12 19:01:38 +03:00
|
|
|
// having to re-translate the string when we do.
|
|
|
|
a: sub => '',
|
|
|
|
},
|
|
|
|
)}</p>
|
|
|
|
</div>
|
2018-12-07 00:39:59 +03:00
|
|
|
<div className="mx_RoomRecoveryReminder_buttons">
|
|
|
|
<AccessibleButton className="mx_RoomRecoveryReminder_button"
|
|
|
|
onClick={this.onSetupClick}>
|
2019-02-12 19:01:38 +03:00
|
|
|
{setupCaption}
|
2019-02-08 14:51:22 +03:00
|
|
|
</AccessibleButton>
|
2019-02-12 19:01:38 +03:00
|
|
|
<p><AccessibleButton className="mx_RoomRecoveryReminder_secondary mx_linkButton"
|
|
|
|
onClick={this.onOnNotNowClick}>
|
|
|
|
{ _t("Not now") }
|
|
|
|
</AccessibleButton></p>
|
2019-02-08 19:27:25 +03:00
|
|
|
<p><AccessibleButton className="mx_RoomRecoveryReminder_secondary mx_linkButton"
|
2019-02-08 14:51:22 +03:00
|
|
|
onClick={this.onDontAskAgainClick}>
|
2019-02-12 19:01:38 +03:00
|
|
|
{ _t("Don't ask me again") }
|
2019-02-08 19:27:25 +03:00
|
|
|
</AccessibleButton></p>
|
2018-12-07 00:39:59 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|