// SPDX-License-Identifier: LGPL-3.0-or-later
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright (C) 2013 - 2024, nymea GmbH
* Copyright (C) 2024 - 2025, chargebyte austria GmbH
*
* This file is part of libnymea-app.
*
* libnymea-app is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3
* of the License, or (at your option) any later version.
*
* libnymea-app 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with libnymea-app. If not, see .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "mqttpolicies.h"
#include "mqttpolicy.h"
MqttPolicies::MqttPolicies(QObject *parent) : QAbstractListModel(parent)
{
}
int MqttPolicies::rowCount(const QModelIndex &index) const
{
Q_UNUSED(index)
return static_cast(m_list.count());
}
QVariant MqttPolicies::data(const QModelIndex &index, int role) const
{
switch (role) {
case RoleClientId:
return m_list.at(index.row())->clientId();
case RoleUsername:
return m_list.at(index.row())->username();
case RolePassword:
return m_list.at(index.row())->password();
case RoleAllowedPublishTopicFilters:
return m_list.at(index.row())->allowedPublishTopicFilters();
case RoleAllowedSubscribeTopicFilters:
return m_list.at(index.row())->allowedSubscribeTopicFilters();
}
return QVariant();
}
QHash MqttPolicies::roleNames() const
{
QHash roles;
roles.insert(RoleClientId, "clientId");
roles.insert(RoleUsername, "username");
roles.insert(RolePassword, "password");
roles.insert(RoleAllowedPublishTopicFilters, "allowedPublishTopicFilters");
roles.insert(RoleAllowedSubscribeTopicFilters, "allowedSubscribeTopicFilters");
return roles;
}
void MqttPolicies::addPolicy(MqttPolicy *policy)
{
policy->setParent(this);
beginInsertRows(QModelIndex(), static_cast(m_list.count()), static_cast(m_list.count()));
m_list.append(policy);
connect(policy, &MqttPolicy::clientIdChanged, this, [this, policy]() {
QModelIndex index = this->index(static_cast(m_list.indexOf(policy)));
emit dataChanged(index, index, {RoleClientId});
});
connect(policy, &MqttPolicy::usernameChanged, this, [this, policy]() {
QModelIndex index = this->index(static_cast(m_list.indexOf(policy)));
emit dataChanged(index, index, {RoleUsername});
});
connect(policy, &MqttPolicy::passwordChanged, this, [this, policy]() {
QModelIndex index = this->index(static_cast(m_list.indexOf(policy)));
emit dataChanged(index, index, {RolePassword});
});
connect(policy, &MqttPolicy::allowedPublishTopicFiltersChanged, this, [this, policy]() {
QModelIndex index = this->index(static_cast(m_list.indexOf(policy)));
emit dataChanged(index, index, {RoleAllowedPublishTopicFilters});
});
connect(policy, &MqttPolicy::allowedSubscribeTopicFiltersChanged, this, [this, policy]() {
QModelIndex index = this->index(static_cast(m_list.indexOf(policy)));
emit dataChanged(index, index, {RoleAllowedSubscribeTopicFilters});
});
endInsertRows();
emit countChanged();
}
void MqttPolicies::removePolicy(MqttPolicy *policy)
{
int idx = static_cast(m_list.indexOf(policy));
if (idx < 0) {
return;
}
beginRemoveRows(QModelIndex(), idx, idx);
m_list.takeAt(idx)->deleteLater();
endRemoveRows();
}
MqttPolicy *MqttPolicies::getPolicy(const QString &clientId) const
{
foreach (MqttPolicy* policy, m_list) {
if (policy->clientId() == clientId) {
return policy;
}
}
return nullptr;
}
MqttPolicy *MqttPolicies::get(int index) const
{
if (index < 0 || index >= m_list.count()){
return nullptr;
}
return m_list.at(index);
}
void MqttPolicies::clear()
{
beginResetModel();
foreach (MqttPolicy* policy, m_list)
policy->deleteLater();
m_list.clear();
endResetModel();
}