mirror of
https://git.jami.net/savoirfairelinux/jami-client-qt.git
synced 2025-08-02 13:55:40 +02:00

- better manage QML interop object lifetimes - allow intellisense to pick up QML registered symbols - fix for PreviewEngine threading Change-Id: I416cdede70b155dc34fc3ee94f428ae2128c8950
234 lines
8.6 KiB
C++
234 lines
8.6 KiB
C++
/*!
|
|
* Copyright (C) 2020-2024 Savoir-faire Linux Inc.
|
|
* Author: Aline Gondim Santos <aline.gondimsantos@savoirfairelinux.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "pluginadapter.h"
|
|
|
|
#include "pluginversionmanager.h"
|
|
#include "pluginlistmodel.h"
|
|
#include "pluginstorelistmodel.h"
|
|
#include "networkmanager.h"
|
|
#include "lrcinstance.h"
|
|
#include "appsettingsmanager.h"
|
|
|
|
#include "api/pluginmodel.h"
|
|
|
|
#include <QJsonArray>
|
|
#include <QJsonDocument>
|
|
#include <QtNetwork>
|
|
#include <QJsonObject>
|
|
#include <QDir>
|
|
#include <QString>
|
|
|
|
PluginAdapter::PluginAdapter(LRCInstance* instance,
|
|
AppSettingsManager* settingsManager,
|
|
QObject* parent)
|
|
: QmlAdapterBase(instance, parent)
|
|
, pluginStoreListModel_(new PluginStoreListModel(instance, this))
|
|
, pluginVersionManager_(new PluginVersionManager(instance, settingsManager, this))
|
|
, pluginListModel_(new PluginListModel(instance, this))
|
|
, lrcInstance_(instance)
|
|
, settingsManager_(settingsManager)
|
|
{
|
|
pluginListModel_ = qApp->property("PluginListModel").value<PluginListModel*>();
|
|
pluginStoreListModel_ = qApp->property("PluginStoreListModel").value<PluginStoreListModel*>();
|
|
|
|
updateHandlersListCount();
|
|
connect(&lrcInstance_->pluginModel(),
|
|
&lrc::api::PluginModel::modelUpdated,
|
|
this,
|
|
&PluginAdapter::updateHandlersListCount);
|
|
connect(pluginVersionManager_,
|
|
&PluginVersionManager::versionStatusChanged,
|
|
pluginListModel_,
|
|
&PluginListModel::onVersionStatusChanged);
|
|
connect(pluginVersionManager_,
|
|
&PluginVersionManager::versionStatusChanged,
|
|
pluginStoreListModel_,
|
|
&PluginStoreListModel::onVersionStatusChanged);
|
|
connect(pluginStoreListModel_,
|
|
&PluginStoreListModel::pluginAdded,
|
|
this,
|
|
&PluginAdapter::getPluginDetails);
|
|
connect(pluginListModel_,
|
|
&PluginListModel::versionCheckRequested,
|
|
pluginVersionManager_,
|
|
&PluginVersionManager::checkVersionStatus);
|
|
connect(pluginListModel_,
|
|
&PluginListModel::autoUpdateChanged,
|
|
pluginVersionManager_,
|
|
&PluginVersionManager::setAutoUpdate);
|
|
connect(pluginListModel_,
|
|
&PluginListModel::setVersionStatus,
|
|
pluginStoreListModel_,
|
|
&PluginStoreListModel::onVersionStatusChanged);
|
|
connect(pluginVersionManager_,
|
|
&PluginVersionManager::newVersionAvailable,
|
|
pluginListModel_,
|
|
&PluginListModel::onNewVersionAvailable);
|
|
getPluginsFromStore();
|
|
}
|
|
|
|
void
|
|
PluginAdapter::getPluginsFromStore()
|
|
{
|
|
const auto& errorHandler = connect(pluginVersionManager_,
|
|
&PluginVersionManager::errorOccurred,
|
|
this,
|
|
[this](NetworkManager::GetError error, const QString& msg) {
|
|
Q_EMIT storeNotAvailable();
|
|
});
|
|
QMap<QString, QByteArray> header;
|
|
const auto& language = settingsManager_->getLanguage();
|
|
header["Accept-Language"] = QByteArray(language.toStdString().c_str(), language.size());
|
|
pluginVersionManager_
|
|
->sendGetRequest(QUrl(baseUrl()
|
|
+ "?arch=" + lrcInstance_->pluginModel().getPlatformInfo()["os"]),
|
|
header,
|
|
[this, errorHandler](const QByteArray& data) {
|
|
auto result = QJsonDocument::fromJson(data).array();
|
|
auto pluginsInstalled = lrcInstance_->pluginModel().getPluginsId();
|
|
QList<QVariantMap> plugins;
|
|
if (result.size() == 0) {
|
|
Q_EMIT storeNotAvailableForPlatform();
|
|
return;
|
|
}
|
|
for (const auto& plugin : result) {
|
|
auto qPlugin = plugin.toVariant().toMap();
|
|
|
|
if (!qPlugin.contains("id")) {
|
|
qPlugin["id"] = qPlugin["name"];
|
|
}
|
|
if (!pluginsInstalled.contains(qPlugin["id"].toString())) {
|
|
plugins.append(qPlugin);
|
|
}
|
|
}
|
|
pluginStoreListModel_->setPlugins(plugins);
|
|
disconnect(errorHandler);
|
|
});
|
|
}
|
|
|
|
void
|
|
PluginAdapter::getPluginDetails(const QString& pluginId)
|
|
{
|
|
QMap<QString, QByteArray> header;
|
|
const auto& language = settingsManager_->getLanguage();
|
|
header["Accept-Language"] = QByteArray(language.toStdString().c_str(), language.size());
|
|
pluginVersionManager_
|
|
->sendGetRequest(QUrl(baseUrl() + "/details/" + pluginId
|
|
+ "?arch=" + lrcInstance_->pluginModel().getPlatformInfo()["os"]),
|
|
header,
|
|
[this](const QByteArray& data) {
|
|
auto result = QJsonDocument::fromJson(data).object();
|
|
// my response is a json object and I want to convert
|
|
// it to a QVariantMap
|
|
auto plugin = result.toVariantMap();
|
|
if (!plugin.contains("id")) {
|
|
plugin["id"] = plugin["name"];
|
|
}
|
|
pluginStoreListModel_->addPlugin(plugin);
|
|
});
|
|
}
|
|
|
|
void
|
|
PluginAdapter::installRemotePlugin(const QString& pluginId)
|
|
{
|
|
pluginVersionManager_->installRemotePlugin(pluginId);
|
|
}
|
|
|
|
bool
|
|
PluginAdapter::isAutoUpdaterEnabled()
|
|
{
|
|
return pluginVersionManager_->isAutoUpdaterEnabled();
|
|
}
|
|
|
|
void
|
|
PluginAdapter::setAutoUpdate(bool state)
|
|
{
|
|
pluginVersionManager_->setAutoUpdate(state);
|
|
}
|
|
|
|
void
|
|
PluginAdapter::cancelDownload(const QString& pluginId)
|
|
{
|
|
pluginVersionManager_->cancelUpdate(pluginId);
|
|
}
|
|
|
|
QVariant
|
|
PluginAdapter::getMediaHandlerSelectableModel(const QString& callId)
|
|
{
|
|
pluginHandlerListModel_.reset(
|
|
new PluginHandlerListModel(this, callId, QString(""), lrcInstance_));
|
|
return QVariant::fromValue(pluginHandlerListModel_.get());
|
|
}
|
|
|
|
QVariant
|
|
PluginAdapter::getChatHandlerSelectableModel(const QString& accountId, const QString& peerId)
|
|
{
|
|
pluginHandlerListModel_.reset(new PluginHandlerListModel(this, accountId, peerId, lrcInstance_));
|
|
return QVariant::fromValue(pluginHandlerListModel_.get());
|
|
}
|
|
|
|
QVariant
|
|
PluginAdapter::getPluginPreferencesCategories(const QString& pluginId,
|
|
const QString& accountId,
|
|
bool removeLast)
|
|
{
|
|
QStringList categories;
|
|
auto preferences = lrcInstance_->pluginModel().getPluginPreferences(pluginId, accountId);
|
|
for (auto& preference : preferences) {
|
|
if (!preference["category"].isEmpty())
|
|
categories.push_back(preference["category"]);
|
|
}
|
|
categories.removeDuplicates();
|
|
if (removeLast)
|
|
categories.pop_back();
|
|
return categories;
|
|
}
|
|
|
|
void
|
|
PluginAdapter::updateHandlersListCount()
|
|
{
|
|
set_callMediaHandlersListCount(lrcInstance_->pluginModel().getCallMediaHandlers().size());
|
|
set_chatHandlersListCount(lrcInstance_->pluginModel().getChatHandlers().size());
|
|
}
|
|
|
|
void
|
|
PluginAdapter::checkVersionStatus(const QString& pluginId)
|
|
{
|
|
pluginVersionManager_->checkVersionStatus(pluginId);
|
|
}
|
|
|
|
QString
|
|
PluginAdapter::baseUrl() const
|
|
{
|
|
return settingsManager_->getValue("PluginStoreEndpoint").toString();
|
|
}
|
|
|
|
QString
|
|
PluginAdapter::getIconUrl(const QString& pluginId) const
|
|
{
|
|
return baseUrl() + "/icons/" + pluginId
|
|
+ "?arch=" + lrcInstance_->pluginModel().getPlatformInfo()["os"];
|
|
}
|
|
|
|
QString
|
|
PluginAdapter::getBackgroundImageUrl(const QString& pluginId) const
|
|
{
|
|
return baseUrl() + "/backgrounds/" + pluginId
|
|
+ "?arch=" + lrcInstance_->pluginModel().getPlatformInfo()["os"];
|
|
}
|