Error Handling and some fixes

This commit is contained in:
CH Chethan Reddy 2020-06-26 15:10:37 +05:30
parent 00e36b6068
commit ffa61095b8
5 changed files with 144 additions and 102 deletions

View file

@ -108,7 +108,18 @@ ApplicationWindow{
// userProfileList.ignoreUser() // userProfileList.ignoreUser()
// } // }
// } // }
ImageButton{
image:":/icons/icons/ui/black-bubble-speech.png"
Layout.margins: {
left: 5
right: 5
}
ToolTip.visible: hovered
ToolTip.text: qsTr("Start a private chat")
onClicked : {
userProfileList.startChat()
}
}
ImageButton{ ImageButton{
image:":/icons/icons/ui/round-remove-button.png" image:":/icons/icons/ui/round-remove-button.png"
Layout.margins: { Layout.margins: {
@ -121,19 +132,6 @@ ApplicationWindow{
userProfileList.kickUser() userProfileList.kickUser()
} }
} }
ImageButton{
image:":/icons/icons/ui/black-bubble-speech.png"
Layout.margins: {
left: 5
right: 5
}
ToolTip.visible: hovered
ToolTip.text: qsTr("Start a conversation")
onClicked : {
userProfileList.startChat()
}
}
} }
ScrollView { ScrollView {
@ -205,7 +203,7 @@ ApplicationWindow{
text:"OK" text:"OK"
onClicked: userProfileDialog.close() onClicked: userProfileDialog.close()
Layout.alignment: Qt.AlignRight Layout.alignment: Qt.AlignRight | Qt.AlignBottom
Layout.margins : { Layout.margins : {
right : 10 right : 10

View file

@ -22,12 +22,6 @@ ApplicationWindow {
implicitHeight: currentItem.implicitHeight implicitHeight: currentItem.implicitHeight
} }
onClosing: {
flow.cancelVerification();
deviceVerificationList.remove(flow.tranId);
delete flow;
}
property var flow property var flow
Connections { Connections {
target: flow target: flow
@ -123,33 +117,6 @@ ApplicationWindow {
color:colors.text color:colors.text
verticalAlignment: Text.AlignVCenter verticalAlignment: Text.AlignVCenter
} }
RowLayout {
RadioButton {
id: decimalRadio
Layout.alignment: Qt.AlignLeft
text: qsTr("Decimal")
contentItem: Text {
text: decimalRadio.text
color: colors.text
}
onClicked: { flow.method = DeviceVerificationFlow.Decimal }
}
Item {
Layout.fillWidth: true
}
RadioButton {
id: emojiRadio
Layout.alignment: Qt.AlignRight
text: qsTr("Emoji")
contentItem: Text {
text: emojiRadio.text
color: colors.text
}
onClicked: { flow.method = DeviceVerificationFlow.Emoji }
}
}
RowLayout { RowLayout {
Button { Button {
Layout.alignment: Qt.AlignLeft Layout.alignment: Qt.AlignLeft
@ -165,9 +132,8 @@ ApplicationWindow {
} }
onClicked: { onClicked: {
dialog.close(); dialog.close();
flow.cancelVerification(); flow.cancelVerification(DeviceVerificationFlow.User);
deviceVerificationList.remove(flow.tranId); deviceVerificationList.remove(flow.tranId);
delete flow;
} }
} }
Item { Item {
@ -227,9 +193,8 @@ ApplicationWindow {
} }
onClicked: { onClicked: {
dialog.close(); dialog.close();
flow.cancelVerification(); flow.cancelVerification(DeviceVerificationFlow.User);
deviceVerificationList.remove(flow.tranId); deviceVerificationList.remove(flow.tranId);
delete flow;
} }
} }
Item { Item {
@ -261,14 +226,17 @@ ApplicationWindow {
Label { Label {
font.pixelSize: Qt.application.font.pixelSize * 2 font.pixelSize: Qt.application.font.pixelSize * 2
text: flow.sasList[0] text: flow.sasList[0]
color:colors.text
} }
Label { Label {
font.pixelSize: Qt.application.font.pixelSize * 2 font.pixelSize: Qt.application.font.pixelSize * 2
text: flow.sasList[1] text: flow.sasList[1]
color:colors.text
} }
Label { Label {
font.pixelSize: Qt.application.font.pixelSize * 2 font.pixelSize: Qt.application.font.pixelSize * 2
text: flow.sasList[2] text: flow.sasList[2]
color:colors.text
} }
} }
@ -287,9 +255,8 @@ ApplicationWindow {
} }
onClicked: { onClicked: {
dialog.close(); dialog.close();
flow.cancelVerification(); flow.cancelVerification(DeviceVerificationFlow.MismatchedSAS);
deviceVerificationList.remove(flow.tranId); deviceVerificationList.remove(flow.tranId);
delete flow;
} }
} }
Item { Item {
@ -411,6 +378,7 @@ ApplicationWindow {
implicitWidth: col.width implicitWidth: col.width
ColumnLayout { ColumnLayout {
id: col id: col
Layout.fillWidth: true
anchors.bottom: parent.bottom anchors.bottom: parent.bottom
property var emoji: emojis.mapping[flow.sasList[index]] property var emoji: emojis.mapping[flow.sasList[index]]
Label { Label {
@ -424,6 +392,7 @@ ApplicationWindow {
Label { Label {
Layout.alignment: Qt.AlignHCenter | Qt.AlignBottom Layout.alignment: Qt.AlignHCenter | Qt.AlignBottom
text: col.emoji.description text: col.emoji.description
color:colors.text
} }
} }
} }
@ -445,9 +414,8 @@ ApplicationWindow {
} }
onClicked: { onClicked: {
dialog.close(); dialog.close();
flow.cancelVerification(); flow.cancelVerification(DeviceVerificationFlow.MismatchedSAS);
deviceVerificationList.remove(flow.tranId); deviceVerificationList.remove(flow.tranId);
delete flow;
} }
} }
Item { Item {
@ -507,7 +475,7 @@ ApplicationWindow {
} }
onClicked: { onClicked: {
dialog.close(); dialog.close();
flow.cancelVerification(); flow.cancelVerification(DeviceVerificationFlow.User);
deviceVerificationList.remove(flow.tranId); deviceVerificationList.remove(flow.tranId);
delete flow; delete flow;
} }

View file

@ -17,42 +17,53 @@ DeviceVerificationFlow::DeviceVerificationFlow(QObject *)
this->isMacVerified = false; this->isMacVerified = false;
connect(timeout, &QTimer::timeout, this, [this]() { connect(timeout, &QTimer::timeout, this, [this]() {
emit timedout(); emit timedout();
this->cancelVerification(DeviceVerificationFlow::Error::Timeout);
this->deleteLater(); this->deleteLater();
}); });
connect(ChatPage::instance(), connect(
&ChatPage::recievedDeviceVerificationStart, ChatPage::instance(),
this, &ChatPage::recievedDeviceVerificationStart,
[this](const mtx::events::collections::DeviceEvents &message) { this,
auto msg = [this](const mtx::events::collections::DeviceEvents &message) {
std::get<mtx::events::DeviceEvent<msgs::KeyVerificationStart>>(message); auto msg =
if (msg.content.transaction_id == this->transaction_id) { std::get<mtx::events::DeviceEvent<msgs::KeyVerificationStart>>(message);
if ((std::find(msg.content.key_agreement_protocols.begin(), if (msg.content.transaction_id == this->transaction_id) {
msg.content.key_agreement_protocols.end(), if ((std::find(msg.content.key_agreement_protocols.begin(),
"curve25519-hkdf-sha256") != msg.content.key_agreement_protocols.end(),
msg.content.key_agreement_protocols.end()) && "curve25519-hkdf-sha256") !=
(std::find(msg.content.hashes.begin(), msg.content.key_agreement_protocols.end()) &&
msg.content.hashes.end(), (std::find(msg.content.hashes.begin(),
"sha256") != msg.content.hashes.end()) && msg.content.hashes.end(),
(std::find(msg.content.message_authentication_codes.begin(), "sha256") != msg.content.hashes.end()) &&
msg.content.message_authentication_codes.end(), (std::find(msg.content.message_authentication_codes.begin(),
"hmac-sha256") != msg.content.message_authentication_codes.end(),
msg.content.message_authentication_codes.end()) && "hmac-sha256") !=
((std::find(msg.content.short_authentication_string.begin(), msg.content.message_authentication_codes.end())) {
if (std::find(msg.content.short_authentication_string.begin(),
msg.content.short_authentication_string.end(), msg.content.short_authentication_string.end(),
mtx::events::msg::SASMethods::Decimal) != mtx::events::msg::SASMethods::Decimal) !=
msg.content.short_authentication_string.end()) || msg.content.short_authentication_string.end()) {
(std::find(msg.content.short_authentication_string.begin(), this->method = DeviceVerificationFlow::Method::Emoji;
msg.content.short_authentication_string.end(), } else if (std::find(
mtx::events::msg::SASMethods::Emoji) != msg.content.short_authentication_string.begin(),
msg.content.short_authentication_string.end()))) { msg.content.short_authentication_string.end(),
this->acceptVerificationRequest(); mtx::events::msg::SASMethods::Emoji) !=
this->canonical_json = nlohmann::json(msg.content); msg.content.short_authentication_string.end()) {
} else { this->method = DeviceVerificationFlow::Method::Decimal;
this->cancelVerification(); } else {
} this->cancelVerification(
} DeviceVerificationFlow::Error::UnknownMethod);
}); return;
}
this->acceptVerificationRequest();
this->canonical_json = nlohmann::json(msg.content);
} else {
this->cancelVerification(
DeviceVerificationFlow::Error::UnknownMethod);
}
}
});
connect( connect(
ChatPage::instance(), ChatPage::instance(),
&ChatPage::recievedDeviceVerificationAccept, &ChatPage::recievedDeviceVerificationAccept,
@ -76,7 +87,8 @@ DeviceVerificationFlow::DeviceVerificationFlow(QObject *)
this->mac_method = msg.content.message_authentication_code; this->mac_method = msg.content.message_authentication_code;
this->sendVerificationKey(); this->sendVerificationKey();
} else { } else {
this->cancelVerification(); this->cancelVerification(
DeviceVerificationFlow::Error::UnknownMethod);
} }
} }
}); });
@ -130,7 +142,8 @@ DeviceVerificationFlow::DeviceVerificationFlow(QObject *)
msg.content.key + this->canonical_json.dump()))) { msg.content.key + this->canonical_json.dump()))) {
emit this->verificationRequestAccepted(this->method); emit this->verificationRequestAccepted(this->method);
} else { } else {
this->cancelVerification(); this->cancelVerification(
DeviceVerificationFlow::Error::MismatchedCommitment);
} }
} }
} }
@ -156,7 +169,8 @@ DeviceVerificationFlow::DeviceVerificationFlow(QObject *)
this->sas->calculate_mac(this->device_keys[mac.first], this->sas->calculate_mac(this->device_keys[mac.first],
info + mac.first)) { info + mac.first)) {
} else { } else {
this->cancelVerification(); this->cancelVerification(
DeviceVerificationFlow::Error::KeyMismatch);
return; return;
} }
} }
@ -172,7 +186,8 @@ DeviceVerificationFlow::DeviceVerificationFlow(QObject *)
else else
this->isMacVerified = true; this->isMacVerified = true;
} else { } else {
this->cancelVerification(); this->cancelVerification(
DeviceVerificationFlow::Error::KeyMismatch);
} }
} }
}); });
@ -429,15 +444,31 @@ DeviceVerificationFlow::sendVerificationRequest()
} }
//! cancels a verification flow //! cancels a verification flow
void void
DeviceVerificationFlow::cancelVerification() DeviceVerificationFlow::cancelVerification(DeviceVerificationFlow::Error error_code)
{ {
mtx::requests::ToDeviceMessages<mtx::events::msg::KeyVerificationCancel> body; mtx::requests::ToDeviceMessages<mtx::events::msg::KeyVerificationCancel> body;
mtx::events::msg::KeyVerificationCancel req; mtx::events::msg::KeyVerificationCancel req;
req.transaction_id = this->transaction_id; req.transaction_id = this->transaction_id;
// TODO: Add Proper Error Messages and Code if (error_code == DeviceVerificationFlow::Error::UnknownMethod) {
req.reason = "Device Verification Cancelled"; req.code = "m.unknown_method";
req.code = "400"; req.reason = "unknown method recieved";
} else if (error_code == DeviceVerificationFlow::Error::MismatchedCommitment) {
req.code = "m.mismatched_commitment";
req.reason = "commitment didn't match";
} else if (error_code == DeviceVerificationFlow::Error::MismatchedSAS) {
req.code = "m.mismatched_sas";
req.reason = "sas didn't match";
} else if (error_code == DeviceVerificationFlow::Error::KeyMismatch) {
req.code = "m.key_match";
req.reason = "keys did not match";
} else if (error_code == DeviceVerificationFlow::Error::Timeout) {
req.code = "m.timeout";
req.reason = "timed out";
} else if (error_code == DeviceVerificationFlow::Error::User) {
req.code = "m.user";
req.reason = "user cancelled the verification";
}
body[this->toClient][deviceId.toStdString()] = req; body[this->toClient][deviceId.toStdString()] = req;

View file

@ -28,6 +28,16 @@ public:
Emoji Emoji
}; };
Q_ENUM(Method) Q_ENUM(Method)
enum Error
{
UnknownMethod,
MismatchedCommitment,
MismatchedSAS,
KeyMismatch,
Timeout,
User
};
Q_ENUM(Error)
DeviceVerificationFlow(QObject *parent = nullptr); DeviceVerificationFlow(QObject *parent = nullptr);
QString getTransactionId(); QString getTransactionId();
@ -56,7 +66,7 @@ public slots:
//! starts the verification flow //! starts the verification flow
void startVerificationRequest(); void startVerificationRequest();
//! cancels a verification flow //! cancels a verification flow
void cancelVerification(); void cancelVerification(DeviceVerificationFlow::Error error_code);
//! sends the verification key //! sends the verification key
void sendVerificationKey(); void sendVerificationKey();
//! sends the mac of the keys //! sends the mac of the keys

