summaryrefslogtreecommitdiffstats
path: root/libraries/ganalytics/src/ganalytics_worker.h
blob: 3504a0328db2d2fc77e34ac12d80c592940b0256 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#pragma once

#include <QUrlQuery>
#include <QDateTime>
#include <QTimer>
#include <QNetworkRequest>
#include <QQueue>

struct QueryBuffer
{
	QUrlQuery postQuery;
	QDateTime time;
};

class GAnalyticsWorker : public QObject
{
	Q_OBJECT

public:
	explicit GAnalyticsWorker(GAnalytics *parent = 0);

	GAnalytics *q;

	QNetworkAccessManager *networkManager = nullptr;

	QQueue<QueryBuffer> m_messageQueue;
	QTimer m_timer;
	QNetworkRequest m_request;
	GAnalytics::LogLevel m_logLevel;

	QString m_trackingID;
	QString m_clientID;
	QString m_userID;
	QString m_appName;
	QString m_appVersion;
	QString m_language;
	QString m_screenResolution;
	QString m_viewportSize;

	bool m_anonymizeIPs = false;
	bool m_isEnabled = false;
	int m_timerInterval = 30000;

	const static int fourHours = 4 * 60 * 60 * 1000;
	const static QLatin1String dateTimeFormat;

public:
	void logMessage(GAnalytics::LogLevel level, const QString &message);

	QUrlQuery buildStandardPostQuery(const QString &type);
	QString getScreenResolution();
	QString getUserAgent();
	QList<QString> persistMessageQueue();
	void readMessagesFromFile(const QList<QString> &dataList);

	void enqueQueryWithCurrentTime(const QUrlQuery &query);
	void setIsSending(bool doSend);
	void enable(bool state);

public slots:
	void postMessage();
	void postMessageFinished();
};