summaryrefslogtreecommitdiffstats
path: root/libraries/ganalytics/src/ganalytics_worker.h
blob: 1962f7998883a431440bd911c63201406a28acf9 (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
65
#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;
    int m_version = 0;

    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();
};