Fix collecting user statistic.
Fix calculation of screen resolution for primary screen in case of HighDPI screen. Collect new metrics: screens number, screen pixel ratio, country code (based on IP), platform type, total memory.
This commit is contained in:
parent
5f60af68ca
commit
1194c43e55
|
@ -26,6 +26,7 @@
|
||||||
**
|
**
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
#include "vganalytics.h"
|
#include "vganalytics.h"
|
||||||
|
#include "../vmisc/defglobal.h"
|
||||||
#include "vganalyticsworker.h"
|
#include "vganalyticsworker.h"
|
||||||
|
|
||||||
#include <QDataStream>
|
#include <QDataStream>
|
||||||
|
@ -47,6 +48,88 @@
|
||||||
#include <QUrlQuery>
|
#include <QUrlQuery>
|
||||||
#include <QUuid>
|
#include <QUuid>
|
||||||
|
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
#include <windows.h>
|
||||||
|
#elif defined(Q_OS_MACOS)
|
||||||
|
#include <mach/mach.h>
|
||||||
|
#include <mach/mach_host.h>
|
||||||
|
#elif defined(Q_OS_LINUX)
|
||||||
|
#include <sys/sysinfo.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (defined(Q_CC_GNU) && Q_CC_GNU < 409) && !defined(Q_CC_CLANG)
|
||||||
|
// DO NOT WORK WITH GCC 4.8
|
||||||
|
#else
|
||||||
|
#if __cplusplus >= 201402L
|
||||||
|
using namespace std::chrono_literals;
|
||||||
|
#else
|
||||||
|
#include "../vmisc/bpstd/chrono.hpp"
|
||||||
|
using namespace bpstd::literals::chrono_literals;
|
||||||
|
#endif // __cplusplus >= 201402L
|
||||||
|
#endif //(defined(Q_CC_GNU) && Q_CC_GNU < 409) && !defined(Q_CC_CLANG)
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
auto GetSystemMemorySize() -> qint64
|
||||||
|
{
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
MEMORYSTATUSEX memory_status;
|
||||||
|
ZeroMemory(&memory_status, sizeof(MEMORYSTATUSEX));
|
||||||
|
memory_status.dwLength = sizeof(MEMORYSTATUSEX);
|
||||||
|
if (GlobalMemoryStatusEx(&memory_status))
|
||||||
|
{
|
||||||
|
return static_cast<qint64>(memory_status.ullTotalPhys);
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
#elif defined(Q_OS_MACOS)
|
||||||
|
vm_size_t pageSize;
|
||||||
|
vm_statistics64_data_t vmStats;
|
||||||
|
|
||||||
|
mach_port_t machPort = mach_host_self();
|
||||||
|
mach_msg_type_number_t count = sizeof(vmStats) / sizeof(natural_t);
|
||||||
|
host_page_size(machPort, &pageSize);
|
||||||
|
|
||||||
|
host_statistics64(machPort, HOST_VM_INFO, reinterpret_cast<host_info64_t>(&vmStats), &count);
|
||||||
|
|
||||||
|
qulonglong freeMemory = static_cast<qulonglong>(vmStats.free_count) * static_cast<qulonglong>(pageSize);
|
||||||
|
qulonglong totalMemoryUsed =
|
||||||
|
(static_cast<qulonglong>(vmStats.active_count) + static_cast<qulonglong>(vmStats.inactive_count) +
|
||||||
|
static_cast<qulonglong>(vmStats.wire_count)) *
|
||||||
|
static_cast<qulonglong>(pageSize);
|
||||||
|
return static_cast<qint64>(freeMemory + totalMemoryUsed);
|
||||||
|
#elif defined(Q_OS_LINUX)
|
||||||
|
struct sysinfo info; // NOLINT(cppcoreguidelines-pro-type-member-init,hicpp-member-init)
|
||||||
|
sysinfo(&info);
|
||||||
|
return static_cast<qint64>(info.totalram) * static_cast<qint64>(info.mem_unit);
|
||||||
|
#else
|
||||||
|
// Unsupported platform
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
auto GetSystemMemorySizeGB() -> double
|
||||||
|
{
|
||||||
|
qint64 totalMemoryBytes = GetSystemMemorySize();
|
||||||
|
if (totalMemoryBytes != -1)
|
||||||
|
{
|
||||||
|
return static_cast<double>(totalMemoryBytes) / (1024 * 1024 * 1024); // Convert bytes to gigabytes
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1.0; // Unsupported platform or error
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
auto TotalMemory() -> QString
|
||||||
|
{
|
||||||
|
double size = GetSystemMemorySizeGB();
|
||||||
|
return !qFuzzyCompare(size, -1.0) ? QStringLiteral("%1 GB").arg(size) : QStringLiteral("Unknown RAM");
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
VGAnalytics::VGAnalytics(QObject *parent)
|
VGAnalytics::VGAnalytics(QObject *parent)
|
||||||
: QObject{parent},
|
: QObject{parent},
|
||||||
|
@ -82,9 +165,9 @@ void VGAnalytics::SetLogLevel(enum VGAnalytics::LogLevel logLevel)
|
||||||
auto VGAnalytics::LogLevel() const -> enum VGAnalytics::LogLevel { return d->m_logLevel; }
|
auto VGAnalytics::LogLevel() const -> enum VGAnalytics::LogLevel { return d->m_logLevel; }
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VGAnalytics::SetRepoRevision(const QString &rev)
|
void VGAnalytics::SetRepoRevision(QString rev)
|
||||||
{
|
{
|
||||||
d->m_repoRevision = !rev.isEmpty() ? rev : QStringLiteral("Unknown");
|
d->m_repoRevision = !rev.isEmpty() ? rev.remove(QStringLiteral("Git:")) : QStringLiteral("Unknown");
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
@ -269,6 +352,8 @@ auto VGAnalytics::InitAppStartEventParams(qint64 engagementTimeMsec) const -> QH
|
||||||
{QStringLiteral("cpu_architecture"), QSysInfo::currentCpuArchitecture()},
|
{QStringLiteral("cpu_architecture"), QSysInfo::currentCpuArchitecture()},
|
||||||
{QStringLiteral("revision"), d->m_repoRevision},
|
{QStringLiteral("revision"), d->m_repoRevision},
|
||||||
{QStringLiteral("os_version"), QSysInfo::prettyProductName()},
|
{QStringLiteral("os_version"), QSysInfo::prettyProductName()},
|
||||||
|
{QStringLiteral("screens_number"), d->m_screensNumber},
|
||||||
|
{QStringLiteral("screen_pixel_ratio"), d->m_screenPixelRatio},
|
||||||
{QStringLiteral("screen_size"), d->m_screenResolution},
|
{QStringLiteral("screen_size"), d->m_screenResolution},
|
||||||
{QStringLiteral("screen_scale_factor"), d->m_screenScaleFactor},
|
{QStringLiteral("screen_scale_factor"), d->m_screenScaleFactor},
|
||||||
// In order for user activity to display in standard reports like Realtime, engagement_time_msec and
|
// In order for user activity to display in standard reports like Realtime, engagement_time_msec and
|
||||||
|
@ -276,378 +361,69 @@ auto VGAnalytics::InitAppStartEventParams(qint64 engagementTimeMsec) const -> QH
|
||||||
// https://developers.google.com/analytics/devguides/collection/protocol/ga4/sending-events?client_type=gtag#optional_parameters_for_reports
|
// https://developers.google.com/analytics/devguides/collection/protocol/ga4/sending-events?client_type=gtag#optional_parameters_for_reports
|
||||||
{QStringLiteral("engagement_time_msec"), engagementTimeMsec},
|
{QStringLiteral("engagement_time_msec"), engagementTimeMsec},
|
||||||
{QStringLiteral("gui_language"), d->m_guiLanguage},
|
{QStringLiteral("gui_language"), d->m_guiLanguage},
|
||||||
{QStringLiteral("countryId"), TerritoryCode()},
|
{QStringLiteral("country_code"), CountryCode()},
|
||||||
|
{QStringLiteral("kernel_type"), QSysInfo::kernelType()},
|
||||||
|
{QStringLiteral("total_memory"), TotalMemory()},
|
||||||
};
|
};
|
||||||
return params;
|
return params;
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
auto VGAnalytics::TerritoryCode() -> QString
|
auto VGAnalytics::CountryCode() -> QString
|
||||||
{
|
{
|
||||||
QLocale loc = QLocale::system();
|
QNetworkAccessManager manager;
|
||||||
|
QNetworkRequest request(QUrl(QStringLiteral("https://api.country.is")));
|
||||||
|
QNetworkReply *reply = manager.get(request);
|
||||||
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 2, 0)
|
QTimer timer;
|
||||||
return QLocale::territoryToCode(loc.territory());
|
timer.setSingleShot(true);
|
||||||
#elif QT_VERSION >= QT_VERSION_CHECK(6, 1, 0)
|
timer.start(V_SECONDS(5)); // Set the timeout to 5 seconds
|
||||||
return QLocale::countryToCode(loc.country());
|
|
||||||
#else
|
QEventLoop eventLoop;
|
||||||
return GetTerritoryCode(loc.country());
|
|
||||||
#endif
|
QObject::connect(&timer, &QTimer::timeout, &eventLoop, &QEventLoop::quit);
|
||||||
|
QObject::connect(reply, &QNetworkReply::finished, &eventLoop, &QEventLoop::quit);
|
||||||
|
|
||||||
|
eventLoop.exec();
|
||||||
|
|
||||||
|
QString country = QStringLiteral("Unknown");
|
||||||
|
|
||||||
|
if (timer.isActive())
|
||||||
|
{
|
||||||
|
// The API response was received before the timeout
|
||||||
|
if (reply->error() == QNetworkReply::NoError)
|
||||||
|
{
|
||||||
|
QByteArray responseData = reply->readAll();
|
||||||
|
QJsonParseError error;
|
||||||
|
QJsonDocument jsonDoc = QJsonDocument::fromJson(responseData, &error);
|
||||||
|
|
||||||
|
if (error.error == QJsonParseError::NoError && jsonDoc.isObject())
|
||||||
|
{
|
||||||
|
QJsonObject jsonObj = jsonDoc.object();
|
||||||
|
if (jsonObj.contains(QStringLiteral("country")))
|
||||||
|
{
|
||||||
|
country = jsonObj[QStringLiteral("country")].toString().toLower();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug() << "Error:" << reply->errorString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Timeout occurred
|
||||||
|
qDebug() << "Request timed out";
|
||||||
|
reply->abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
// Clean up the reply
|
||||||
#if QT_VERSION < QT_VERSION_CHECK(6, 1, 0)
|
reply->deleteLater();
|
||||||
auto VGAnalytics::GetTerritoryCode(QLocale::Country territory) -> QString
|
|
||||||
{
|
return country;
|
||||||
if (territory == QLocale::AnyCountry || territory > QLocale::LastCountry)
|
|
||||||
{
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const QHash<QLocale::Country, QString> territoryCodeList = {
|
|
||||||
{QLocale::Afghanistan, QLatin1String("AF")},
|
|
||||||
{QLocale::AlandIslands, QLatin1String("AX")},
|
|
||||||
{QLocale::Albania, QLatin1String("AL")},
|
|
||||||
{QLocale::Algeria, QLatin1String("DZ")},
|
|
||||||
{QLocale::AmericanSamoa, QLatin1String("AS")},
|
|
||||||
{QLocale::Andorra, QLatin1String("AD")},
|
|
||||||
{QLocale::Angola, QLatin1String("AO")},
|
|
||||||
{QLocale::Anguilla, QLatin1String("AI")},
|
|
||||||
{QLocale::Antarctica, QLatin1String("AQ")},
|
|
||||||
{QLocale::AntiguaAndBarbuda, QLatin1String("AG")},
|
|
||||||
{QLocale::Argentina, QLatin1String("AR")},
|
|
||||||
{QLocale::Armenia, QLatin1String("AM")},
|
|
||||||
{QLocale::Aruba, QLatin1String("AW")},
|
|
||||||
{QLocale::AscensionIsland, QLatin1String("AC")},
|
|
||||||
{QLocale::Australia, QLatin1String("AU")},
|
|
||||||
{QLocale::Austria, QLatin1String("AT")},
|
|
||||||
{QLocale::Azerbaijan, QLatin1String("AZ")},
|
|
||||||
{QLocale::Bahamas, QLatin1String("BS")},
|
|
||||||
{QLocale::Bahrain, QLatin1String("BH")},
|
|
||||||
{QLocale::Bangladesh, QLatin1String("BD")},
|
|
||||||
{QLocale::Barbados, QLatin1String("BB")},
|
|
||||||
{QLocale::Belarus, QLatin1String("BY")},
|
|
||||||
{QLocale::Belgium, QLatin1String("BE")},
|
|
||||||
{QLocale::Belize, QLatin1String("BZ")},
|
|
||||||
{QLocale::Benin, QLatin1String("BJ")},
|
|
||||||
{QLocale::Bermuda, QLatin1String("BM")},
|
|
||||||
{QLocale::Bhutan, QLatin1String("BT")},
|
|
||||||
{QLocale::Bolivia, QLatin1String("BO")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::BosniaAndHerzegovina, QLatin1String("BA")},
|
|
||||||
#else
|
|
||||||
{QLocale::BosniaAndHerzegowina, QLatin1String("BA")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Botswana, QLatin1String("BW")},
|
|
||||||
{QLocale::BouvetIsland, QLatin1String("BV")},
|
|
||||||
{QLocale::Brazil, QLatin1String("BR")},
|
|
||||||
{QLocale::BritishIndianOceanTerritory, QLatin1String("IO")},
|
|
||||||
{QLocale::BritishVirginIslands, QLatin1String("VG")},
|
|
||||||
{QLocale::Brunei, QLatin1String("BN")},
|
|
||||||
{QLocale::Bulgaria, QLatin1String("BG")},
|
|
||||||
{QLocale::BurkinaFaso, QLatin1String("BF")},
|
|
||||||
{QLocale::Burundi, QLatin1String("BI")},
|
|
||||||
{QLocale::Cambodia, QLatin1String("KH")},
|
|
||||||
{QLocale::Cameroon, QLatin1String("CM")},
|
|
||||||
{QLocale::Canada, QLatin1String("CA")},
|
|
||||||
{QLocale::CanaryIslands, QLatin1String("IC")},
|
|
||||||
{QLocale::CapeVerde, QLatin1String("CV")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::CaribbeanNetherlands, QLatin1String("BQ")},
|
|
||||||
#endif
|
|
||||||
{QLocale::CaymanIslands, QLatin1String("KY")},
|
|
||||||
{QLocale::CentralAfricanRepublic, QLatin1String("CF")},
|
|
||||||
{QLocale::CeutaAndMelilla, QLatin1String("EA")},
|
|
||||||
{QLocale::Chad, QLatin1String("TD")},
|
|
||||||
{QLocale::Chile, QLatin1String("CL")},
|
|
||||||
{QLocale::China, QLatin1String("CN")},
|
|
||||||
{QLocale::ChristmasIsland, QLatin1String("CX")},
|
|
||||||
{QLocale::ClippertonIsland, QLatin1String("CP")},
|
|
||||||
{QLocale::CocosIslands, QLatin1String("CC")},
|
|
||||||
{QLocale::Colombia, QLatin1String("CO")},
|
|
||||||
{QLocale::Comoros, QLatin1String("KM")},
|
|
||||||
{QLocale::CongoBrazzaville, QLatin1String("CG")},
|
|
||||||
{QLocale::CongoKinshasa, QLatin1String("CD")},
|
|
||||||
{QLocale::CookIslands, QLatin1String("CK")},
|
|
||||||
{QLocale::CostaRica, QLatin1String("CR")},
|
|
||||||
{QLocale::Croatia, QLatin1String("HR")},
|
|
||||||
{QLocale::Cuba, QLatin1String("CU")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::Curacao, QLatin1String("CW")},
|
|
||||||
#else
|
|
||||||
{QLocale::CuraSao, QLatin1String("CW")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Cyprus, QLatin1String("CY")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::Czechia, QLatin1String("CZ")},
|
|
||||||
#else
|
|
||||||
{QLocale::CzechRepublic, QLatin1String("CZ")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Denmark, QLatin1String("DK")},
|
|
||||||
{QLocale::DiegoGarcia, QLatin1String("DG")},
|
|
||||||
{QLocale::Djibouti, QLatin1String("DJ")},
|
|
||||||
{QLocale::Dominica, QLatin1String("DM")},
|
|
||||||
{QLocale::DominicanRepublic, QLatin1String("DO")},
|
|
||||||
{QLocale::Ecuador, QLatin1String("EC")},
|
|
||||||
{QLocale::Egypt, QLatin1String("EG")},
|
|
||||||
{QLocale::ElSalvador, QLatin1String("SV")},
|
|
||||||
{QLocale::EquatorialGuinea, QLatin1String("GQ")},
|
|
||||||
{QLocale::Eritrea, QLatin1String("ER")},
|
|
||||||
{QLocale::Estonia, QLatin1String("EE")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::Eswatini, QLatin1String("SZ")},
|
|
||||||
#else
|
|
||||||
{QLocale::Swaziland, QLatin1String("SZ")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Ethiopia, QLatin1String("ET")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 12, 0)
|
|
||||||
{QLocale::Europe, QLatin1String("150")},
|
|
||||||
#endif
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
||||||
{QLocale::EuropeanUnion, QLatin1String("EU")},
|
|
||||||
#endif
|
|
||||||
{QLocale::FalklandIslands, QLatin1String("FK")},
|
|
||||||
{QLocale::FaroeIslands, QLatin1String("FO")},
|
|
||||||
{QLocale::Fiji, QLatin1String("FJ")},
|
|
||||||
{QLocale::Finland, QLatin1String("FI")},
|
|
||||||
{QLocale::France, QLatin1String("FR")},
|
|
||||||
{QLocale::FrenchGuiana, QLatin1String("GF")},
|
|
||||||
{QLocale::FrenchPolynesia, QLatin1String("PF")},
|
|
||||||
{QLocale::FrenchSouthernTerritories, QLatin1String("TF")},
|
|
||||||
{QLocale::Gabon, QLatin1String("GA")},
|
|
||||||
{QLocale::Gambia, QLatin1String("GM")},
|
|
||||||
{QLocale::Georgia, QLatin1String("GE")},
|
|
||||||
{QLocale::Germany, QLatin1String("DE")},
|
|
||||||
{QLocale::Ghana, QLatin1String("GH")},
|
|
||||||
{QLocale::Gibraltar, QLatin1String("GI")},
|
|
||||||
{QLocale::Greece, QLatin1String("GR")},
|
|
||||||
{QLocale::Greenland, QLatin1String("GL")},
|
|
||||||
{QLocale::Grenada, QLatin1String("GD")},
|
|
||||||
{QLocale::Guadeloupe, QLatin1String("GP")},
|
|
||||||
{QLocale::Guam, QLatin1String("GU")},
|
|
||||||
{QLocale::Guatemala, QLatin1String("GT")},
|
|
||||||
{QLocale::Guernsey, QLatin1String("GG")},
|
|
||||||
{QLocale::GuineaBissau, QLatin1String("GW")},
|
|
||||||
{QLocale::Guinea, QLatin1String("GN")},
|
|
||||||
{QLocale::Guyana, QLatin1String("GY")},
|
|
||||||
{QLocale::Haiti, QLatin1String("HT")},
|
|
||||||
{QLocale::HeardAndMcDonaldIslands, QLatin1String("HM")},
|
|
||||||
{QLocale::Honduras, QLatin1String("HN")},
|
|
||||||
{QLocale::HongKong, QLatin1String("HK")},
|
|
||||||
{QLocale::Hungary, QLatin1String("HU")},
|
|
||||||
{QLocale::Iceland, QLatin1String("IS")},
|
|
||||||
{QLocale::India, QLatin1String("IN")},
|
|
||||||
{QLocale::Indonesia, QLatin1String("ID")},
|
|
||||||
{QLocale::Iran, QLatin1String("IR")},
|
|
||||||
{QLocale::Iraq, QLatin1String("IQ")},
|
|
||||||
{QLocale::Ireland, QLatin1String("IE")},
|
|
||||||
{QLocale::IsleOfMan, QLatin1String("IM")},
|
|
||||||
{QLocale::Israel, QLatin1String("IL")},
|
|
||||||
{QLocale::Italy, QLatin1String("IT")},
|
|
||||||
{QLocale::IvoryCoast, QLatin1String("CI")},
|
|
||||||
{QLocale::Jamaica, QLatin1String("JM")},
|
|
||||||
{QLocale::Japan, QLatin1String("JP")},
|
|
||||||
{QLocale::Jersey, QLatin1String("JE")},
|
|
||||||
{QLocale::Jordan, QLatin1String("JO")},
|
|
||||||
{QLocale::Kazakhstan, QLatin1String("KZ")},
|
|
||||||
{QLocale::Kenya, QLatin1String("KE")},
|
|
||||||
{QLocale::Kiribati, QLatin1String("KI")},
|
|
||||||
{QLocale::Kosovo, QLatin1String("XK")},
|
|
||||||
{QLocale::Kuwait, QLatin1String("KW")},
|
|
||||||
{QLocale::Kyrgyzstan, QLatin1String("KG")},
|
|
||||||
{QLocale::Laos, QLatin1String("LA")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 12, 0)
|
|
||||||
{QLocale::LatinAmerica, QLatin1String("419")},
|
|
||||||
#else
|
|
||||||
{QLocale::LatinAmericaAndTheCaribbean, QLatin1String("419")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Latvia, QLatin1String("LV")},
|
|
||||||
{QLocale::Lebanon, QLatin1String("LB")},
|
|
||||||
{QLocale::Lesotho, QLatin1String("LS")},
|
|
||||||
{QLocale::Liberia, QLatin1String("LR")},
|
|
||||||
{QLocale::Libya, QLatin1String("LY")},
|
|
||||||
{QLocale::Liechtenstein, QLatin1String("LI")},
|
|
||||||
{QLocale::Lithuania, QLatin1String("LT")},
|
|
||||||
{QLocale::Luxembourg, QLatin1String("LU")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::Macao, QLatin1String("MO")},
|
|
||||||
#else
|
|
||||||
{QLocale::Macau, QLatin1String("MO")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Macedonia, QLatin1String("MK")},
|
|
||||||
{QLocale::Madagascar, QLatin1String("MG")},
|
|
||||||
{QLocale::Malawi, QLatin1String("MW")},
|
|
||||||
{QLocale::Malaysia, QLatin1String("MY")},
|
|
||||||
{QLocale::Maldives, QLatin1String("MV")},
|
|
||||||
{QLocale::Mali, QLatin1String("ML")},
|
|
||||||
{QLocale::Malta, QLatin1String("MT")},
|
|
||||||
{QLocale::MarshallIslands, QLatin1String("MH")},
|
|
||||||
{QLocale::Martinique, QLatin1String("MQ")},
|
|
||||||
{QLocale::Mauritania, QLatin1String("MR")},
|
|
||||||
{QLocale::Mauritius, QLatin1String("MU")},
|
|
||||||
{QLocale::Mayotte, QLatin1String("YT")},
|
|
||||||
{QLocale::Mexico, QLatin1String("MX")},
|
|
||||||
{QLocale::Micronesia, QLatin1String("FM")},
|
|
||||||
{QLocale::Moldova, QLatin1String("MD")},
|
|
||||||
{QLocale::Monaco, QLatin1String("MC")},
|
|
||||||
{QLocale::Mongolia, QLatin1String("MN")},
|
|
||||||
{QLocale::Montenegro, QLatin1String("ME")},
|
|
||||||
{QLocale::Montserrat, QLatin1String("MS")},
|
|
||||||
{QLocale::Morocco, QLatin1String("MA")},
|
|
||||||
{QLocale::Mozambique, QLatin1String("MZ")},
|
|
||||||
{QLocale::Myanmar, QLatin1String("MM")},
|
|
||||||
{QLocale::Namibia, QLatin1String("NA")},
|
|
||||||
{QLocale::NauruCountry, QLatin1String("NR")},
|
|
||||||
{QLocale::Nepal, QLatin1String("NP")},
|
|
||||||
{QLocale::Netherlands, QLatin1String("NL")},
|
|
||||||
{QLocale::NewCaledonia, QLatin1String("NC")},
|
|
||||||
{QLocale::NewZealand, QLatin1String("NZ")},
|
|
||||||
{QLocale::Nicaragua, QLatin1String("NI")},
|
|
||||||
{QLocale::Nigeria, QLatin1String("NG")},
|
|
||||||
{QLocale::Niger, QLatin1String("NE")},
|
|
||||||
{QLocale::Niue, QLatin1String("NU")},
|
|
||||||
{QLocale::NorfolkIsland, QLatin1String("NF")},
|
|
||||||
{QLocale::NorthernMarianaIslands, QLatin1String("MP")},
|
|
||||||
{QLocale::NorthKorea, QLatin1String("KP")},
|
|
||||||
{QLocale::Norway, QLatin1String("NO")},
|
|
||||||
{QLocale::Oman, QLatin1String("OM")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
||||||
{QLocale::OutlyingOceania, QLatin1String("QO")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Pakistan, QLatin1String("PK")},
|
|
||||||
{QLocale::Palau, QLatin1String("PW")},
|
|
||||||
{QLocale::PalestinianTerritories, QLatin1String("PS")},
|
|
||||||
{QLocale::Panama, QLatin1String("PA")},
|
|
||||||
{QLocale::PapuaNewGuinea, QLatin1String("PG")},
|
|
||||||
{QLocale::Paraguay, QLatin1String("PY")},
|
|
||||||
{QLocale::Peru, QLatin1String("PE")},
|
|
||||||
{QLocale::Philippines, QLatin1String("PH")},
|
|
||||||
{QLocale::Pitcairn, QLatin1String("PN")},
|
|
||||||
{QLocale::Poland, QLatin1String("PL")},
|
|
||||||
{QLocale::Portugal, QLatin1String("PT")},
|
|
||||||
{QLocale::PuertoRico, QLatin1String("PR")},
|
|
||||||
{QLocale::Qatar, QLatin1String("QA")},
|
|
||||||
{QLocale::Reunion, QLatin1String("RE")},
|
|
||||||
{QLocale::Romania, QLatin1String("RO")},
|
|
||||||
{QLocale::Russia, QLatin1String("RU")},
|
|
||||||
{QLocale::Rwanda, QLatin1String("RW")},
|
|
||||||
{QLocale::SaintBarthelemy, QLatin1String("BL")},
|
|
||||||
{QLocale::SaintHelena, QLatin1String("SH")},
|
|
||||||
{QLocale::SaintKittsAndNevis, QLatin1String("KN")},
|
|
||||||
{QLocale::SaintLucia, QLatin1String("LC")},
|
|
||||||
{QLocale::SaintMartin, QLatin1String("MF")},
|
|
||||||
{QLocale::SaintPierreAndMiquelon, QLatin1String("PM")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::SaintVincentAndGrenadines, QLatin1String("VC")},
|
|
||||||
#else
|
|
||||||
{QLocale::SaintVincentAndTheGrenadines, QLatin1String("VC")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Samoa, QLatin1String("WS")},
|
|
||||||
{QLocale::SanMarino, QLatin1String("SM")},
|
|
||||||
{QLocale::SaoTomeAndPrincipe, QLatin1String("ST")},
|
|
||||||
{QLocale::SaudiArabia, QLatin1String("SA")},
|
|
||||||
{QLocale::Senegal, QLatin1String("SN")},
|
|
||||||
{QLocale::Serbia, QLatin1String("RS")},
|
|
||||||
{QLocale::Seychelles, QLatin1String("SC")},
|
|
||||||
{QLocale::SierraLeone, QLatin1String("SL")},
|
|
||||||
{QLocale::Singapore, QLatin1String("SG")},
|
|
||||||
{QLocale::SintMaarten, QLatin1String("SX")},
|
|
||||||
{QLocale::Slovakia, QLatin1String("SK")},
|
|
||||||
{QLocale::Slovenia, QLatin1String("SI")},
|
|
||||||
{QLocale::SolomonIslands, QLatin1String("SB")},
|
|
||||||
{QLocale::Somalia, QLatin1String("SO")},
|
|
||||||
{QLocale::SouthAfrica, QLatin1String("ZA")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::SouthGeorgiaAndSouthSandwichIslands, QLatin1String("GS")},
|
|
||||||
#else
|
|
||||||
{QLocale::SouthGeorgiaAndTheSouthSandwichIslands, QLatin1String("GS")},
|
|
||||||
#endif
|
|
||||||
{QLocale::SouthKorea, QLatin1String("KR")},
|
|
||||||
{QLocale::SouthSudan, QLatin1String("SS")},
|
|
||||||
{QLocale::Spain, QLatin1String("ES")},
|
|
||||||
{QLocale::SriLanka, QLatin1String("LK")},
|
|
||||||
{QLocale::Sudan, QLatin1String("SD")},
|
|
||||||
{QLocale::Suriname, QLatin1String("SR")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::SvalbardAndJanMayen, QLatin1String("SJ")},
|
|
||||||
#else
|
|
||||||
{QLocale::SvalbardAndJanMayenIslands, QLatin1String("SJ")},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{QLocale::Sweden, QLatin1String("SE")},
|
|
||||||
{QLocale::Switzerland, QLatin1String("CH")},
|
|
||||||
{QLocale::Syria, QLatin1String("SY")},
|
|
||||||
{QLocale::Taiwan, QLatin1String("TW")},
|
|
||||||
{QLocale::Tajikistan, QLatin1String("TJ")},
|
|
||||||
{QLocale::Tanzania, QLatin1String("TZ")},
|
|
||||||
{QLocale::Thailand, QLatin1String("TH")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::TimorLeste, QLatin1String("TL")},
|
|
||||||
#else
|
|
||||||
{QLocale::EastTimor, QLatin1String("TL")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Togo, QLatin1String("TG")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
||||||
{QLocale::TokelauCountry, QLatin1String("TK")},
|
|
||||||
#else
|
|
||||||
{QLocale::Tokelau, QLatin1String("TK")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Tonga, QLatin1String("TO")},
|
|
||||||
{QLocale::TrinidadAndTobago, QLatin1String("TT")},
|
|
||||||
{QLocale::TristanDaCunha, QLatin1String("TA")},
|
|
||||||
{QLocale::Tunisia, QLatin1String("TN")},
|
|
||||||
{QLocale::Turkey, QLatin1String("TR")},
|
|
||||||
{QLocale::Turkmenistan, QLatin1String("TM")},
|
|
||||||
{QLocale::TurksAndCaicosIslands, QLatin1String("TC")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
||||||
{QLocale::TuvaluCountry, QLatin1String("TV")},
|
|
||||||
#else
|
|
||||||
{QLocale::Tuvalu, QLatin1String("TV")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Uganda, QLatin1String("UG")},
|
|
||||||
{QLocale::Ukraine, QLatin1String("UA")},
|
|
||||||
{QLocale::UnitedArabEmirates, QLatin1String("AE")},
|
|
||||||
{QLocale::UnitedKingdom, QLatin1String("GB")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::UnitedStatesOutlyingIslands, QLatin1String("UM")},
|
|
||||||
#else
|
|
||||||
{QLocale::UnitedStatesMinorOutlyingIslands, QLatin1String("UM")},
|
|
||||||
#endif
|
|
||||||
{QLocale::UnitedStates, QLatin1String("US")},
|
|
||||||
{QLocale::UnitedStatesVirginIslands, QLatin1String("VI")},
|
|
||||||
{QLocale::Uruguay, QLatin1String("UY")},
|
|
||||||
{QLocale::Uzbekistan, QLatin1String("UZ")},
|
|
||||||
{QLocale::Vanuatu, QLatin1String("VU")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::VaticanCity, QLatin1String("VA")},
|
|
||||||
#else
|
|
||||||
{QLocale::VaticanCityState, QLatin1String("VA")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Venezuela, QLatin1String("VE")},
|
|
||||||
{QLocale::Vietnam, QLatin1String("VN")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
|
||||||
{QLocale::WallisAndFutuna, QLatin1String("WF")},
|
|
||||||
#else
|
|
||||||
{QLocale::WallisAndFutunaIslands, QLatin1String("WF")},
|
|
||||||
#endif
|
|
||||||
{QLocale::WesternSahara, QLatin1String("EH")},
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 12, 0)
|
|
||||||
{QLocale::World, QLatin1String("001")},
|
|
||||||
#endif
|
|
||||||
{QLocale::Yemen, QLatin1String("YE")},
|
|
||||||
{QLocale::Zambia, QLatin1String("ZM")},
|
|
||||||
{QLocale::Zimbabwe, QLatin1String("ZW")},
|
|
||||||
};
|
|
||||||
|
|
||||||
if (territoryCodeList.contains(territory))
|
|
||||||
{
|
|
||||||
return territoryCodeList.value(territory);
|
|
||||||
}
|
|
||||||
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
/**
|
/**
|
||||||
* Qut stream to persist class GAnalytics.
|
* Qut stream to persist class GAnalytics.
|
||||||
|
|
|
@ -67,7 +67,7 @@ public:
|
||||||
void SetLogLevel(LogLevel logLevel);
|
void SetLogLevel(LogLevel logLevel);
|
||||||
auto LogLevel() const -> LogLevel;
|
auto LogLevel() const -> LogLevel;
|
||||||
|
|
||||||
void SetRepoRevision(const QString &rev);
|
void SetRepoRevision(QString rev);
|
||||||
auto RepoRevision() const -> QString;
|
auto RepoRevision() const -> QString;
|
||||||
|
|
||||||
void SetGUILanguage(const QString &language);
|
void SetGUILanguage(const QString &language);
|
||||||
|
@ -83,6 +83,8 @@ public:
|
||||||
void SetNetworkAccessManager(QNetworkAccessManager *networkAccessManager);
|
void SetNetworkAccessManager(QNetworkAccessManager *networkAccessManager);
|
||||||
auto NetworkAccessManager() const -> QNetworkAccessManager *;
|
auto NetworkAccessManager() const -> QNetworkAccessManager *;
|
||||||
|
|
||||||
|
static auto CountryCode() -> QString;
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void SendAppFreshInstallEvent(qint64 engagementTimeMsec);
|
void SendAppFreshInstallEvent(qint64 engagementTimeMsec);
|
||||||
void SendAppStartEvent(qint64 engagementTimeMsec);
|
void SendAppStartEvent(qint64 engagementTimeMsec);
|
||||||
|
@ -100,11 +102,6 @@ private:
|
||||||
|
|
||||||
auto InitAppStartEventParams(qint64 engagementTimeMsec) const -> QHash<QString, QJsonValue>;
|
auto InitAppStartEventParams(qint64 engagementTimeMsec) const -> QHash<QString, QJsonValue>;
|
||||||
|
|
||||||
static auto TerritoryCode() -> QString;
|
|
||||||
#if QT_VERSION < QT_VERSION_CHECK(6, 1, 0)
|
|
||||||
static auto GetTerritoryCode(QLocale::Country territory) -> QString;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
friend auto operator<<(QDataStream &outStream, const VGAnalytics &analytics) -> QDataStream &;
|
friend auto operator<<(QDataStream &outStream, const VGAnalytics &analytics) -> QDataStream &;
|
||||||
friend auto operator>>(QDataStream &inStream, VGAnalytics &analytics) -> QDataStream &;
|
friend auto operator>>(QDataStream &inStream, VGAnalytics &analytics) -> QDataStream &;
|
||||||
};
|
};
|
||||||
|
|
|
@ -58,10 +58,17 @@ VGAnalyticsWorker::VGAnalyticsWorker(QObject *parent)
|
||||||
|
|
||||||
m_guiLanguage = QLocale::system().name().toLower().replace(QChar('_'), QChar('-'));
|
m_guiLanguage = QLocale::system().name().toLower().replace(QChar('_'), QChar('-'));
|
||||||
|
|
||||||
QScreen *screen = QGuiApplication::primaryScreen();
|
m_screensNumber = QString::number(QGuiApplication::screens().size());
|
||||||
QSize size = screen->size();
|
|
||||||
|
|
||||||
m_screenResolution = QStringLiteral("%1x%2").arg(size.width()).arg(size.height());
|
QScreen *screen = QGuiApplication::primaryScreen();
|
||||||
|
QSize logicalSize = screen->size();
|
||||||
|
qreal devicePixelRatio = screen->devicePixelRatio();
|
||||||
|
m_screenPixelRatio = QString::number(devicePixelRatio);
|
||||||
|
|
||||||
|
int screenWidth = qRound(logicalSize.width() * devicePixelRatio);
|
||||||
|
int screenHeight = qRound(logicalSize.height() * devicePixelRatio);
|
||||||
|
|
||||||
|
m_screenResolution = QStringLiteral("%1x%2").arg(screenWidth).arg(screenHeight);
|
||||||
m_screenScaleFactor = screen->logicalDotsPerInchX() / 96.0;
|
m_screenScaleFactor = screen->logicalDotsPerInchX() / 96.0;
|
||||||
|
|
||||||
m_timer.setInterval(m_timerInterval);
|
m_timer.setInterval(m_timerInterval);
|
||||||
|
|
|
@ -74,6 +74,8 @@ public:
|
||||||
QString m_appName{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
QString m_appName{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
QString m_appVersion{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
QString m_appVersion{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
QString m_guiLanguage{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
QString m_guiLanguage{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
|
QString m_screensNumber{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
|
QString m_screenPixelRatio{}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
QString m_screenResolution{QStringLiteral("0x0")}; // NOLINT(misc-non-private-member-variables-in-classes)
|
QString m_screenResolution{QStringLiteral("0x0")}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
QString m_repoRevision{QStringLiteral("Unknown")}; // NOLINT(misc-non-private-member-variables-in-classes)
|
QString m_repoRevision{QStringLiteral("Unknown")}; // NOLINT(misc-non-private-member-variables-in-classes)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user