PrismLauncher/libraries/ganalytics/src/ganalytics_worker.h

66 lines
1.4 KiB
C
Raw Normal View History

#pragma once
#include <QUrlQuery>
#include <QDateTime>
#include <QTimer>
#include <QNetworkRequest>
#include <QQueue>
struct QueryBuffer
{
2018-07-15 14:51:05 +02:00
QUrlQuery postQuery;
QDateTime time;
};
class GAnalyticsWorker : public QObject
{
2018-07-15 14:51:05 +02:00
Q_OBJECT
public:
2018-07-15 14:51:05 +02:00
explicit GAnalyticsWorker(GAnalytics *parent = 0);
2018-07-15 14:51:05 +02:00
GAnalytics *q;
2018-07-15 14:51:05 +02:00
QNetworkAccessManager *networkManager = nullptr;
2018-07-15 14:51:05 +02:00
QQueue<QueryBuffer> m_messageQueue;
QTimer m_timer;
QNetworkRequest m_request;
GAnalytics::LogLevel m_logLevel;
2018-07-15 14:51:05 +02:00
QString m_trackingID;
QString m_clientID;
QString m_userID;
QString m_appName;
QString m_appVersion;
QString m_language;
QString m_screenResolution;
QString m_viewportSize;
2018-07-15 14:51:05 +02:00
bool m_anonymizeIPs = false;
bool m_isEnabled = false;
int m_timerInterval = 30000;
int m_version = 0;
2018-07-15 14:51:05 +02:00
const static int fourHours = 4 * 60 * 60 * 1000;
const static QLatin1String dateTimeFormat;
public:
2018-07-15 14:51:05 +02:00
void logMessage(GAnalytics::LogLevel level, const QString &message);
2018-07-15 14:51:05 +02:00
QUrlQuery buildStandardPostQuery(const QString &type);
QString getScreenResolution();
QString getUserAgent();
QList<QString> persistMessageQueue();
void readMessagesFromFile(const QList<QString> &dataList);
2018-07-15 14:51:05 +02:00
void enqueQueryWithCurrentTime(const QUrlQuery &query);
void setIsSending(bool doSend);
void enable(bool state);
public slots:
2018-07-15 14:51:05 +02:00
void postMessage();
void postMessageFinished();
};