UNPKG

matrix-react-sdk

Version:
111 lines (109 loc) 22.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _logger = require("matrix-js-sdk/src/logger"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _languageHandler = require("../../../languageHandler"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var FormattingUtils = _interopRequireWildcard(require("../../../utils/FormattingUtils")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _SettingsFlag = _interopRequireDefault(require("../elements/SettingsFlag")); var _SettingLevel = require("../../../settings/SettingLevel"); var _SettingsSubsection = _interopRequireWildcard(require("./shared/SettingsSubsection")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* Copyright 2024 New Vector Ltd. Copyright 2021 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ class CryptographyPanel extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "onExportE2eKeysClicked", () => { _Modal.default.createDialogAsync(Promise.resolve().then(() => _interopRequireWildcard(require("../../../async-components/views/dialogs/security/ExportE2eKeysDialog"))), { matrixClient: _MatrixClientPeg.MatrixClientPeg.safeGet() }); }); (0, _defineProperty2.default)(this, "onImportE2eKeysClicked", () => { _Modal.default.createDialogAsync(Promise.resolve().then(() => _interopRequireWildcard(require("../../../async-components/views/dialogs/security/ImportE2eKeysDialog"))), { matrixClient: _MatrixClientPeg.MatrixClientPeg.safeGet() }); }); (0, _defineProperty2.default)(this, "updateBlacklistDevicesFlag", checked => { _MatrixClientPeg.MatrixClientPeg.safeGet().setGlobalBlacklistUnverifiedDevices(checked); }); const client = _MatrixClientPeg.MatrixClientPeg.safeGet(); const crypto = client.getCrypto(); if (!crypto) { this.state = { deviceIdentityKey: null }; } else { this.state = { deviceIdentityKey: undefined }; crypto.getOwnDeviceKeys().then(keys => { this.setState({ deviceIdentityKey: keys.ed25519 }); }).catch(e => { _logger.logger.error(`CryptographyPanel: Error fetching own device keys: ${e}`); this.setState({ deviceIdentityKey: null }); }); } } render() { const client = _MatrixClientPeg.MatrixClientPeg.safeGet(); const deviceId = client.deviceId; let identityKey = this.state.deviceIdentityKey; if (identityKey === undefined) { // Should show a spinner here really, but since this will be very transitional, I can't be doing with the // necessary styling. identityKey = "..."; } else if (identityKey === null) { identityKey = (0, _languageHandler._t)("encryption|not_supported"); } else { identityKey = FormattingUtils.formatCryptoKey(identityKey); } let importExportButtons; if (client.getCrypto()) { importExportButtons = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CryptographyPanel_importExportButtons" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "primary_outline", onClick: this.onExportE2eKeysClicked }, (0, _languageHandler._t)("settings|security|export_megolm_keys")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "primary_outline", onClick: this.onImportE2eKeysClicked }, (0, _languageHandler._t)("settings|security|import_megolm_keys"))); } let noSendUnverifiedSetting; if (_SettingsStore.default.canSetValue("blacklistUnverifiedDevices", null, _SettingLevel.SettingLevel.DEVICE)) { noSendUnverifiedSetting = /*#__PURE__*/_react.default.createElement(_SettingsFlag.default, { name: "blacklistUnverifiedDevices", level: _SettingLevel.SettingLevel.DEVICE, onChange: this.updateBlacklistDevicesFlag }); } return /*#__PURE__*/_react.default.createElement(_SettingsSubsection.default, { heading: (0, _languageHandler._t)("settings|security|cryptography_section") }, /*#__PURE__*/_react.default.createElement(_SettingsSubsection.SettingsSubsectionText, null, /*#__PURE__*/_react.default.createElement("table", { className: "mx_CryptographyPanel_sessionInfo" }, /*#__PURE__*/_react.default.createElement("tbody", null, /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("th", { scope: "row" }, (0, _languageHandler._t)("settings|security|session_id")), /*#__PURE__*/_react.default.createElement("td", null, /*#__PURE__*/_react.default.createElement("code", null, deviceId))), /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("th", { scope: "row" }, (0, _languageHandler._t)("settings|security|session_key")), /*#__PURE__*/_react.default.createElement("td", null, /*#__PURE__*/_react.default.createElement("code", null, /*#__PURE__*/_react.default.createElement("strong", null, identityKey))))))), importExportButtons, noSendUnverifiedSetting); } } exports.default = CryptographyPanel; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_logger","_MatrixClientPeg","_languageHandler","_Modal","_AccessibleButton","FormattingUtils","_interopRequireWildcard","_SettingsStore","_SettingsFlag","_SettingLevel","_SettingsSubsection","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","CryptographyPanel","React","Component","constructor","props","_defineProperty2","Modal","createDialogAsync","Promise","resolve","then","matrixClient","MatrixClientPeg","safeGet","checked","setGlobalBlacklistUnverifiedDevices","client","crypto","getCrypto","state","deviceIdentityKey","undefined","getOwnDeviceKeys","keys","setState","ed25519","catch","logger","error","render","deviceId","identityKey","_t","formatCryptoKey","importExportButtons","createElement","className","kind","onClick","onExportE2eKeysClicked","onImportE2eKeysClicked","noSendUnverifiedSetting","SettingsStore","canSetValue","SettingLevel","DEVICE","name","level","onChange","updateBlacklistDevicesFlag","heading","SettingsSubsectionText","scope","exports"],"sources":["../../../../src/components/views/settings/CryptographyPanel.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React from \"react\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport type ExportE2eKeysDialog from \"../../../async-components/views/dialogs/security/ExportE2eKeysDialog\";\nimport type ImportE2eKeysDialog from \"../../../async-components/views/dialogs/security/ImportE2eKeysDialog\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { _t } from \"../../../languageHandler\";\nimport Modal from \"../../../Modal\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport * as FormattingUtils from \"../../../utils/FormattingUtils\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport SettingsFlag from \"../elements/SettingsFlag\";\nimport { SettingLevel } from \"../../../settings/SettingLevel\";\nimport SettingsSubsection, { SettingsSubsectionText } from \"./shared/SettingsSubsection\";\n\ninterface IProps {}\n\ninterface IState {\n    /** The device's base64-encoded Ed25519 identity key, or:\n     *\n     * * `undefined`: not yet loaded\n     * * `null`: encryption is not supported (or the crypto stack was not correctly initialized)\n     */\n    deviceIdentityKey: string | undefined | null;\n}\n\nexport default class CryptographyPanel extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n\n        const client = MatrixClientPeg.safeGet();\n        const crypto = client.getCrypto();\n        if (!crypto) {\n            this.state = { deviceIdentityKey: null };\n        } else {\n            this.state = { deviceIdentityKey: undefined };\n            crypto\n                .getOwnDeviceKeys()\n                .then((keys) => {\n                    this.setState({ deviceIdentityKey: keys.ed25519 });\n                })\n                .catch((e) => {\n                    logger.error(`CryptographyPanel: Error fetching own device keys: ${e}`);\n                    this.setState({ deviceIdentityKey: null });\n                });\n        }\n    }\n\n    public render(): React.ReactNode {\n        const client = MatrixClientPeg.safeGet();\n        const deviceId = client.deviceId;\n        let identityKey = this.state.deviceIdentityKey;\n        if (identityKey === undefined) {\n            // Should show a spinner here really, but since this will be very transitional, I can't be doing with the\n            // necessary styling.\n            identityKey = \"...\";\n        } else if (identityKey === null) {\n            identityKey = _t(\"encryption|not_supported\");\n        } else {\n            identityKey = FormattingUtils.formatCryptoKey(identityKey);\n        }\n\n        let importExportButtons: JSX.Element | undefined;\n        if (client.getCrypto()) {\n            importExportButtons = (\n                <div className=\"mx_CryptographyPanel_importExportButtons\">\n                    <AccessibleButton kind=\"primary_outline\" onClick={this.onExportE2eKeysClicked}>\n                        {_t(\"settings|security|export_megolm_keys\")}\n                    </AccessibleButton>\n                    <AccessibleButton kind=\"primary_outline\" onClick={this.onImportE2eKeysClicked}>\n                        {_t(\"settings|security|import_megolm_keys\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        let noSendUnverifiedSetting: JSX.Element | undefined;\n        if (SettingsStore.canSetValue(\"blacklistUnverifiedDevices\", null, SettingLevel.DEVICE)) {\n            noSendUnverifiedSetting = (\n                <SettingsFlag\n                    name=\"blacklistUnverifiedDevices\"\n                    level={SettingLevel.DEVICE}\n                    onChange={this.updateBlacklistDevicesFlag}\n                />\n            );\n        }\n\n        return (\n            <SettingsSubsection heading={_t(\"settings|security|cryptography_section\")}>\n                <SettingsSubsectionText>\n                    <table className=\"mx_CryptographyPanel_sessionInfo\">\n                        <tbody>\n                            <tr>\n                                <th scope=\"row\">{_t(\"settings|security|session_id\")}</th>\n                                <td>\n                                    <code>{deviceId}</code>\n                                </td>\n                            </tr>\n                            <tr>\n                                <th scope=\"row\">{_t(\"settings|security|session_key\")}</th>\n                                <td>\n                                    <code>\n                                        <strong>{identityKey}</strong>\n                                    </code>\n                                </td>\n                            </tr>\n                        </tbody>\n                    </table>\n                </SettingsSubsectionText>\n                {importExportButtons}\n                {noSendUnverifiedSetting}\n            </SettingsSubsection>\n        );\n    }\n\n    private onExportE2eKeysClicked = (): void => {\n        Modal.createDialogAsync(\n            import(\"../../../async-components/views/dialogs/security/ExportE2eKeysDialog\") as unknown as Promise<\n                typeof ExportE2eKeysDialog\n            >,\n            { matrixClient: MatrixClientPeg.safeGet() },\n        );\n    };\n\n    private onImportE2eKeysClicked = (): void => {\n        Modal.createDialogAsync(\n            import(\"../../../async-components/views/dialogs/security/ImportE2eKeysDialog\") as unknown as Promise<\n                typeof ImportE2eKeysDialog\n            >,\n            { matrixClient: MatrixClientPeg.safeGet() },\n        );\n    };\n\n    private updateBlacklistDevicesFlag = (checked: boolean): void => {\n        MatrixClientPeg.safeGet().setGlobalBlacklistUnverifiedDevices(checked);\n    };\n}\n"],"mappings":"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","ignoreList":[]}