* refactoring: improved the performance of secure_settings * bugfix: fixed textFields on PageSetupWizardCredentials * bugfix: fixed scrolling by keys on PageSettingsApiServerInfo * chore: hide site links for ios (#1374) * chore: fixed log output with split tunneling info * chore: hide "open logs folder" button for mobule platforms * chore: fixed again log output with split tunneling info * chore: bump version * Install apparmor (#1379) Install apparmor * chore: returned the backup page for androidTV * Enable PFS for Windows IKEv2 * refactoring: moved api info pages from ServerInfo * refactoring: moved gateway interaction functions to a separate class * bugfix: fixed storeEndpoint parsing * chore: returned links for mobile platforms * Update VPN protocol descriptions * Update VPN description texts * feature: added pages for subscription settings feature * feature: added page for export api native configs * feature: added error handling and minor ui fixes * refactor: update ios build configuration to use automatic code signing and prebuilt OpenVPNAdapter framework * feat: remove OpenVPNAdapter submodule * feat: remove ios openvpn script and associated cmake configuration * Update README.md * Update README_RU.md * Update README.md fix link * feature: added share vpn key to subscription settings page * bugfix: fixed possible crush on android * add timeouts in ipc client init * apply timeouts only for Windows * apply format to file * refactoring: simplified the validity check of the config before connection - improved project structure * bugfix: fixed visability of share drawer * feature: added 409 error handling from server response * chore: fixed android build * chore: fixed qr code display * Rewrite timeouts using waitForSource * feature: added error messages handler * feature: added issued configs info parsing * feature: added functionality to revoke api configs * chore: added links to instructions * chore: fixed qr code with vpnkey processing * chore: fixed native config post processing * chore: added link to android tv instruction * change node to IpcProcessTun2SocksReplica * chore: minor ui fixes * Update Windows OpenSSL (#1426) * Update Windows OpenSSL to 3.0.16 and add shared library for QSslSocket plugin * chore: update link to submodule 3rd-prebuild --------- Co-authored-by: vladimir.kuznetsov <nethiuswork@gmail.com> * chore: added 404 handling for revoke configs - added revoke before remove api server for premium v2 * chore: added log to see proxy decrypt errors * chore: minor ui fix * chore: bump version * bugfix: fixed mobile controllers initialization (#1436) * bugfix: fixed mobile controllers initialization * chore: bump version * Merge pull request #1440 from amnezia-vpn/feature/subscription-settings-page feature/subscription settings page --------- Co-authored-by: vladimir.kuznetsov <nethiuswork@gmail.com> Co-authored-by: pokamest <pokamest@gmail.com> Co-authored-by: Mykola Baibuz <mykola.baibuz@gmail.com> Co-authored-by: Yaroslav Yashin <yaroslav.yashin@gmail.com> Co-authored-by: KsZnak <ksu@amnezia.org> Co-authored-by: Cyril Anisimov <CyAn84@gmail.com>
143 lines
4.7 KiB
C++
143 lines
4.7 KiB
C++
#include "apiAccountInfoModel.h"
|
|
|
|
#include <QJsonObject>
|
|
|
|
#include "core/api/apiUtils.h"
|
|
#include "logger.h"
|
|
|
|
namespace
|
|
{
|
|
Logger logger("AccountInfoModel");
|
|
}
|
|
|
|
ApiAccountInfoModel::ApiAccountInfoModel(QObject *parent) : QAbstractListModel(parent)
|
|
{
|
|
}
|
|
|
|
int ApiAccountInfoModel::rowCount(const QModelIndex &parent) const
|
|
{
|
|
Q_UNUSED(parent)
|
|
return 1;
|
|
}
|
|
|
|
QVariant ApiAccountInfoModel::data(const QModelIndex &index, int role) const
|
|
{
|
|
if (!index.isValid() || index.row() < 0 || index.row() >= static_cast<int>(rowCount()))
|
|
return QVariant();
|
|
|
|
switch (role) {
|
|
case SubscriptionStatusRole: {
|
|
if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaFreeV3) {
|
|
return tr("Active");
|
|
}
|
|
|
|
return apiUtils::isSubscriptionExpired(m_accountInfoData.subscriptionEndDate) ? tr("Inactive") : tr("Active");
|
|
}
|
|
case EndDateRole: {
|
|
if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaFreeV3) {
|
|
return "";
|
|
}
|
|
|
|
return QDateTime::fromString(m_accountInfoData.subscriptionEndDate, Qt::ISODate).toLocalTime().toString("d MMM yyyy");
|
|
}
|
|
case ConnectedDevicesRole: {
|
|
if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaFreeV3) {
|
|
return "";
|
|
}
|
|
return tr("%1 out of %2").arg(m_accountInfoData.activeDeviceCount).arg(m_accountInfoData.maxDeviceCount);
|
|
}
|
|
case ServiceDescriptionRole: {
|
|
if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaPremiumV2) {
|
|
return tr("Classic VPN for comfortable work, downloading large files and watching videos. Works for any sites. Speed up to 200 "
|
|
"Mb/s");
|
|
} else if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaFreeV3) {
|
|
return tr("Free unlimited access to a basic set of websites such as Facebook, Instagram, Twitter (X), Discord, Telegram and "
|
|
"more. YouTube is not included in the free plan.");
|
|
}
|
|
}
|
|
case IsComponentVisibleRole: {
|
|
return m_accountInfoData.configType == apiDefs::ConfigType::AmneziaPremiumV2;
|
|
}
|
|
case HasExpiredWorkerRole: {
|
|
for (int i = 0; i < m_issuedConfigsInfo.size(); i++) {
|
|
QJsonObject issuedConfigObject = m_issuedConfigsInfo.at(i).toObject();
|
|
|
|
auto lastDownloaded = QDateTime::fromString(issuedConfigObject.value(apiDefs::key::lastDownloaded).toString());
|
|
auto workerLastUpdated = QDateTime::fromString(issuedConfigObject.value(apiDefs::key::workerLastUpdated).toString());
|
|
|
|
if (lastDownloaded < workerLastUpdated) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return QVariant();
|
|
}
|
|
|
|
void ApiAccountInfoModel::updateModel(const QJsonObject &accountInfoObject, const QJsonObject &serverConfig)
|
|
{
|
|
beginResetModel();
|
|
|
|
AccountInfoData accountInfoData;
|
|
|
|
m_availableCountries = accountInfoObject.value(apiDefs::key::availableCountries).toArray();
|
|
m_issuedConfigsInfo = accountInfoObject.value(apiDefs::key::issuedConfigs).toArray();
|
|
|
|
accountInfoData.activeDeviceCount = accountInfoObject.value(apiDefs::key::activeDeviceCount).toInt();
|
|
accountInfoData.maxDeviceCount = accountInfoObject.value(apiDefs::key::maxDeviceCount).toInt();
|
|
accountInfoData.subscriptionEndDate = accountInfoObject.value(apiDefs::key::subscriptionEndDate).toString();
|
|
|
|
accountInfoData.configType = apiUtils::getConfigType(serverConfig);
|
|
|
|
m_accountInfoData = accountInfoData;
|
|
|
|
endResetModel();
|
|
}
|
|
|
|
QVariant ApiAccountInfoModel::data(const QString &roleString)
|
|
{
|
|
QModelIndex modelIndex = index(0);
|
|
auto roles = roleNames();
|
|
for (auto it = roles.begin(); it != roles.end(); it++) {
|
|
if (QString(it.value()) == roleString) {
|
|
return data(modelIndex, it.key());
|
|
}
|
|
}
|
|
|
|
return {};
|
|
}
|
|
|
|
QJsonArray ApiAccountInfoModel::getAvailableCountries()
|
|
{
|
|
return m_availableCountries;
|
|
}
|
|
|
|
QJsonArray ApiAccountInfoModel::getIssuedConfigsInfo()
|
|
{
|
|
return m_issuedConfigsInfo;
|
|
}
|
|
|
|
QString ApiAccountInfoModel::getTelegramBotLink()
|
|
{
|
|
if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaFreeV3) {
|
|
return tr("amnezia_free_support_bot");
|
|
} else if (m_accountInfoData.configType == apiDefs::ConfigType::AmneziaPremiumV2) {
|
|
return tr("amnezia_premium_support_bot");
|
|
}
|
|
return "";
|
|
}
|
|
|
|
QHash<int, QByteArray> ApiAccountInfoModel::roleNames() const
|
|
{
|
|
QHash<int, QByteArray> roles;
|
|
roles[SubscriptionStatusRole] = "subscriptionStatus";
|
|
roles[EndDateRole] = "endDate";
|
|
roles[ConnectedDevicesRole] = "connectedDevices";
|
|
roles[ServiceDescriptionRole] = "serviceDescription";
|
|
roles[IsComponentVisibleRole] = "isComponentVisible";
|
|
roles[HasExpiredWorkerRole] = "hasExpiredWorker";
|
|
|
|
return roles;
|
|
}
|