2020-03-13 21:05:18 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
|
|
|
|
class QTimer;
|
|
|
|
|
|
|
|
class DeviceVerificationFlow : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
// Q_CLASSINFO("RegisterEnumClassesUnscoped", "false")
|
|
|
|
|
|
|
|
public:
|
|
|
|
enum Method
|
|
|
|
{
|
|
|
|
Decimal,
|
|
|
|
Emoji
|
|
|
|
};
|
|
|
|
Q_ENUM(Method)
|
|
|
|
|
|
|
|
DeviceVerificationFlow(QObject *parent = nullptr);
|
|
|
|
|
|
|
|
public slots:
|
2020-06-04 15:44:15 +02:00
|
|
|
//! sends a verification request
|
|
|
|
void sendVerificationRequest();
|
|
|
|
//! accepts a verification
|
2020-03-13 21:05:18 +01:00
|
|
|
void acceptVerificationRequest();
|
2020-06-04 15:44:15 +02:00
|
|
|
//! starts the verification flow
|
|
|
|
void startVerificationRequest();
|
2020-03-13 21:05:18 +01:00
|
|
|
//! cancels a verification flow
|
|
|
|
void cancelVerification();
|
|
|
|
//! Completes the verification flow
|
|
|
|
void acceptDevice();
|
|
|
|
|
|
|
|
signals:
|
|
|
|
void verificationRequestAccepted(Method method);
|
|
|
|
void deviceVerified();
|
|
|
|
void timedout();
|
|
|
|
void verificationCanceled();
|
|
|
|
|
|
|
|
private:
|
2020-06-04 15:44:15 +02:00
|
|
|
//! generates a unique transaction id
|
|
|
|
std::string generate_txn_id();
|
|
|
|
|
2020-03-13 21:05:18 +01:00
|
|
|
QTimer *timeout = nullptr;
|
2020-06-04 15:44:15 +02:00
|
|
|
std::string transaction_id;
|
2020-03-13 21:05:18 +01:00
|
|
|
};
|