matrix-react-sdk
Version:
SDK for matrix.org using React
66 lines (63 loc) • 12.9 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
exports.shouldShowQr = shouldShowQr;
var _react = _interopRequireDefault(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _qrCode = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/qr-code"));
var _compoundWeb = require("@vector-im/compound-web");
var _languageHandler = require("../../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../../elements/AccessibleButton"));
var _SettingsSubsection = _interopRequireDefault(require("../shared/SettingsSubsection"));
var _MatrixClientContext = require("../../../../contexts/MatrixClientContext");
/*
Copyright 2024 New Vector Ltd.
Copyright 2022 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.
*/
function shouldShowQrLegacy(versions, wellKnown, capabilities) {
// Needs server support for (get_login_token or OIDC Device Authorization Grant) and MSC3886:
// in r0 of MSC3882 it is exposed as a feature flag, but in stable and unstable r1 it is a capability
const loginTokenCapability = _matrix.GET_LOGIN_TOKEN_CAPABILITY.findIn(capabilities);
const getLoginTokenSupported = !!versions?.unstable_features?.["org.matrix.msc3882"] || !!loginTokenCapability?.enabled;
const msc3886Supported = !!versions?.unstable_features?.["org.matrix.msc3886"] || !!wellKnown?.["io.element.rendezvous"]?.server;
return getLoginTokenSupported && msc3886Supported;
}
function shouldShowQr(cli, isCrossSigningReady, oidcClientConfig, versions, wellKnown) {
const msc4108Supported = !!versions?.unstable_features?.["org.matrix.msc4108"] || !!wellKnown?.["io.element.rendezvous"]?.server;
const deviceAuthorizationGrantSupported = oidcClientConfig?.metadata?.grant_types_supported.includes(_matrix.DEVICE_CODE_SCOPE);
return !!deviceAuthorizationGrantSupported && msc4108Supported && !!cli.getCrypto()?.exportSecretsBundle && isCrossSigningReady;
}
const LoginWithQRSection = ({
onShowQr,
versions,
capabilities,
wellKnown,
oidcClientConfig,
isCrossSigningReady
}) => {
const cli = (0, _MatrixClientContext.useMatrixClientContext)();
const offerShowQr = oidcClientConfig ? shouldShowQr(cli, !!isCrossSigningReady, oidcClientConfig, versions, wellKnown) : shouldShowQrLegacy(versions, wellKnown, capabilities);
return /*#__PURE__*/_react.default.createElement(_SettingsSubsection.default, {
heading: (0, _languageHandler._t)("settings|sessions|sign_in_with_qr")
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_LoginWithQRSection"
}, /*#__PURE__*/_react.default.createElement("p", {
className: "mx_SettingsTab_subsectionText"
}, (0, _languageHandler._t)("settings|sessions|sign_in_with_qr_description")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: onShowQr,
kind: "primary",
disabled: !offerShowQr
}, /*#__PURE__*/_react.default.createElement(_qrCode.default, {
height: 20,
width: 20
}), (0, _languageHandler._t)("settings|sessions|sign_in_with_qr_button")), !offerShowQr && /*#__PURE__*/_react.default.createElement(_compoundWeb.Text, {
size: "sm"
}, (0, _languageHandler._t)("settings|sessions|sign_in_with_qr_unsupported"))));
};
var _default = exports.default = LoginWithQRSection;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_qrCode","_compoundWeb","_languageHandler","_AccessibleButton","_SettingsSubsection","_MatrixClientContext","shouldShowQrLegacy","versions","wellKnown","capabilities","loginTokenCapability","GET_LOGIN_TOKEN_CAPABILITY","findIn","getLoginTokenSupported","unstable_features","enabled","msc3886Supported","server","shouldShowQr","cli","isCrossSigningReady","oidcClientConfig","msc4108Supported","deviceAuthorizationGrantSupported","metadata","grant_types_supported","includes","DEVICE_CODE_SCOPE","getCrypto","exportSecretsBundle","LoginWithQRSection","onShowQr","useMatrixClientContext","offerShowQr","default","createElement","heading","_t","className","onClick","kind","disabled","height","width","Text","size","_default","exports"],"sources":["../../../../../src/components/views/settings/devices/LoginWithQRSection.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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 {\n    IGetLoginTokenCapability,\n    IServerVersions,\n    GET_LOGIN_TOKEN_CAPABILITY,\n    Capabilities,\n    IClientWellKnown,\n    OidcClientConfig,\n    MatrixClient,\n    DEVICE_CODE_SCOPE,\n} from \"matrix-js-sdk/src/matrix\";\nimport QrCodeIcon from \"@vector-im/compound-design-tokens/assets/web/icons/qr-code\";\nimport { Text } from \"@vector-im/compound-web\";\n\nimport { _t } from \"../../../../languageHandler\";\nimport AccessibleButton from \"../../elements/AccessibleButton\";\nimport SettingsSubsection from \"../shared/SettingsSubsection\";\nimport { useMatrixClientContext } from \"../../../../contexts/MatrixClientContext\";\n\ninterface IProps {\n    onShowQr: () => void;\n    versions?: IServerVersions;\n    capabilities?: Capabilities;\n    wellKnown?: IClientWellKnown;\n    oidcClientConfig?: OidcClientConfig;\n    isCrossSigningReady?: boolean;\n}\n\nfunction shouldShowQrLegacy(\n    versions?: IServerVersions,\n    wellKnown?: IClientWellKnown,\n    capabilities?: Capabilities,\n): boolean {\n    // Needs server support for (get_login_token or OIDC Device Authorization Grant) and MSC3886:\n    // in r0 of MSC3882 it is exposed as a feature flag, but in stable and unstable r1 it is a capability\n    const loginTokenCapability = GET_LOGIN_TOKEN_CAPABILITY.findIn<IGetLoginTokenCapability>(capabilities);\n    const getLoginTokenSupported =\n        !!versions?.unstable_features?.[\"org.matrix.msc3882\"] || !!loginTokenCapability?.enabled;\n    const msc3886Supported =\n        !!versions?.unstable_features?.[\"org.matrix.msc3886\"] || !!wellKnown?.[\"io.element.rendezvous\"]?.server;\n    return getLoginTokenSupported && msc3886Supported;\n}\n\nexport function shouldShowQr(\n    cli: MatrixClient,\n    isCrossSigningReady: boolean,\n    oidcClientConfig?: OidcClientConfig,\n    versions?: IServerVersions,\n    wellKnown?: IClientWellKnown,\n): boolean {\n    const msc4108Supported =\n        !!versions?.unstable_features?.[\"org.matrix.msc4108\"] || !!wellKnown?.[\"io.element.rendezvous\"]?.server;\n\n    const deviceAuthorizationGrantSupported =\n        oidcClientConfig?.metadata?.grant_types_supported.includes(DEVICE_CODE_SCOPE);\n\n    return (\n        !!deviceAuthorizationGrantSupported &&\n        msc4108Supported &&\n        !!cli.getCrypto()?.exportSecretsBundle &&\n        isCrossSigningReady\n    );\n}\n\nconst LoginWithQRSection: React.FC<IProps> = ({\n    onShowQr,\n    versions,\n    capabilities,\n    wellKnown,\n    oidcClientConfig,\n    isCrossSigningReady,\n}) => {\n    const cli = useMatrixClientContext();\n    const offerShowQr = oidcClientConfig\n        ? shouldShowQr(cli, !!isCrossSigningReady, oidcClientConfig, versions, wellKnown)\n        : shouldShowQrLegacy(versions, wellKnown, capabilities);\n\n    return (\n        <SettingsSubsection heading={_t(\"settings|sessions|sign_in_with_qr\")}>\n            <div className=\"mx_LoginWithQRSection\">\n                <p className=\"mx_SettingsTab_subsectionText\">{_t(\"settings|sessions|sign_in_with_qr_description\")}</p>\n                <AccessibleButton onClick={onShowQr} kind=\"primary\" disabled={!offerShowQr}>\n                    <QrCodeIcon height={20} width={20} />\n                    {_t(\"settings|sessions|sign_in_with_qr_button\")}\n                </AccessibleButton>\n                {!offerShowQr && <Text size=\"sm\">{_t(\"settings|sessions|sign_in_with_qr_unsupported\")}</Text>}\n            </div>\n        </SettingsSubsection>\n    );\n};\n\nexport default LoginWithQRSection;\n"],"mappings":"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","ignoreList":[]}