UNPKG

matrix-react-sdk

Version:
239 lines (202 loc) 29.7 kB
"use strict"; 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 _MatrixClientPeg = require("../../../MatrixClientPeg"); var sdk = _interopRequireWildcard(require("../../../index")); var _languageHandler = require("../../../languageHandler"); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _Media = require("../../../customisations/Media"); var _dec, _class, _class2, _temp; const PHASE_START = 0; const PHASE_SHOW_SAS = 1; const PHASE_WAIT_FOR_PARTNER_TO_CONFIRM = 2; const PHASE_VERIFIED = 3; const PHASE_CANCELLED = 4; let IncomingSasDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.IncomingSasDialog"), _dec(_class = (_temp = _class2 = class IncomingSasDialog extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "_onFinished", () => { this.props.onFinished(this.state.phase === PHASE_VERIFIED); }); (0, _defineProperty2.default)(this, "_onCancelClick", () => { this.props.onFinished(this.state.phase === PHASE_VERIFIED); }); (0, _defineProperty2.default)(this, "_onContinueClick", () => { this.setState({ phase: PHASE_WAIT_FOR_PARTNER_TO_CONFIRM }); this.props.verifier.verify().then(() => { this.setState({ phase: PHASE_VERIFIED }); }).catch(e => { console.log("Verification failed", e); }); }); (0, _defineProperty2.default)(this, "_onVerifierShowSas", e => { this._showSasEvent = e; this.setState({ phase: PHASE_SHOW_SAS, sas: e.sas }); }); (0, _defineProperty2.default)(this, "_onVerifierCancel", e => { this.setState({ phase: PHASE_CANCELLED }); }); (0, _defineProperty2.default)(this, "_onSasMatchesClick", () => { this._showSasEvent.confirm(); this.setState({ phase: PHASE_WAIT_FOR_PARTNER_TO_CONFIRM }); }); (0, _defineProperty2.default)(this, "_onVerifiedDoneClick", () => { this.props.onFinished(true); }); let phase = PHASE_START; if (this.props.verifier.cancelled) { console.log("Verifier was cancelled in the background."); phase = PHASE_CANCELLED; } this._showSasEvent = null; this.state = { phase: phase, sasVerified: false, opponentProfile: null, opponentProfileError: null }; this.props.verifier.on('show_sas', this._onVerifierShowSas); this.props.verifier.on('cancel', this._onVerifierCancel); this._fetchOpponentProfile(); } componentWillUnmount() { if (this.state.phase !== PHASE_CANCELLED && this.state.phase !== PHASE_VERIFIED) { this.props.verifier.cancel('User cancel'); } this.props.verifier.removeListener('show_sas', this._onVerifierShowSas); } async _fetchOpponentProfile() { try { const prof = await _MatrixClientPeg.MatrixClientPeg.get().getProfileInfo(this.props.verifier.userId); this.setState({ opponentProfile: prof }); } catch (e) { this.setState({ opponentProfileError: e }); } } _renderPhaseStart() { const DialogButtons = sdk.getComponent('views.elements.DialogButtons'); const Spinner = sdk.getComponent("views.elements.Spinner"); const BaseAvatar = sdk.getComponent("avatars.BaseAvatar"); const isSelf = this.props.verifier.userId === _MatrixClientPeg.MatrixClientPeg.get().getUserId(); let profile; const oppProfile = this.state.opponentProfile; if (oppProfile) { const url = oppProfile.avatar_url ? (0, _Media.mediaFromMxc)(oppProfile.avatar_url).getSquareThumbnailHttp(48) : null; profile = /*#__PURE__*/_react.default.createElement("div", { className: "mx_IncomingSasDialog_opponentProfile" }, /*#__PURE__*/_react.default.createElement(BaseAvatar, { name: oppProfile.displayname, idName: this.props.verifier.userId, url: url, width: 48, height: 48, resizeMethod: "crop" }), /*#__PURE__*/_react.default.createElement("h2", null, oppProfile.displayname)); } else if (this.state.opponentProfileError) { profile = /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(BaseAvatar, { name: this.props.verifier.userId.slice(1), idName: this.props.verifier.userId, width: 48, height: 48 }), /*#__PURE__*/_react.default.createElement("h2", null, this.props.verifier.userId)); } else { profile = /*#__PURE__*/_react.default.createElement(Spinner, null); } const userDetailText = [/*#__PURE__*/_react.default.createElement("p", { key: "p1" }, (0, _languageHandler._t)("Verify this user to mark them as trusted. " + "Trusting users gives you extra peace of mind when using " + "end-to-end encrypted messages.")), /*#__PURE__*/_react.default.createElement("p", { key: "p2" }, (0, _languageHandler._t)( // NB. Below wording adjusted to singular 'session' until we have // cross-signing "Verifying this user will mark their session as trusted, and " + "also mark your session as trusted to them."))]; const selfDetailText = [/*#__PURE__*/_react.default.createElement("p", { key: "p1" }, (0, _languageHandler._t)("Verify this device to mark it as trusted. " + "Trusting this device gives you and other users extra peace of mind when using " + "end-to-end encrypted messages.")), /*#__PURE__*/_react.default.createElement("p", { key: "p2" }, (0, _languageHandler._t)("Verifying this device will mark it as trusted, and users who have verified with " + "you will trust this device."))]; return /*#__PURE__*/_react.default.createElement("div", null, profile, isSelf ? selfDetailText : userDetailText, /*#__PURE__*/_react.default.createElement(DialogButtons, { primaryButton: (0, _languageHandler._t)('Continue'), hasCancel: true, onPrimaryButtonClick: this._onContinueClick, onCancel: this._onCancelClick })); } _renderPhaseShowSas() { const VerificationShowSas = sdk.getComponent('views.verification.VerificationShowSas'); return /*#__PURE__*/_react.default.createElement(VerificationShowSas, { sas: this._showSasEvent.sas, onCancel: this._onCancelClick, onDone: this._onSasMatchesClick, isSelf: this.props.verifier.userId === _MatrixClientPeg.MatrixClientPeg.get().getUserId(), inDialog: true }); } _renderPhaseWaitForPartnerToConfirm() { const Spinner = sdk.getComponent("views.elements.Spinner"); return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(Spinner, null), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Waiting for partner to confirm..."))); } _renderPhaseVerified() { const VerificationComplete = sdk.getComponent('views.verification.VerificationComplete'); return /*#__PURE__*/_react.default.createElement(VerificationComplete, { onDone: this._onVerifiedDoneClick }); } _renderPhaseCancelled() { const VerificationCancelled = sdk.getComponent('views.verification.VerificationCancelled'); return /*#__PURE__*/_react.default.createElement(VerificationCancelled, { onDone: this._onCancelClick }); } render() { let body; switch (this.state.phase) { case PHASE_START: body = this._renderPhaseStart(); break; case PHASE_SHOW_SAS: body = this._renderPhaseShowSas(); break; case PHASE_WAIT_FOR_PARTNER_TO_CONFIRM: body = this._renderPhaseWaitForPartnerToConfirm(); break; case PHASE_VERIFIED: body = this._renderPhaseVerified(); break; case PHASE_CANCELLED: body = this._renderPhaseCancelled(); break; } const BaseDialog = sdk.getComponent("dialogs.BaseDialog"); return /*#__PURE__*/_react.default.createElement(BaseDialog, { title: (0, _languageHandler._t)("Incoming Verification Request"), onFinished: this._onFinished, fixedWidth: false }, body); } }, (0, _defineProperty2.default)(_class2, "propTypes", { verifier: _propTypes.default.object.isRequired }), _temp)) || _class); exports.default = IncomingSasDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/IncomingSasDialog.js"],"names":["PHASE_START","PHASE_SHOW_SAS","PHASE_WAIT_FOR_PARTNER_TO_CONFIRM","PHASE_VERIFIED","PHASE_CANCELLED","IncomingSasDialog","React","Component","constructor","props","onFinished","state","phase","setState","verifier","verify","then","catch","e","console","log","_showSasEvent","sas","confirm","cancelled","sasVerified","opponentProfile","opponentProfileError","on","_onVerifierShowSas","_onVerifierCancel","_fetchOpponentProfile","componentWillUnmount","cancel","removeListener","prof","MatrixClientPeg","get","getProfileInfo","userId","_renderPhaseStart","DialogButtons","sdk","getComponent","Spinner","BaseAvatar","isSelf","getUserId","profile","oppProfile","url","avatar_url","getSquareThumbnailHttp","displayname","slice","userDetailText","selfDetailText","_onContinueClick","_onCancelClick","_renderPhaseShowSas","VerificationShowSas","_onSasMatchesClick","_renderPhaseWaitForPartnerToConfirm","_renderPhaseVerified","VerificationComplete","_onVerifiedDoneClick","_renderPhaseCancelled","VerificationCancelled","render","body","BaseDialog","_onFinished","PropTypes","object","isRequired"],"mappings":"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","sourcesContent":["/*\nCopyright 2019 New Vector Ltd\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 {MatrixClientPeg} from '../../../MatrixClientPeg';\nimport * as sdk from '../../../index';\nimport { _t } from '../../../languageHandler';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\nconst PHASE_START = 0;\nconst PHASE_SHOW_SAS = 1;\nconst PHASE_WAIT_FOR_PARTNER_TO_CONFIRM = 2;\nconst PHASE_VERIFIED = 3;\nconst PHASE_CANCELLED = 4;\n\n@replaceableComponent(\"views.dialogs.IncomingSasDialog\")\nexport default class IncomingSasDialog extends React.Component {\n    static propTypes = {\n        verifier: PropTypes.object.isRequired,\n    };\n\n    constructor(props) {\n        super(props);\n\n        let phase = PHASE_START;\n        if (this.props.verifier.cancelled) {\n            console.log(\"Verifier was cancelled in the background.\");\n            phase = PHASE_CANCELLED;\n        }\n\n        this._showSasEvent = null;\n        this.state = {\n            phase: phase,\n            sasVerified: false,\n            opponentProfile: null,\n            opponentProfileError: null,\n        };\n        this.props.verifier.on('show_sas', this._onVerifierShowSas);\n        this.props.verifier.on('cancel', this._onVerifierCancel);\n        this._fetchOpponentProfile();\n    }\n\n    componentWillUnmount() {\n        if (this.state.phase !== PHASE_CANCELLED && this.state.phase !== PHASE_VERIFIED) {\n            this.props.verifier.cancel('User cancel');\n        }\n        this.props.verifier.removeListener('show_sas', this._onVerifierShowSas);\n    }\n\n    async _fetchOpponentProfile() {\n        try {\n            const prof = await MatrixClientPeg.get().getProfileInfo(\n                this.props.verifier.userId,\n            );\n            this.setState({\n                opponentProfile: prof,\n            });\n        } catch (e) {\n            this.setState({\n                opponentProfileError: e,\n            });\n        }\n    }\n\n    _onFinished = () => {\n        this.props.onFinished(this.state.phase === PHASE_VERIFIED);\n    }\n\n    _onCancelClick = () => {\n        this.props.onFinished(this.state.phase === PHASE_VERIFIED);\n    }\n\n    _onContinueClick = () => {\n        this.setState({phase: PHASE_WAIT_FOR_PARTNER_TO_CONFIRM});\n        this.props.verifier.verify().then(() => {\n            this.setState({phase: PHASE_VERIFIED});\n        }).catch((e) => {\n            console.log(\"Verification failed\", e);\n        });\n    }\n\n    _onVerifierShowSas = (e) => {\n        this._showSasEvent = e;\n        this.setState({\n            phase: PHASE_SHOW_SAS,\n            sas: e.sas,\n        });\n    }\n\n    _onVerifierCancel = (e) => {\n        this.setState({\n            phase: PHASE_CANCELLED,\n        });\n    }\n\n    _onSasMatchesClick = () => {\n        this._showSasEvent.confirm();\n        this.setState({\n            phase: PHASE_WAIT_FOR_PARTNER_TO_CONFIRM,\n        });\n    }\n\n    _onVerifiedDoneClick = () => {\n        this.props.onFinished(true);\n    }\n\n    _renderPhaseStart() {\n        const DialogButtons = sdk.getComponent('views.elements.DialogButtons');\n        const Spinner = sdk.getComponent(\"views.elements.Spinner\");\n        const BaseAvatar = sdk.getComponent(\"avatars.BaseAvatar\");\n\n        const isSelf = this.props.verifier.userId === MatrixClientPeg.get().getUserId();\n\n        let profile;\n        const oppProfile = this.state.opponentProfile;\n        if (oppProfile) {\n            const url = oppProfile.avatar_url\n                ? mediaFromMxc(oppProfile.avatar_url).getSquareThumbnailHttp(48)\n                : null;\n            profile = <div className=\"mx_IncomingSasDialog_opponentProfile\">\n                <BaseAvatar name={oppProfile.displayname}\n                    idName={this.props.verifier.userId}\n                    url={url}\n                    width={48} height={48} resizeMethod='crop'\n                />\n                <h2>{oppProfile.displayname}</h2>\n            </div>;\n        } else if (this.state.opponentProfileError) {\n            profile = <div>\n                <BaseAvatar name={this.props.verifier.userId.slice(1)}\n                    idName={this.props.verifier.userId}\n                    width={48} height={48}\n                />\n                <h2>{this.props.verifier.userId}</h2>\n            </div>;\n        } else {\n            profile = <Spinner />;\n        }\n\n        const userDetailText = [\n            <p key=\"p1\">{_t(\n                \"Verify this user to mark them as trusted. \" +\n                \"Trusting users gives you extra peace of mind when using \" +\n                \"end-to-end encrypted messages.\",\n            )}</p>,\n            <p key=\"p2\">{_t(\n                // NB. Below wording adjusted to singular 'session' until we have\n                // cross-signing\n                \"Verifying this user will mark their session as trusted, and \" +\n                \"also mark your session as trusted to them.\",\n            )}</p>,\n        ];\n\n        const selfDetailText = [\n            <p key=\"p1\">{_t(\n                \"Verify this device to mark it as trusted. \" +\n                \"Trusting this device gives you and other users extra peace of mind when using \" +\n                \"end-to-end encrypted messages.\",\n            )}</p>,\n            <p key=\"p2\">{_t(\n                \"Verifying this device will mark it as trusted, and users who have verified with \" +\n                \"you will trust this device.\",\n            )}</p>,\n        ];\n\n        return (\n            <div>\n                {profile}\n                {isSelf ? selfDetailText : userDetailText}\n                <DialogButtons\n                    primaryButton={_t('Continue')}\n                    hasCancel={true}\n                    onPrimaryButtonClick={this._onContinueClick}\n                    onCancel={this._onCancelClick}\n                />\n            </div>\n        );\n    }\n\n    _renderPhaseShowSas() {\n        const VerificationShowSas = sdk.getComponent('views.verification.VerificationShowSas');\n        return <VerificationShowSas\n            sas={this._showSasEvent.sas}\n            onCancel={this._onCancelClick}\n            onDone={this._onSasMatchesClick}\n            isSelf={this.props.verifier.userId === MatrixClientPeg.get().getUserId()}\n            inDialog={true}\n        />;\n    }\n\n    _renderPhaseWaitForPartnerToConfirm() {\n        const Spinner = sdk.getComponent(\"views.elements.Spinner\");\n\n        return (\n            <div>\n                <Spinner />\n                <p>{_t(\"Waiting for partner to confirm...\")}</p>\n            </div>\n        );\n    }\n\n    _renderPhaseVerified() {\n        const VerificationComplete = sdk.getComponent('views.verification.VerificationComplete');\n        return <VerificationComplete onDone={this._onVerifiedDoneClick} />;\n    }\n\n    _renderPhaseCancelled() {\n        const VerificationCancelled = sdk.getComponent('views.verification.VerificationCancelled');\n        return <VerificationCancelled onDone={this._onCancelClick} />;\n    }\n\n    render() {\n        let body;\n        switch (this.state.phase) {\n            case PHASE_START:\n                body = this._renderPhaseStart();\n                break;\n            case PHASE_SHOW_SAS:\n                body = this._renderPhaseShowSas();\n                break;\n            case PHASE_WAIT_FOR_PARTNER_TO_CONFIRM:\n                body = this._renderPhaseWaitForPartnerToConfirm();\n                break;\n            case PHASE_VERIFIED:\n                body = this._renderPhaseVerified();\n                break;\n            case PHASE_CANCELLED:\n                body = this._renderPhaseCancelled();\n                break;\n        }\n\n        const BaseDialog = sdk.getComponent(\"dialogs.BaseDialog\");\n        return (\n            <BaseDialog\n                title={_t(\"Incoming Verification Request\")}\n                onFinished={this._onFinished}\n                fixedWidth={false}\n            >\n                {body}\n            </BaseDialog>\n        );\n    }\n}\n\n"]}