/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright 2013 - 2024, 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 "serverdebugmanager.h" #include "engine.h" #include "logging.h" #include "serverloggingcategories.h" NYMEA_LOGGING_CATEGORY(dcServerDebug, "ServerDebug") ServerDebugManager::ServerDebugManager(QObject *parent) : QObject{parent}, m_categories{new ServerLoggingCategories(this)} { qRegisterMetaType("ServerLoggingCategory"); } ServerDebugManager::~ServerDebugManager() { if (m_engine) { m_engine->jsonRpcClient()->unregisterNotificationHandler(this); } } Engine *ServerDebugManager::engine() const { return m_engine; } void ServerDebugManager::setEngine(Engine *engine) { if (m_engine != engine) { if (m_engine) m_engine->jsonRpcClient()->unregisterNotificationHandler(this); m_engine = engine; emit engineChanged(); init(); } } ServerLoggingCategories *ServerDebugManager::categories() const { return m_categories; } bool ServerDebugManager::fetchingData() const { return m_fetchingData; } void ServerDebugManager::getLoggingCategories() { if (!m_engine) return; m_engine->jsonRpcClient()->sendCommand("Debug.GetLoggingCategories", this, "getLoggingCategoriesResponse"); } void ServerDebugManager::setLoggingLevel(const QString &name, int level) { if (!m_engine) return; QVariantMap params; params.insert("name", name); switch (level) { case ServerLoggingCategory::LevelCritical: params.insert("level", "LoggingLevelCritical"); break; case ServerLoggingCategory::LevelWarning: params.insert("level", "LoggingLevelWarning"); break; case ServerLoggingCategory::LevelInfo: params.insert("level", "LoggingLevelInfo"); break; case ServerLoggingCategory::LevelDebug: params.insert("level", "LoggingLevelDebug"); break; } m_engine->jsonRpcClient()->sendCommand("Debug.SetLoggingCategoryLevel", params, this, "setLoggingCategoryLevelResponse"); } void ServerDebugManager::notificationReceived(const QVariantMap ¬ification) { qCDebug(dcServerDebug()) << "Notification received" << notification; } void ServerDebugManager::init() { m_fetchingData = true; emit fetchingDataChanged(); if (m_engine) m_engine->jsonRpcClient()->registerNotificationHandler(this, "Debug", "notificationReceived"); getLoggingCategories(); } void ServerDebugManager::getLoggingCategoriesResponse(int commandId, const QVariantMap ¶ms) { Q_UNUSED(commandId) QVariantList categories = params.value("loggingCategories").toList(); m_categories->createFromVariantList(categories); // foreach (const QVariant &categoryVariant, categories) { // QVariantMap categoryMap = categoryVariant.toMap(); // qCDebug(dcServerDebug()) << categoryMap.value("name").toString() << categoryMap.value("level").toString() << categoryMap.value("type").toString(); // } m_fetchingData = false; emit fetchingDataChanged(); } void ServerDebugManager::setLoggingCategoryLevelResponse(int commandId, const QVariantMap ¶ms) { Q_UNUSED(commandId) qCDebug(dcServerDebug()) << "Response for setting logging level" << params; }