feat: prettify model event handling logic
This commit is contained in:
parent
b70d73ce96
commit
664d3cff16
@ -94,6 +94,23 @@
|
|||||||
return ret; \
|
return ret; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define DEFINE_EXECUTE_API_USING_STANDARD_EVEN_HANDLE_MODEL \
|
||||||
|
EXECUTE_MODULE() { \
|
||||||
|
auto event_id = event["event_id"]; \
|
||||||
|
auto it = _gr_module_event_handlers.find(event_id); \
|
||||||
|
if (it != _gr_module_event_handlers.end()) { \
|
||||||
|
return it.value()(event); \
|
||||||
|
} \
|
||||||
|
CB_ERR(event, -1, QString("unsupported event id: %1").arg(event_id)); \
|
||||||
|
} \
|
||||||
|
END_EXECUTE_MODULE()
|
||||||
|
|
||||||
|
#define REGISTER_EVENT_HANDLER(event_id, handler) \
|
||||||
|
static const bool _gv_register_event_handler_by_id_##event_id = [] { \
|
||||||
|
_gr_module_event_handlers[#event_id] = handler; \
|
||||||
|
return true; \
|
||||||
|
}();
|
||||||
|
|
||||||
inline void MLogDebug(const QString& s) { GFModuleLogDebug(s.toUtf8()); }
|
inline void MLogDebug(const QString& s) { GFModuleLogDebug(s.toUtf8()); }
|
||||||
inline void MLogInfo(const QString& s) { GFModuleLogInfo(s.toUtf8()); }
|
inline void MLogInfo(const QString& s) { GFModuleLogInfo(s.toUtf8()); }
|
||||||
inline void MLogWarn(const QString& s) { GFModuleLogWarn(s.toUtf8()); }
|
inline void MLogWarn(const QString& s) { GFModuleLogWarn(s.toUtf8()); }
|
||||||
@ -121,11 +138,22 @@ inline auto UnStrDup(const char* s) -> QString {
|
|||||||
return q_s;
|
return q_s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline auto FormatStringHelper(const QString& format,
|
||||||
|
const std::string& arg) -> QString {
|
||||||
|
return format.arg(QString::fromStdString(arg));
|
||||||
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
auto FormatStringHelper(const QString& format, T arg) -> QString {
|
auto FormatStringHelper(const QString& format, T arg) -> QString {
|
||||||
return format.arg(arg);
|
return format.arg(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename... Args>
|
||||||
|
auto FormatStringHelper(const QString& format, const std::string& arg,
|
||||||
|
Args... args) -> QString {
|
||||||
|
return FormatStringHelper(format.arg(QString::fromStdString(arg)), args...);
|
||||||
|
}
|
||||||
|
|
||||||
template <typename T, typename... Args>
|
template <typename T, typename... Args>
|
||||||
auto FormatStringHelper(const QString& format, T arg, Args... args) -> QString {
|
auto FormatStringHelper(const QString& format, T arg, Args... args) -> QString {
|
||||||
return FormatStringHelper(format.arg(arg), args...);
|
return FormatStringHelper(format.arg(arg), args...);
|
||||||
@ -135,6 +163,13 @@ inline auto FormatStringHelper(const QString& format) -> QString {
|
|||||||
return format;
|
return format;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline auto FormatStringHelper(const T& format) ->
|
||||||
|
typename std::enable_if<std::is_same<T, std::string>::value,
|
||||||
|
QString>::type {
|
||||||
|
return FormatStringHelper(QString::fromStdString(format));
|
||||||
|
}
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
auto FormatString(const QString& format, Args... args) -> QString {
|
auto FormatString(const QString& format, Args... args) -> QString {
|
||||||
return FormatStringHelper(format, args...);
|
return FormatStringHelper(format, args...);
|
||||||
|
@ -44,3 +44,23 @@
|
|||||||
return QMapToGFModuleMetaDataList( \
|
return QMapToGFModuleMetaDataList( \
|
||||||
{{"Name", (name)}, {"Description", (desc)}, {"Author", (author)}}); \
|
{{"Name", (name)}, {"Description", (desc)}, {"Author", (author)}}); \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define GF_MODULE_API_DEFINE_V2(id, name, ver, desc, author) \
|
||||||
|
auto GFGetModuleGFSDKVersion() -> const char* { \
|
||||||
|
return DUP(GF_SDK_VERSION_STR); \
|
||||||
|
} \
|
||||||
|
auto GFGetModuleQtEnvVersion() -> const char* { \
|
||||||
|
return DUP(QT_VERSION_STR); \
|
||||||
|
} \
|
||||||
|
auto GFGetModuleID() -> const char* { return DUP((id)); } \
|
||||||
|
auto GFGetModuleVersion() -> const char* { return DUP((ver)); } \
|
||||||
|
auto GFGetModuleMetaData() -> GFModuleMetaData* { \
|
||||||
|
return QMapToGFModuleMetaDataList( \
|
||||||
|
{{"Name", (name)}, {"Description", (desc)}, {"Author", (author)}}); \
|
||||||
|
} \
|
||||||
|
using MEvent = QMap<QString, QString>; \
|
||||||
|
using EventHandler = std::function<int(const MEvent&)>; \
|
||||||
|
static QMap<QString, EventHandler> Module##nameEventHandlers; \
|
||||||
|
static QMap<QString, EventHandler>& _gr_module_event_handlers = \
|
||||||
|
Module##nameEventHandlers; \
|
||||||
|
DEFINE_EXECUTE_API_USING_STANDARD_EVEN_HANDLE_MODEL
|
@ -30,13 +30,13 @@
|
|||||||
|
|
||||||
#include <QtCore>
|
#include <QtCore>
|
||||||
|
|
||||||
#include "GFModuleCommonUtils.hpp"
|
|
||||||
#include "GFModuleDefine.h"
|
#include "GFModuleDefine.h"
|
||||||
#include "VKSInterface.h"
|
#include "VKSInterface.h"
|
||||||
|
|
||||||
GF_MODULE_API_DEFINE("com.bktus.gpgfrontend.module.key_server_sync",
|
GF_MODULE_API_DEFINE_V2("com.bktus.gpgfrontend.module.key_server_sync",
|
||||||
"KeyServerSync", "1.0.0",
|
"KeyServerSync", "1.0.0",
|
||||||
"Sync Information From Trusted Key Server.", "Saturneric")
|
"Sync Information From Trusted Key Server.",
|
||||||
|
"Saturneric")
|
||||||
|
|
||||||
auto GFRegisterModule() -> int {
|
auto GFRegisterModule() -> int {
|
||||||
LOG_DEBUG("key server sync module registering");
|
LOG_DEBUG("key server sync module registering");
|
||||||
@ -51,122 +51,117 @@ auto GFActiveModule() -> int {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
EXECUTE_MODULE() {
|
REGISTER_EVENT_HANDLER(
|
||||||
FLOG_DEBUG("key server sync module executing, event id: %1",
|
REQUEST_GET_PUBLIC_KEY_BY_FINGERPRINT, [](const MEvent& event) -> int {
|
||||||
event["event_id"]);
|
if (event["fingerprint"].isEmpty())
|
||||||
|
CB_ERR(event, -1, "fingerprint is empty");
|
||||||
|
|
||||||
if (event["event_id"] == "REQUEST_GET_PUBLIC_KEY_BY_FINGERPRINT") {
|
QByteArray fingerprint = event["fingerprint"].toLatin1();
|
||||||
if (event["fingerprint"].isEmpty())
|
FLOG_DEBUG("try to get key info of fingerprint: %1", fingerprint);
|
||||||
CB_ERR(event, -1, "fingerprint is empty");
|
|
||||||
|
|
||||||
QByteArray fingerprint = event["fingerprint"].toLatin1();
|
auto* vks = new VKSInterface();
|
||||||
FLOG_DEBUG("try to get key info of fingerprint: %1", fingerprint);
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved,
|
||||||
|
QThread::currentThread(), [event](const QString& key) {
|
||||||
|
// callback
|
||||||
|
CB(event, GFGetModuleID(),
|
||||||
|
{
|
||||||
|
{"ret", QString::number(0)},
|
||||||
|
{"key_data", key},
|
||||||
|
});
|
||||||
|
});
|
||||||
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
|
&VKSInterface::deleteLater);
|
||||||
|
|
||||||
auto* vks = new VKSInterface();
|
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved,
|
QThread::currentThread(),
|
||||||
QThread::currentThread(), [event](const QString& key) {
|
[event](const QString& error, const QString& data) {
|
||||||
// callback
|
CB(event, GFGetModuleID(),
|
||||||
CB(event, GFGetModuleID(),
|
{
|
||||||
{
|
{"ret", QString::number(-1)},
|
||||||
{"ret", QString::number(0)},
|
{"error_msg", error},
|
||||||
{"key_data", key},
|
{"reply_data", data},
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
&VKSInterface::deleteLater);
|
&VKSInterface::deleteLater);
|
||||||
|
vks->GetByFingerprint(fingerprint);
|
||||||
|
return 0;
|
||||||
|
});
|
||||||
|
|
||||||
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
REGISTER_EVENT_HANDLER(
|
||||||
QThread::currentThread(),
|
REQUEST_GET_PUBLIC_KEY_BY_KEY_ID, [](const MEvent& event) -> int {
|
||||||
[event](const QString& error, const QString& data) {
|
if (event["key_id"].isEmpty()) CB_ERR(event, -1, "key_id is empty");
|
||||||
CB(event, GFGetModuleID(),
|
|
||||||
{
|
|
||||||
{"ret", QString::number(-1)},
|
|
||||||
{"error_msg", error},
|
|
||||||
{"reply_data", data},
|
|
||||||
});
|
|
||||||
});
|
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
|
||||||
&VKSInterface::deleteLater);
|
|
||||||
vks->GetByFingerprint(fingerprint);
|
|
||||||
|
|
||||||
return 0;
|
QByteArray key_id = event["key_id"].toLatin1();
|
||||||
}
|
FLOG_DEBUG("try to get key info of key id: %1", key_id);
|
||||||
|
|
||||||
if (event["event_id"] == "REQUEST_GET_PUBLIC_KEY_BY_KEY_ID") {
|
auto* vks = new VKSInterface();
|
||||||
if (event["key_id"].isEmpty()) CB_ERR(event, -1, "key_id is empty");
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved,
|
||||||
|
QThread::currentThread(), [event](const QString& key) {
|
||||||
|
// callback
|
||||||
|
CB(event, GFGetModuleID(),
|
||||||
|
{
|
||||||
|
{"ret", QString::number(0)},
|
||||||
|
{"key_data", key},
|
||||||
|
});
|
||||||
|
});
|
||||||
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
|
&VKSInterface::deleteLater);
|
||||||
|
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
||||||
|
QThread::currentThread(),
|
||||||
|
[event](const QString& error, const QString& data) {
|
||||||
|
CB(event, GFGetModuleID(),
|
||||||
|
{
|
||||||
|
{"ret", QString::number(-1)},
|
||||||
|
{"error_msg", error},
|
||||||
|
{"reply_data", data},
|
||||||
|
});
|
||||||
|
});
|
||||||
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
|
&VKSInterface::deleteLater);
|
||||||
|
vks->GetByKeyId(key_id);
|
||||||
|
|
||||||
QByteArray key_id = event["key_id"].toLatin1();
|
return 0;
|
||||||
FLOG_DEBUG("try to get key info of key id: %1", key_id);
|
});
|
||||||
|
|
||||||
auto* vks = new VKSInterface();
|
REGISTER_EVENT_HANDLER(
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved,
|
REQUEST_UPLOAD_PUBLIC_KEY, [](const MEvent& event) -> int {
|
||||||
QThread::currentThread(), [event](const QString& key) {
|
if (event["key_text"].isEmpty()) CB_ERR(event, -1, "key_text is empty");
|
||||||
// callback
|
|
||||||
CB(event, GFGetModuleID(),
|
|
||||||
{
|
|
||||||
{"ret", QString::number(0)},
|
|
||||||
{"key_data", key},
|
|
||||||
});
|
|
||||||
});
|
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
|
||||||
&VKSInterface::deleteLater);
|
|
||||||
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
|
||||||
QThread::currentThread(),
|
|
||||||
[event](const QString& error, const QString& data) {
|
|
||||||
CB(event, GFGetModuleID(),
|
|
||||||
{
|
|
||||||
{"ret", QString::number(-1)},
|
|
||||||
{"error_msg", error},
|
|
||||||
{"reply_data", data},
|
|
||||||
});
|
|
||||||
});
|
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
|
||||||
&VKSInterface::deleteLater);
|
|
||||||
vks->GetByKeyId(key_id);
|
|
||||||
|
|
||||||
return 0;
|
QByteArray key_text = event["key_text"].toLatin1();
|
||||||
}
|
FLOG_DEBUG("try to get key info of key id: %1", key_text);
|
||||||
|
|
||||||
if (event["event_id"] == "REQUEST_UPLOAD_PUBLIC_KEY") {
|
auto* vks = new VKSInterface();
|
||||||
if (event["key_text"].isEmpty()) CB_ERR(event, -1, "key_text is empty");
|
QObject::connect(
|
||||||
|
vks, &VKSInterface::SignalKeyUploaded, QThread::currentThread(),
|
||||||
QByteArray key_text = event["key_text"].toLatin1();
|
[event](const QString& fpr, const QJsonObject& status,
|
||||||
FLOG_DEBUG("try to get key info of key id: %1", key_text);
|
const QString& token) {
|
||||||
|
CB(event, GFGetModuleID(),
|
||||||
auto* vks = new VKSInterface();
|
{
|
||||||
QObject::connect(
|
{"ret", QString::number(0)},
|
||||||
vks, &VKSInterface::SignalKeyUploaded, QThread::currentThread(),
|
{"fingerprint", fpr},
|
||||||
[event](const QString& fpr, const QJsonObject& status,
|
{"status",
|
||||||
const QString& token) {
|
QString::fromUtf8(QJsonDocument(status).toJson())},
|
||||||
CB(event, GFGetModuleID(),
|
{"token", token},
|
||||||
{
|
});
|
||||||
{"ret", QString::number(0)},
|
});
|
||||||
{"fingerprint", fpr},
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
{"status", QString::fromUtf8(QJsonDocument(status).toJson())},
|
&VKSInterface::deleteLater);
|
||||||
{"token", token},
|
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
||||||
});
|
QThread::currentThread(),
|
||||||
});
|
[event](const QString& error, const QString& data) {
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
CB(event, GFGetModuleID(),
|
||||||
&VKSInterface::deleteLater);
|
{
|
||||||
QObject::connect(vks, &VKSInterface::SignalErrorOccurred,
|
{"ret", QString::number(-1)},
|
||||||
QThread::currentThread(),
|
{"error_msg", error},
|
||||||
[event](const QString& error, const QString& data) {
|
{"reply_data", data},
|
||||||
CB(event, GFGetModuleID(),
|
});
|
||||||
{
|
});
|
||||||
{"ret", QString::number(-1)},
|
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
||||||
{"error_msg", error},
|
&VKSInterface::deleteLater);
|
||||||
{"reply_data", data},
|
vks->UploadKey(key_text);
|
||||||
});
|
return 0;
|
||||||
});
|
});
|
||||||
QObject::connect(vks, &VKSInterface::SignalKeyRetrieved, vks,
|
|
||||||
&VKSInterface::deleteLater);
|
|
||||||
vks->UploadKey(key_text);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
CB_ERR(event, -1, "the type of this event is not supported");
|
|
||||||
}
|
|
||||||
END_EXECUTE_MODULE()
|
|
||||||
|
|
||||||
auto GFDeactivateModule() -> int { return 0; }
|
auto GFDeactivateModule() -> int { return 0; }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user