diff --git a/src/components/views/right_panel/EncryptionPanel.js b/src/components/views/right_panel/EncryptionPanel.js
index 89c9a26e92..a5685e0617 100644
--- a/src/components/views/right_panel/EncryptionPanel.js
+++ b/src/components/views/right_panel/EncryptionPanel.js
@@ -23,7 +23,7 @@ import {MatrixClientPeg} from "../../../MatrixClientPeg";
import {ensureDMExists} from "../../../createRoom";
import {useEventEmitter} from "../../../hooks/useEventEmitter";
import Modal from "../../../Modal";
-import {PHASE_REQUESTED} from "matrix-js-sdk/src/crypto/verification/request/VerificationRequest";
+import {PHASE_REQUESTED, PHASE_UNSENT} from "matrix-js-sdk/src/crypto/verification/request/VerificationRequest";
import * as sdk from "../../../index";
import {_t} from "../../../languageHandler";
@@ -72,7 +72,7 @@ const EncryptionPanel = ({verificationRequest, member, onClose, layout}) => {
setPhase(verificationRequest.phase);
}, [member.userId]);
- const requested = request && (phase === PHASE_REQUESTED || phase === undefined);
+ const requested = request && (phase === PHASE_REQUESTED || phase === PHASE_UNSENT || phase === undefined);
if (!request || requested) {
return ;
} else {
diff --git a/src/components/views/right_panel/VerificationPanel.js b/src/components/views/right_panel/VerificationPanel.js
index 106007b98b..45a9b9eddb 100644
--- a/src/components/views/right_panel/VerificationPanel.js
+++ b/src/components/views/right_panel/VerificationPanel.js
@@ -19,6 +19,8 @@ import PropTypes from "prop-types";
import * as sdk from '../../../index';
import {verificationMethods} from 'matrix-js-sdk/src/crypto';
+import {SCAN_QR_CODE_METHOD} from "matrix-js-sdk/src/crypto/verification/QRCode";
+
import VerificationQRCode from "../elements/crypto/VerificationQRCode";
import {_t} from "../../../languageHandler";
import E2EIcon from "../rooms/E2EIcon";
@@ -54,7 +56,9 @@ export default class VerificationPanel extends React.PureComponent {
qrCodeProps: null, // generated by the VerificationQRCode component itself
};
this._hasVerifier = false;
- this._generateQRCodeProps(props.request);
+ if (this.props.request.otherPartySupportsMethod(SCAN_QR_CODE_METHOD)) {
+ this._generateQRCodeProps(props.request);
+ }
}
async _generateQRCodeProps(verificationRequest: VerificationRequest) {
@@ -67,59 +71,60 @@ export default class VerificationPanel extends React.PureComponent {
}
renderQRPhase(pending) {
- const {member} = this.props;
+ const {member, request} = this.props;
+ const showSAS = request.methods.includes(verificationMethods.SAS);
+ const showQR = this.props.request.otherPartySupportsMethod(SCAN_QR_CODE_METHOD);
const AccessibleButton = sdk.getComponent('elements.AccessibleButton');
+ const noCommonMethodError = !showSAS && !showQR ?
+
{_t("The session you are trying to verify doesn't support scanning a QR code or emoji verification, which is what Riot supports. Try with a different client.")}
:
+ null;
+
if (this.props.layout === 'dialog') {
// HACK: This is a terrible idea.
- let qrCode =
;
- if (this.state.qrCodeProps) {
- qrCode = ;
+ let qrBlock;
+ let sasBlock;
+ if (showQR) {
+ let qrCode;
+ if (this.state.qrCodeProps) {
+ qrCode = ;
+ } else {
+ qrCode =
;
+ }
+ qrBlock =
+
+
{_t("Scan this unique code")}
+ {qrCode}
+
;
}
+ if (showSAS) {
+ sasBlock =
+
+
{_t("Compare unique emoji")}
+
{_t("Compare a unique set of emoji if you don't have a camera on either device")}
+
+ {_t("Start")}
+
+
;
+ }
+ const or = qrBlock && sasBlock ?
+ {_t("or")}
: null;
return (
{_t("Verify this session by completing one of the following:")}
-
-
{_t("Scan this unique code")}
- {qrCode}
-
-
{_t("or")}
-
-
{_t("Compare unique emoji")}
-
{_t("Compare a unique set of emoji if you don't have a camera on either device")}
-
- {_t("Start")}
-
-
+ {qrBlock}
+ {or}
+ {sasBlock}
+ {noCommonMethodError}
);
}
- let button;
- if (pending) {
- button = ;
- } else {
- const disabled = this.state.emojiButtonClicked;
- button = (
-
- {_t("Verify by emoji")}
-
- );
- }
-
- if (!this.state.qrCodeProps) {
- return
-
{_t("Verify by emoji")}
-
{_t("Verify by comparing unique emoji.")}
- { button }
-
;
- }
-
- // TODO: add way to open camera to scan a QR code
- return
-
+ let qrBlock;
+ if (this.state.qrCodeProps) {
+ qrBlock =
{_t("Verify by scanning")}
{_t("Ask %(displayName)s to scan your code:", {
displayName: member.displayName || member.name || member.userId,
@@ -128,14 +133,41 @@ export default class VerificationPanel extends React.PureComponent {
-
+
;
+ }
-
+ let sasBlock;
+ if (showSAS) {
+ let button;
+ if (pending) {
+ button =
;
+ } else {
+ const disabled = this.state.emojiButtonClicked;
+ button = (
+
+ {_t("Verify by emoji")}
+
+ );
+ }
+ const sasLabel = this.state.qrCodeProps ?
+ _t("If you can't scan the code above, verify by comparing unique emoji.") :
+ _t("Verify by comparing unique emoji.");
+ sasBlock =
{_t("Verify by emoji")}
-
{_t("If you can't scan the code above, verify by comparing unique emoji.")}
-
+
{sasLabel}
{ button }
-
+
;
+ }
+
+ const noCommonMethodBlock = noCommonMethodError ?
+ {noCommonMethodError}
:
+ null;
+
+ // TODO: add way to open camera to scan a QR code
+ return
+ {qrBlock}
+ {sasBlock}
+ {noCommonMethodBlock}
;
}
diff --git a/src/i18n/strings/en_EN.json b/src/i18n/strings/en_EN.json
index 474c5e15f3..b55b28ce97 100644
--- a/src/i18n/strings/en_EN.json
+++ b/src/i18n/strings/en_EN.json
@@ -1198,11 +1198,12 @@
"This client does not support end-to-end encryption.": "This client does not support end-to-end encryption.",
"Messages in this room are not end-to-end encrypted.": "Messages in this room are not end-to-end encrypted.",
"Security": "Security",
- "Verify by emoji": "Verify by emoji",
- "Verify by comparing unique emoji.": "Verify by comparing unique emoji.",
+ "The session you are trying to verify doesn't support scanning a QR code or emoji verification, which is what Riot supports. Try with a different client.": "The session you are trying to verify doesn't support scanning a QR code or emoji verification, which is what Riot supports. Try with a different client.",
"Verify by scanning": "Verify by scanning",
"Ask %(displayName)s to scan your code:": "Ask %(displayName)s to scan your code:",
+ "Verify by emoji": "Verify by emoji",
"If you can't scan the code above, verify by comparing unique emoji.": "If you can't scan the code above, verify by comparing unique emoji.",
+ "Verify by comparing unique emoji.": "Verify by comparing unique emoji.",
"You've successfully verified %(displayName)s!": "You've successfully verified %(displayName)s!",
"Got it": "Got it",
"Verification timed out. Start verification again from their profile.": "Verification timed out. Start verification again from their profile.",