From b6d455a02bd338e9dc0faa09d4d8177ecd8d569a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petr=20Mr=C3=A1zek?= Date: Sun, 10 Apr 2016 15:53:05 +0200 Subject: NOISSUE reorganize and document libraries --- api/logic/notifications/NotificationChecker.h | 63 +++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 api/logic/notifications/NotificationChecker.h (limited to 'api/logic/notifications/NotificationChecker.h') diff --git a/api/logic/notifications/NotificationChecker.h b/api/logic/notifications/NotificationChecker.h new file mode 100644 index 00000000..a2d92ab9 --- /dev/null +++ b/api/logic/notifications/NotificationChecker.h @@ -0,0 +1,63 @@ +#pragma once + +#include + +#include "net/NetJob.h" +#include "net/CacheDownload.h" + +#include "multimc_logic_export.h" + +class MULTIMC_LOGIC_EXPORT NotificationChecker : public QObject +{ + Q_OBJECT + +public: + explicit NotificationChecker(QObject *parent = 0); + + void setNotificationsUrl(const QUrl ¬ificationsUrl); + void setApplicationPlatform(QString platform); + void setApplicationChannel(QString channel); + void setApplicationFullVersion(QString version); + + struct NotificationEntry + { + int id; + QString message; + enum + { + Critical, + Warning, + Information + } type; + QString channel; + QString platform; + QString from; + QString to; + }; + + QList notificationEntries() const; + +public +slots: + void checkForNotifications(); + +private +slots: + void downloadSucceeded(int); + +signals: + void notificationCheckFinished(); + +private: + bool entryApplies(const NotificationEntry &entry) const; + +private: + QList m_entries; + QUrl m_notificationsUrl; + NetJobPtr m_checkJob; + CacheDownloadPtr m_download; + + QString m_appVersionChannel; + QString m_appPlatform; + QString m_appFullVersion; +}; -- cgit v1.2.3