#pragma once #include "Olm.h" #include "mtx/responses/crypto.hpp" #include #include class QTimer; using sas_ptr = std::unique_ptr; class DeviceVerificationFlow : public QObject { Q_OBJECT // Q_CLASSINFO("RegisterEnumClassesUnscoped", "false") Q_PROPERTY(QString tranId READ getTransactionId WRITE setTransactionId) Q_PROPERTY(bool sender READ getSender WRITE setSender) Q_PROPERTY(QString userId READ getUserId WRITE setUserId) Q_PROPERTY(QString deviceId READ getDeviceId WRITE setDeviceId) Q_PROPERTY(Method method READ getMethod WRITE setMethod) Q_PROPERTY(std::vector sasList READ getSasList) public: enum Method { Decimal, Emoji }; Q_ENUM(Method) enum Error { UnknownMethod, MismatchedCommitment, MismatchedSAS, KeyMismatch, Timeout, User }; Q_ENUM(Error) DeviceVerificationFlow(QObject *parent = nullptr); QString getTransactionId(); QString getUserId(); QString getDeviceId(); Method getMethod(); std::vector getSasList(); void setTransactionId(QString transaction_id_); bool getSender(); void setUserId(QString userID); void setDeviceId(QString deviceID); void setMethod(Method method_); void setSender(bool sender_); void callback_fn(const mtx::responses::QueryKeys &res, mtx::http::RequestErr err, std::string user_id); nlohmann::json canonical_json; public slots: //! sends a verification request void sendVerificationRequest(); //! accepts a verification request void sendVerificationReady(); //! completes the verification flow(); void sendVerificationDone(); //! accepts a verification void acceptVerificationRequest(); //! starts the verification flow void startVerificationRequest(); //! cancels a verification flow void cancelVerification(DeviceVerificationFlow::Error error_code); //! sends the verification key void sendVerificationKey(); //! sends the mac of the keys void sendVerificationMac(); //! Completes the verification flow void acceptDevice(); //! unverifies a device void unverify(); signals: void verificationRequestAccepted(Method method); void deviceVerified(); void timedout(); void verificationCanceled(); void refreshProfile(); private: QString userId; QString deviceId; Method method; bool sender; QTimer *timeout = nullptr; sas_ptr sas; bool isMacVerified = false; std::string mac_method; std::string transaction_id; std::string commitment; mtx::identifiers::User toClient; std::vector sasList; std::map device_keys; };