View file

@ -184,6 +184,9 @@ TimelineViewManager::TimelineViewManager(QSharedPointer<UserSettings> userSettin
QString::fromStdString(msg.content.transaction_id), QString::fromStdString(msg.content.transaction_id),
QString::fromStdString(msg.sender), QString::fromStdString(msg.sender),
QString::fromStdString(msg.content.from_device)); QString::fromStdString(msg.content.from_device));
} else {
flow->cancelVerification(
DeviceVerificationFlow::Error::UnknownMethod);
} }
} }
}); });
@ -197,11 +200,43 @@ TimelineViewManager::TimelineViewManager(QSharedPointer<UserSettings> userSettin
auto flow = new DeviceVerificationFlow(this); auto flow = new DeviceVerificationFlow(this);
flow->canonical_json = nlohmann::json(msg.content); flow->canonical_json = nlohmann::json(msg.content);
if (!(this->dvList->exist(QString::fromStdString(msg.content.transaction_id)))) { if (!(this->dvList->exist(QString::fromStdString(msg.content.transaction_id)))) {
emit newDeviceVerificationRequest( if ((std::find(msg.content.key_agreement_protocols.begin(),
std::move(flow), msg.content.key_agreement_protocols.end(),
QString::fromStdString(msg.content.transaction_id), "curve25519-hkdf-sha256") !=
QString::fromStdString(msg.sender), msg.content.key_agreement_protocols.end()) &&
QString::fromStdString(msg.content.from_device)); (std::find(msg.content.hashes.begin(),
msg.content.hashes.end(),
"sha256") != msg.content.hashes.end()) &&
(std::find(msg.content.message_authentication_codes.begin(),
msg.content.message_authentication_codes.end(),
"hmac-sha256") !=
msg.content.message_authentication_codes.end())) {
if (std::find(msg.content.short_authentication_string.begin(),
msg.content.short_authentication_string.end(),
mtx::events::msg::SASMethods::Emoji) !=
msg.content.short_authentication_string.end()) {
flow->setMethod(DeviceVerificationFlow::Method::Emoji);
} else if (std::find(
msg.content.short_authentication_string.begin(),
msg.content.short_authentication_string.end(),
mtx::events::msg::SASMethods::Decimal) !=
msg.content.short_authentication_string.end()) {
flow->setMethod(DeviceVerificationFlow::Method::Decimal);
} else {
flow->cancelVerification(
DeviceVerificationFlow::Error::UnknownMethod);
return;
}
emit newDeviceVerificationRequest(
std::move(flow),
QString::fromStdString(msg.content.transaction_id),
QString::fromStdString(msg.sender),
QString::fromStdString(msg.content.from_device));
flow->canonical_json = nlohmann::json(msg.content);
} else {
flow->cancelVerification(
DeviceVerificationFlow::Error::UnknownMethod);
}
} }
}); });
} }