UNPKG

matrix-react-sdk

Version:
88 lines (83 loc) 12.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.E2EStatus = void 0; exports.shieldStatusForRoom = shieldStatusForRoom; var _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _DMRoomMap = _interopRequireDefault(require("./DMRoomMap")); var _arrays = require("./arrays"); /* 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. */ let E2EStatus = exports.E2EStatus = /*#__PURE__*/function (E2EStatus) { E2EStatus["Warning"] = "warning"; E2EStatus["Verified"] = "verified"; E2EStatus["Normal"] = "normal"; return E2EStatus; }({}); async function shieldStatusForRoom(client, room) { const crypto = client.getCrypto(); if (!crypto) { return E2EStatus.Warning; } try { const members = (await room.getEncryptionTargetMembers()).map(({ userId }) => userId); const inDMMap = !!_DMRoomMap.default.shared().getUserIdForRoomId(room.roomId); const verified = []; const unverified = []; for (const userId of members) { if (userId === client.getUserId()) continue; const userTrust = await crypto.getUserVerificationStatus(userId); /* Alarm if any unverified users were verified before. */ if (userTrust.wasCrossSigningVerified() && !userTrust.isCrossSigningVerified()) { return E2EStatus.Warning; } (userTrust.isCrossSigningVerified() ? verified : unverified).push(userId); } /* Check all verified user devices. */ /* Don't alarm if no other users are verified */ const includeUser = verified.length > 0 && // Don't alarm for self in rooms where nobody else is verified !inDMMap && // Don't alarm for self in DMs with other users members.length !== 2 || // Don't alarm for self in 1:1 chats with other users members.length === 1; // Do alarm for self if we're alone in a room const targets = includeUser ? [...verified, client.getUserId()] : verified; const devicesByUser = await crypto.getUserDeviceInfo(targets); for (const userId of targets) { const devices = devicesByUser.get(userId); if (!devices) { // getUserDeviceInfo returned nothing about this user, which means we know nothing about their device list. // That seems odd, so treat it as a warning. _logger.logger.warn(`No device info for user ${userId}`); return E2EStatus.Warning; } const anyDeviceNotVerified = await (0, _arrays.asyncSome)(devices.keys(), async deviceId => { const verificationStatus = await crypto.getDeviceVerificationStatus(userId, deviceId); return !verificationStatus?.isVerified(); }); if (anyDeviceNotVerified) { return E2EStatus.Warning; } } return unverified.length === 0 ? E2EStatus.Verified : E2EStatus.Normal; } catch (e) { if (!(e instanceof _matrix.ClientStoppedError)) { throw e; } // The client has been stopped while we were figuring out what to do. Catch the exception to stop it being // logged. It probably doesn't really matter what we return. _logger.logger.warn("shieldStatusForRoom: client stopped"); return E2EStatus.Normal; } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_matrix","require","_logger","_DMRoomMap","_interopRequireDefault","_arrays","E2EStatus","exports","shieldStatusForRoom","client","room","crypto","getCrypto","Warning","members","getEncryptionTargetMembers","map","userId","inDMMap","DMRoomMap","shared","getUserIdForRoomId","roomId","verified","unverified","getUserId","userTrust","getUserVerificationStatus","wasCrossSigningVerified","isCrossSigningVerified","push","includeUser","length","targets","devicesByUser","getUserDeviceInfo","devices","get","logger","warn","anyDeviceNotVerified","asyncSome","keys","deviceId","verificationStatus","getDeviceVerificationStatus","isVerified","Verified","Normal","e","ClientStoppedError"],"sources":["../../src/utils/ShieldUtils.ts"],"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 { ClientStoppedError, MatrixClient, Room } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport DMRoomMap from \"./DMRoomMap\";\nimport { asyncSome } from \"./arrays\";\n\nexport enum E2EStatus {\n    Warning = \"warning\",\n    Verified = \"verified\",\n    Normal = \"normal\",\n}\n\nexport async function shieldStatusForRoom(client: MatrixClient, room: Room): Promise<E2EStatus> {\n    const crypto = client.getCrypto();\n    if (!crypto) {\n        return E2EStatus.Warning;\n    }\n\n    try {\n        const members = (await room.getEncryptionTargetMembers()).map(({ userId }) => userId);\n        const inDMMap = !!DMRoomMap.shared().getUserIdForRoomId(room.roomId);\n\n        const verified: string[] = [];\n        const unverified: string[] = [];\n        for (const userId of members) {\n            if (userId === client.getUserId()) continue;\n            const userTrust = await crypto.getUserVerificationStatus(userId);\n\n            /* Alarm if any unverified users were verified before. */\n            if (userTrust.wasCrossSigningVerified() && !userTrust.isCrossSigningVerified()) {\n                return E2EStatus.Warning;\n            }\n            (userTrust.isCrossSigningVerified() ? verified : unverified).push(userId);\n        }\n\n        /* Check all verified user devices. */\n        /* Don't alarm if no other users are verified  */\n        const includeUser =\n            (verified.length > 0 && // Don't alarm for self in rooms where nobody else is verified\n                !inDMMap && // Don't alarm for self in DMs with other users\n                members.length !== 2) || // Don't alarm for self in 1:1 chats with other users\n            members.length === 1; // Do alarm for self if we're alone in a room\n        const targets = includeUser ? [...verified, client.getUserId()!] : verified;\n        const devicesByUser = await crypto.getUserDeviceInfo(targets);\n        for (const userId of targets) {\n            const devices = devicesByUser.get(userId);\n            if (!devices) {\n                // getUserDeviceInfo returned nothing about this user, which means we know nothing about their device list.\n                // That seems odd, so treat it as a warning.\n                logger.warn(`No device info for user ${userId}`);\n                return E2EStatus.Warning;\n            }\n\n            const anyDeviceNotVerified = await asyncSome(devices.keys(), async (deviceId) => {\n                const verificationStatus = await crypto.getDeviceVerificationStatus(userId, deviceId);\n                return !verificationStatus?.isVerified();\n            });\n            if (anyDeviceNotVerified) {\n                return E2EStatus.Warning;\n            }\n        }\n\n        return unverified.length === 0 ? E2EStatus.Verified : E2EStatus.Normal;\n    } catch (e) {\n        if (!(e instanceof ClientStoppedError)) {\n            throw e;\n        }\n\n        // The client has been stopped while we were figuring out what to do. Catch the exception to stop it being\n        // logged. It probably doesn't really matter what we return.\n        logger.warn(\"shieldStatusForRoom: client stopped\");\n        return E2EStatus.Normal;\n    }\n}\n"],"mappings":"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","ignoreList":[]}