2017-05-19 11:54:29 +03:00
|
|
|
/*
|
|
|
|
Copyright 2017 Vector Creations Ltd
|
|
|
|
|
|
|
|
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 Modal from '../../../Modal';
|
|
|
|
import React from 'react';
|
2019-08-24 13:59:46 +03:00
|
|
|
import createReactClass from 'create-react-class';
|
2017-12-26 04:03:18 +03:00
|
|
|
import PropTypes from 'prop-types';
|
2019-12-20 04:19:56 +03:00
|
|
|
import * as sdk from '../../../index';
|
2017-05-19 11:54:29 +03:00
|
|
|
|
2017-09-23 10:02:51 +03:00
|
|
|
import { _t, _td } from '../../../languageHandler';
|
2017-05-19 11:54:29 +03:00
|
|
|
|
2017-06-05 19:58:11 +03:00
|
|
|
/**
|
|
|
|
* Dialog which asks the user whether they want to share their keys with
|
|
|
|
* an unverified device.
|
|
|
|
*
|
|
|
|
* onFinished is called with `true` if the key should be shared, `false` if it
|
|
|
|
* should not, and `undefined` if the dialog is cancelled. (In other words:
|
|
|
|
* truthy: do the key share. falsy: don't share the keys).
|
|
|
|
*/
|
2019-08-24 13:59:46 +03:00
|
|
|
export default createReactClass({
|
2017-05-19 11:54:29 +03:00
|
|
|
propTypes: {
|
2017-12-26 04:03:18 +03:00
|
|
|
matrixClient: PropTypes.object.isRequired,
|
|
|
|
userId: PropTypes.string.isRequired,
|
|
|
|
deviceId: PropTypes.string.isRequired,
|
|
|
|
onFinished: PropTypes.func.isRequired,
|
2017-05-19 11:54:29 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
deviceInfo: null,
|
|
|
|
wasNewDevice: false,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
componentDidMount: function() {
|
|
|
|
this._unmounted = false;
|
|
|
|
const userId = this.props.userId;
|
|
|
|
const deviceId = this.props.deviceId;
|
|
|
|
|
|
|
|
// give the client a chance to refresh the device list
|
|
|
|
this.props.matrixClient.downloadKeys([userId], false).then((r) => {
|
|
|
|
if (this._unmounted) { return; }
|
|
|
|
|
|
|
|
const deviceInfo = r[userId][deviceId];
|
|
|
|
|
2017-11-16 16:19:36 +03:00
|
|
|
if (!deviceInfo) {
|
2017-05-19 11:54:29 +03:00
|
|
|
console.warn(`No details found for device ${userId}:${deviceId}`);
|
|
|
|
|
|
|
|
this.props.onFinished(false);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const wasNewDevice = !deviceInfo.isKnown();
|
|
|
|
|
|
|
|
this.setState({
|
|
|
|
deviceInfo: deviceInfo,
|
|
|
|
wasNewDevice: wasNewDevice,
|
|
|
|
});
|
|
|
|
|
|
|
|
// if the device was new before, it's not any more.
|
|
|
|
if (wasNewDevice) {
|
|
|
|
this.props.matrixClient.setDeviceKnown(
|
|
|
|
userId,
|
|
|
|
deviceId,
|
|
|
|
true,
|
|
|
|
);
|
|
|
|
}
|
2019-11-18 13:03:05 +03:00
|
|
|
});
|
2017-05-19 11:54:29 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
componentWillUnmount: function() {
|
|
|
|
this._unmounted = true;
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_onVerifyClicked: function() {
|
|
|
|
const DeviceVerifyDialog = sdk.getComponent('views.dialogs.DeviceVerifyDialog');
|
|
|
|
|
|
|
|
console.log("KeyShareDialog: Starting verify dialog");
|
2017-07-27 19:19:18 +03:00
|
|
|
Modal.createTrackedDialog('Key Share', 'Starting dialog', DeviceVerifyDialog, {
|
2017-05-19 11:54:29 +03:00
|
|
|
userId: this.props.userId,
|
|
|
|
device: this.state.deviceInfo,
|
|
|
|
onFinished: (verified) => {
|
|
|
|
if (verified) {
|
|
|
|
// can automatically share the keys now.
|
|
|
|
this.props.onFinished(true);
|
|
|
|
}
|
|
|
|
},
|
2019-12-13 16:55:26 +03:00
|
|
|
}, null, /* priority = */ false, /* static = */ true);
|
2017-05-19 11:54:29 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
_onShareClicked: function() {
|
|
|
|
console.log("KeyShareDialog: User clicked 'share'");
|
|
|
|
this.props.onFinished(true);
|
|
|
|
},
|
|
|
|
|
|
|
|
_onIgnoreClicked: function() {
|
|
|
|
console.log("KeyShareDialog: User clicked 'ignore'");
|
|
|
|
this.props.onFinished(false);
|
|
|
|
},
|
|
|
|
|
|
|
|
_renderContent: function() {
|
|
|
|
const displayName = this.state.deviceInfo.getDisplayName() ||
|
|
|
|
this.state.deviceInfo.deviceId;
|
|
|
|
|
|
|
|
let text;
|
|
|
|
if (this.state.wasNewDevice) {
|
2017-09-23 10:02:51 +03:00
|
|
|
text = _td("You added a new device '%(displayName)s', which is"
|
|
|
|
+ " requesting encryption keys.");
|
2017-05-19 11:54:29 +03:00
|
|
|
} else {
|
2017-09-23 10:02:51 +03:00
|
|
|
text = _td("Your unverified device '%(displayName)s' is requesting"
|
|
|
|
+ " encryption keys.");
|
2017-05-19 11:54:29 +03:00
|
|
|
}
|
|
|
|
text = _t(text, {displayName: displayName});
|
|
|
|
|
|
|
|
return (
|
2017-12-05 15:52:20 +03:00
|
|
|
<div id='mx_Dialog_content'>
|
2017-09-28 13:21:06 +03:00
|
|
|
<p>{ text }</p>
|
2017-05-19 11:54:29 +03:00
|
|
|
|
|
|
|
<div className="mx_Dialog_buttons">
|
2017-12-05 15:52:20 +03:00
|
|
|
<button onClick={this._onVerifyClicked} autoFocus="true">
|
2017-09-28 13:21:06 +03:00
|
|
|
{ _t('Start verification') }
|
2017-05-19 11:54:29 +03:00
|
|
|
</button>
|
|
|
|
<button onClick={this._onShareClicked}>
|
2017-09-28 13:21:06 +03:00
|
|
|
{ _t('Share without verifying') }
|
2017-05-19 11:54:29 +03:00
|
|
|
</button>
|
|
|
|
<button onClick={this._onIgnoreClicked}>
|
2017-09-28 13:21:06 +03:00
|
|
|
{ _t('Ignore request') }
|
2017-05-19 11:54:29 +03:00
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
|
|
|
render: function() {
|
|
|
|
const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog');
|
|
|
|
const Spinner = sdk.getComponent('views.elements.Spinner');
|
|
|
|
|
|
|
|
let content;
|
|
|
|
|
|
|
|
if (this.state.deviceInfo) {
|
|
|
|
content = this._renderContent();
|
|
|
|
} else {
|
|
|
|
content = (
|
2017-12-05 15:52:20 +03:00
|
|
|
<div id='mx_Dialog_content'>
|
2017-09-28 13:21:06 +03:00
|
|
|
<p>{ _t('Loading device info...') }</p>
|
2017-05-19 11:54:29 +03:00
|
|
|
<Spinner />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<BaseDialog className='mx_KeyShareRequestDialog'
|
|
|
|
onFinished={this.props.onFinished}
|
2017-06-05 19:58:11 +03:00
|
|
|
title={_t('Encryption key request')}
|
2017-12-05 15:52:20 +03:00
|
|
|
contentId='mx_Dialog_content'
|
2017-05-19 11:54:29 +03:00
|
|
|
>
|
2017-09-28 13:21:06 +03:00
|
|
|
{ content }
|
2017-05-19 11:54:29 +03:00
|
|
|
</BaseDialog>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
});
|