matrix-react-sdk
Version:
SDK for matrix.org using React
112 lines (86 loc) • 15.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _languageHandler = require("../../../languageHandler");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _VerificationRequestDialog = _interopRequireDefault(require("./VerificationRequestDialog"));
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var sdk = _interopRequireWildcard(require("../../../index"));
var _dec, _class, _class2, _temp;
let NewSessionReviewDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.NewSessionReviewDialog"), _dec(_class = (_temp = _class2 = class NewSessionReviewDialog extends _react.default.PureComponent {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onCancelClick", () => {
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
_Modal.default.createTrackedDialog("Verification failed", "insecure", ErrorDialog, {
headerImage: require("../../../../res/img/e2e/warning.svg"),
title: (0, _languageHandler._t)("Your account is not secure"),
description: /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("One of the following may be compromised:"), /*#__PURE__*/_react.default.createElement("ul", null, /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("Your password")), /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("Your homeserver")), /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("This session, or the other session")), /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("The internet connection either session is using"))), /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("We recommend you change your password and Security Key in Settings immediately"))),
onFinished: () => this.props.onFinished(false)
});
});
(0, _defineProperty2.default)(this, "onContinueClick", () => {
const {
userId,
device
} = this.props;
const cli = _MatrixClientPeg.MatrixClientPeg.get();
const requestPromise = cli.requestVerification(userId, [device.deviceId]);
this.props.onFinished(true);
_Modal.default.createTrackedDialog('New Session Verification', 'Starting dialog', _VerificationRequestDialog.default, {
verificationRequestPromise: requestPromise,
member: cli.getUser(userId),
onFinished: async () => {
const request = await requestPromise;
request.cancel();
}
});
});
}
render() {
const {
device
} = this.props;
const icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_NewSessionReviewDialog_headerIcon mx_E2EIcon_warning"
});
const titleText = (0, _languageHandler._t)("New session");
const title = /*#__PURE__*/_react.default.createElement("h2", {
className: "mx_NewSessionReviewDialog_header"
}, icon, titleText);
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
title: title,
onFinished: this.props.onFinished
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_NewSessionReviewDialog_body"
}, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Use this session to verify your new one, " + "granting it access to encrypted messages:")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_NewSessionReviewDialog_deviceInfo"
}, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_NewSessionReviewDialog_deviceName"
}, device.getDisplayName()), " ", /*#__PURE__*/_react.default.createElement("span", {
className: "mx_NewSessionReviewDialog_deviceID"
}, "(", device.deviceId, ")"))), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("If you didn’t sign in to this session, " + "your account may be compromised.")), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
cancelButton: (0, _languageHandler._t)("This wasn't me"),
cancelButtonClass: "danger",
primaryButton: (0, _languageHandler._t)("Continue"),
onCancel: this.onCancelClick,
onPrimaryButtonClick: this.onContinueClick
})));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
userId: _propTypes.default.string.isRequired,
device: _propTypes.default.object.isRequired,
onFinished: _propTypes.default.func.isRequired
}), _temp)) || _class);
exports.default = NewSessionReviewDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/NewSessionReviewDialog.js"],"names":["NewSessionReviewDialog","React","PureComponent","ErrorDialog","sdk","getComponent","Modal","createTrackedDialog","headerImage","require","title","description","onFinished","props","userId","device","cli","MatrixClientPeg","get","requestPromise","requestVerification","deviceId","VerificationRequestDialog","verificationRequestPromise","member","getUser","request","cancel","render","icon","titleText","getDisplayName","onCancelClick","onContinueClick","PropTypes","string","isRequired","object","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { _t } from '../../../languageHandler';\nimport Modal from '../../../Modal';\nimport { replaceableComponent } from '../../../utils/replaceableComponent';\nimport VerificationRequestDialog from './VerificationRequestDialog';\nimport BaseDialog from './BaseDialog';\nimport DialogButtons from '../elements/DialogButtons';\nimport {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport * as sdk from '../../../index';\n\n@replaceableComponent(\"views.dialogs.NewSessionReviewDialog\")\nexport default class NewSessionReviewDialog extends React.PureComponent {\n    static propTypes = {\n        userId: PropTypes.string.isRequired,\n        device: PropTypes.object.isRequired,\n        onFinished: PropTypes.func.isRequired,\n    }\n\n    onCancelClick = () => {\n        const ErrorDialog = sdk.getComponent(\"dialogs.ErrorDialog\");\n        Modal.createTrackedDialog(\"Verification failed\", \"insecure\", ErrorDialog, {\n            headerImage: require(\"../../../../res/img/e2e/warning.svg\"),\n            title: _t(\"Your account is not secure\"),\n            description: <div>\n                {_t(\"One of the following may be compromised:\")}\n                <ul>\n                    <li>{_t(\"Your password\")}</li>\n                    <li>{_t(\"Your homeserver\")}</li>\n                    <li>{_t(\"This session, or the other session\")}</li>\n                    <li>{_t(\"The internet connection either session is using\")}</li>\n                </ul>\n                <div>\n                    {_t(\"We recommend you change your password and Security Key in Settings immediately\")}\n                </div>\n            </div>,\n            onFinished: () => this.props.onFinished(false),\n        });\n    }\n\n    onContinueClick = () => {\n        const { userId, device } = this.props;\n        const cli = MatrixClientPeg.get();\n        const requestPromise = cli.requestVerification(\n            userId,\n            [device.deviceId],\n        );\n\n        this.props.onFinished(true);\n        Modal.createTrackedDialog('New Session Verification', 'Starting dialog', VerificationRequestDialog, {\n            verificationRequestPromise: requestPromise,\n            member: cli.getUser(userId),\n            onFinished: async () => {\n                const request = await requestPromise;\n                request.cancel();\n            },\n        });\n    }\n\n    render() {\n        const { device } = this.props;\n\n        const icon = <span className=\"mx_NewSessionReviewDialog_headerIcon mx_E2EIcon_warning\"></span>;\n        const titleText = _t(\"New session\");\n\n        const title = <h2 className=\"mx_NewSessionReviewDialog_header\">\n            {icon}\n            {titleText}\n        </h2>;\n\n        return (\n            <BaseDialog\n                title={title}\n                onFinished={this.props.onFinished}\n            >\n                <div className=\"mx_NewSessionReviewDialog_body\">\n                    <p>{_t(\n                        \"Use this session to verify your new one, \" +\n                        \"granting it access to encrypted messages:\",\n                    )}</p>\n                    <div className=\"mx_NewSessionReviewDialog_deviceInfo\">\n                        <div>\n                            <span className=\"mx_NewSessionReviewDialog_deviceName\">\n                                {device.getDisplayName()}\n                            </span> <span className=\"mx_NewSessionReviewDialog_deviceID\">\n                                ({device.deviceId})\n                            </span>\n                        </div>\n                    </div>\n                    <p>{_t(\n                        \"If you didn’t sign in to this session, \" +\n                        \"your account may be compromised.\",\n                    )}</p>\n                    <DialogButtons\n                        cancelButton={_t(\"This wasn't me\")}\n                        cancelButtonClass=\"danger\"\n                        primaryButton={_t(\"Continue\")}\n                        onCancel={this.onCancelClick}\n                        onPrimaryButtonClick={this.onContinueClick}\n                    />\n                </div>\n            </BaseDialog>\n        );\n    }\n}\n"]}