2016-11-20 12:32:27 +01:00
|
|
|
#include "ganalytics.h"
|
|
|
|
#include "ganalytics_worker.h"
|
|
|
|
#include "sys.h"
|
|
|
|
|
|
|
|
#include <QDataStream>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QLocale>
|
|
|
|
#include <QNetworkAccessManager>
|
|
|
|
#include <QNetworkReply>
|
|
|
|
#include <QNetworkRequest>
|
|
|
|
#include <QQueue>
|
|
|
|
#include <QSettings>
|
|
|
|
#include <QTimer>
|
|
|
|
#include <QUrlQuery>
|
|
|
|
#include <QUuid>
|
|
|
|
|
2016-12-05 02:29:08 +01:00
|
|
|
GAnalytics::GAnalytics(const QString &trackingID, const QString &clientID, const int version, QObject *parent) : QObject(parent)
|
2016-11-20 12:32:27 +01:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d = new GAnalyticsWorker(this);
|
|
|
|
d->m_trackingID = trackingID;
|
|
|
|
d->m_clientID = clientID;
|
|
|
|
d->m_version = version;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor of class GAnalytics.
|
|
|
|
*/
|
|
|
|
GAnalytics::~GAnalytics()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
delete d;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void GAnalytics::setLogLevel(GAnalytics::LogLevel logLevel)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->m_logLevel = logLevel;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
GAnalytics::LogLevel GAnalytics::logLevel() const
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_logLevel;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// SETTER and GETTER
|
|
|
|
void GAnalytics::setViewportSize(const QString &viewportSize)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->m_viewportSize = viewportSize;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QString GAnalytics::viewportSize() const
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_viewportSize;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void GAnalytics::setLanguage(const QString &language)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->m_language = language;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QString GAnalytics::language() const
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_language;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
2016-11-21 21:18:30 +01:00
|
|
|
void GAnalytics::setAnonymizeIPs(bool anonymize)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->m_anonymizeIPs = anonymize;
|
2016-11-21 21:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool GAnalytics::anonymizeIPs()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_anonymizeIPs;
|
2016-11-21 21:18:30 +01:00
|
|
|
}
|
|
|
|
|
2016-11-20 12:32:27 +01:00
|
|
|
void GAnalytics::setSendInterval(int milliseconds)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->m_timer.setInterval(milliseconds);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int GAnalytics::sendInterval() const
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return (d->m_timer.interval());
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
2016-11-24 04:10:07 +01:00
|
|
|
bool GAnalytics::isEnabled()
|
2016-11-20 12:32:27 +01:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_isEnabled;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
2016-11-24 04:10:07 +01:00
|
|
|
void GAnalytics::enable(bool state)
|
2016-11-20 12:32:27 +01:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->enable(state);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
2016-12-05 02:29:08 +01:00
|
|
|
int GAnalytics::version()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->m_version;
|
2016-12-05 02:29:08 +01:00
|
|
|
}
|
|
|
|
|
2016-11-20 12:32:27 +01:00
|
|
|
void GAnalytics::setNetworkAccessManager(QNetworkAccessManager *networkAccessManager)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
if (d->networkManager != networkAccessManager)
|
|
|
|
{
|
|
|
|
// Delete the old network manager if it was our child
|
|
|
|
if (d->networkManager && d->networkManager->parent() == this)
|
|
|
|
{
|
|
|
|
d->networkManager->deleteLater();
|
|
|
|
}
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
d->networkManager = networkAccessManager;
|
|
|
|
}
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QNetworkAccessManager *GAnalytics::networkAccessManager() const
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
return d->networkManager;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void appendCustomValues(QUrlQuery &query, const QVariantMap &customValues)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
for (QVariantMap::const_iterator iter = customValues.begin(); iter != customValues.end(); ++iter)
|
|
|
|
{
|
|
|
|
query.addQueryItem(iter.key(), iter.value().toString());
|
|
|
|
}
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sent screen view is called when the user changed the applications view.
|
|
|
|
* These action of the user should be noticed and reported. Therefore
|
|
|
|
* a QUrlQuery is build in this method. It holts all the parameter for
|
|
|
|
* a http POST. The UrlQuery will be stored in a message Queue.
|
|
|
|
*/
|
|
|
|
void GAnalytics::sendScreenView(const QString &screenName, const QVariantMap &customValues)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
d->logMessage(Info, QString("ScreenView: %1").arg(screenName));
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
QUrlQuery query = d->buildStandardPostQuery("screenview");
|
|
|
|
query.addQueryItem("cd", screenName);
|
|
|
|
query.addQueryItem("an", d->m_appName);
|
|
|
|
query.addQueryItem("av", d->m_appVersion);
|
|
|
|
appendCustomValues(query, customValues);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
d->enqueQueryWithCurrentTime(query);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is called whenever a button was pressed in the application.
|
|
|
|
* A query for a POST message will be created to report this event. The
|
|
|
|
* created query will be stored in a message queue.
|
|
|
|
*/
|
|
|
|
void GAnalytics::sendEvent(const QString &category, const QString &action, const QString &label, const QVariant &value, const QVariantMap &customValues)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QUrlQuery query = d->buildStandardPostQuery("event");
|
|
|
|
query.addQueryItem("an", d->m_appName);
|
|
|
|
query.addQueryItem("av", d->m_appVersion);
|
|
|
|
query.addQueryItem("ec", category);
|
|
|
|
query.addQueryItem("ea", action);
|
|
|
|
if (!label.isEmpty())
|
|
|
|
query.addQueryItem("el", label);
|
|
|
|
if (value.isValid())
|
|
|
|
query.addQueryItem("ev", value.toString());
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
appendCustomValues(query, customValues);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
d->enqueQueryWithCurrentTime(query);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Method is called after an exception was raised. It builds a
|
|
|
|
* query for a POST message. These query will be stored in a
|
|
|
|
* message queue.
|
|
|
|
*/
|
|
|
|
void GAnalytics::sendException(const QString &exceptionDescription, bool exceptionFatal, const QVariantMap &customValues)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QUrlQuery query = d->buildStandardPostQuery("exception");
|
|
|
|
query.addQueryItem("an", d->m_appName);
|
|
|
|
query.addQueryItem("av", d->m_appVersion);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
query.addQueryItem("exd", exceptionDescription);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
if (exceptionFatal)
|
|
|
|
{
|
|
|
|
query.addQueryItem("exf", "1");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
query.addQueryItem("exf", "0");
|
|
|
|
}
|
|
|
|
appendCustomValues(query, customValues);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
d->enqueQueryWithCurrentTime(query);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Session starts. This event will be sent by a POST message.
|
|
|
|
* Query is setup in this method and stored in the message
|
|
|
|
* queue.
|
|
|
|
*/
|
|
|
|
void GAnalytics::startSession()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QVariantMap customValues;
|
|
|
|
customValues.insert("sc", "start");
|
|
|
|
sendEvent("Session", "Start", QString(), QVariant(), customValues);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Session ends. This event will be sent by a POST message.
|
|
|
|
* Query is setup in this method and stored in the message
|
|
|
|
* queue.
|
|
|
|
*/
|
|
|
|
void GAnalytics::endSession()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QVariantMap customValues;
|
|
|
|
customValues.insert("sc", "end");
|
|
|
|
sendEvent("Session", "End", QString(), QVariant(), customValues);
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Qut stream to persist class GAnalytics.
|
|
|
|
*/
|
|
|
|
QDataStream &operator<<(QDataStream &outStream, const GAnalytics &analytics)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
outStream << analytics.d->persistMessageQueue();
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
return outStream;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* In stream to read GAnalytics from file.
|
|
|
|
*/
|
|
|
|
QDataStream &operator>>(QDataStream &inStream, GAnalytics &analytics)
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QList<QString> dataList;
|
|
|
|
inStream >> dataList;
|
|
|
|
analytics.d->readMessagesFromFile(dataList);
|
2016-11-20 12:32:27 +01:00
|
|
|
|
2018-07-15 14:51:05 +02:00
|
|
|
return inStream;
|
2016-11-20 12:32:27 +01:00
|
|
|
}
|