/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright 2013 - 2022, nymea GmbH * Contact: contact@nymea.io * * This file is part of nymea. * This project including source code and documentation is protected by copyright law, and * remains the property of nymea GmbH. All rights, including reproduction, publication, * editing and translation, are reserved. The use of this project is subject to the terms of a * license agreement to be concluded with nymea GmbH in accordance with the terms * of use of nymea GmbH, available under https://nymea.io/license * * GNU General Public License Usage * Alternatively, this project may be redistributed and/or modified under * the terms of the GNU General Public License as published by the Free Software Foundation, * GNU version 3. this project 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 project. * If not, see . * * For any further details and any questions please contact us under contact@nymea.io * or see our FAQ/Licensing Information on https://nymea.io/license/faq * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include "authorizer.h" #include #include Authorizer::Authorizer(const QString &policyFile, QObject *parent): QObject{parent}, m_settingsFile(policyFile) { if (QFile::exists(policyFile)) { qInfo() << "Using policy file:" << policyFile; } } Mqtt::ConnectReturnCode Authorizer::authorizeConnect(int serverAddressId, const QString &clientId, const QString &username, const QString &password, const QHostAddress &peerAddress) { Q_UNUSED(serverAddressId) Q_UNUSED(peerAddress); if (!QFile::exists(m_settingsFile)) { return Mqtt::ConnectReturnCodeServerUnavailable; } MqttPolicy policy = loadPolicy(clientId); if (!policy.isValid()) { return Mqtt::ConnectReturnCodeNotAuthorized; } if (policy.username() != username || policy.password() != password) { return Mqtt::ConnectReturnCodeBadUsernameOrPassword; } return Mqtt::ConnectReturnCodeAccepted; } bool Authorizer::authorizeSubscribe(int serverAddressId, const QString &clientId, const QString &topicFilter) { Q_UNUSED(serverAddressId) qCritical() << "sub filters" << topicFilter; if (!QFile::exists(m_settingsFile)) { return false; } MqttPolicy policy = loadPolicy(clientId); if (!policy.isValid()) { return false; } qCritical() << "policy" << policy.allowedSubscribeTopicFilters(); if (policy.allowedSubscribeTopicFilters().contains(topicFilter)) { return true; } return false; } bool Authorizer::authorizePublish(int serverAddressId, const QString &clientId, const QString &topic) { Q_UNUSED(serverAddressId) if (!QFile::exists(m_settingsFile)) { return false; } MqttPolicy policy = loadPolicy(clientId); if (!policy.isValid()) { return false; } if (policy.allowedPublishTopicFilters().contains(topic)) { return true; } return false; } void Authorizer::addPolicy(const QString &clientId, const QString &username, const QString &password, const QStringList &allowedSubscribeTopicFilters, const QStringList &allowedPublishTopicFilters) { QSettings settings(m_settingsFile, QSettings::IniFormat); settings.beginGroup(clientId); settings.setValue("username", username); settings.setValue("password", password); settings.setValue("allowedSubscribeTopicFilters", allowedSubscribeTopicFilters); settings.setValue("allowedPublishTopicFilters", allowedPublishTopicFilters); } void Authorizer::removePolicy(const QString &clientId) { QSettings settings(m_settingsFile, QSettings::IniFormat); settings.remove(clientId); } MqttPolicy Authorizer::loadPolicy(const QString &clientId) { QSettings settings(m_settingsFile, QSettings::IniFormat); if (!settings.childGroups().contains(clientId)) { return MqttPolicy(); } settings.beginGroup(clientId); MqttPolicy policy(clientId, settings.value("username").toString(), settings.value("password").toString(), settings.value("allowedSubscribeTopicFilters").toStringList(), settings.value("allowedPublishTopicFilters").toStringList()); return policy; }