/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 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 "noninteractivemonitor.h" #include "utils.h" #include #include NonInteractiveMonitor::NonInteractiveMonitor(const QString &serverName, bool jsonMode, bool printAll, QObject *parent) : QObject{parent}, m_jsonMode{jsonMode} { m_monitorClient = new MonitorClient(serverName, m_jsonMode, this); m_monitorClient->setPrintAll(printAll); connect(m_monitorClient, &MonitorClient::connected, this, &NonInteractiveMonitor::onConnected); m_monitorClient->connectMonitor(); } void NonInteractiveMonitor::onConnected() { connect(m_monitorClient, &MonitorClient::dataReady, this, [](const QVariantMap &dataMap){ QVariantMap tunnelProxyMap = dataMap.value("tunnelProxyStatistic").toMap(); qStdOut() << "---------------------------------------------------------------------\n"; qStdOut() << "Server name:" << dataMap.value("serverName", "-").toString() << "\n"; qStdOut() << "Server version:" << dataMap.value("serverVersion", "-").toString() << "\n"; qStdOut() << "API version:" << dataMap.value("apiVersion", "-").toString() << "\n"; qStdOut() << "Total client count:" << tunnelProxyMap.value("totalClientCount", 0).toInt() << "\n"; qStdOut() << "Server connections:" << tunnelProxyMap.value("serverConnectionsCount", 0).toInt() << "\n"; qStdOut() << "Client connections:" << tunnelProxyMap.value("clientConnectionsCount", 0).toInt() << "\n"; qStdOut() << "Data troughput:" << Utils::humanReadableTraffic(tunnelProxyMap.value("troughput", 0).toInt()) + " / s" << "\n"; qStdOut() << "---------------------------------------------------------------------" << "\n"; QVariantMap transportsMap = tunnelProxyMap.value("transports").toMap(); foreach(const QString &transportInterface, transportsMap.keys()) { qStdOut() << "Connections on " << transportInterface << ": " << transportsMap.value(transportInterface).toInt() << "\n"; } qStdOut() << "---------------------------------------------------------------------" << "\n"; foreach (const QVariant &serverVariant, tunnelProxyMap.value("tunnelConnections").toList()) { QVariantMap serverMap = serverVariant.toMap(); QVariantList clientList = serverMap.value("clientConnections").toList(); // Server line QString serverConnectionTime = QDateTime::fromMSecsSinceEpoch(serverMap.value("timestamp").toLongLong() * 1000).toString("dd.MM.yyyy hh:mm:ss"); QString serverLinePrint; if (clientList.isEmpty()) { serverLinePrint.prepend("├──"); } else { serverLinePrint.prepend("├┬─"); } serverLinePrint += QString("%1 | %2 | %3 RX: %4 TX: %5 | %6") .arg(serverConnectionTime) .arg(serverMap.value("serverUuid").toString()) .arg(serverMap.value("address").toString(), - 15) .arg(Utils::humanReadableTraffic(serverMap.value("rxDataCount").toInt()), - 9) .arg(Utils::humanReadableTraffic(serverMap.value("txDataCount").toInt()), - 9) .arg(serverMap.value("name").toString()); qStdOut() << serverLinePrint << "\n"; for (int cc = 0; cc < clientList.count(); cc++) { QVariantMap clientMap = clientList.at(cc).toMap(); QString clientLinePrint; if (cc >= clientList.count() - 1) { clientLinePrint.append("│└─"); } else { clientLinePrint.prepend("│├─"); } clientLinePrint += QString("%1 | %2 | %3 RX: %4 TX: %5 | %6") .arg(QDateTime::fromMSecsSinceEpoch(clientMap.value("timestamp").toLongLong() * 1000).toString("dd.MM.yyyy hh:mm:ss")) .arg(clientMap.value("clientUuid").toString()) .arg(clientMap.value("address").toString(), - 15) .arg(Utils::humanReadableTraffic(serverMap.value("rxDataCount").toInt()), - 9) .arg(Utils::humanReadableTraffic(serverMap.value("txDataCount").toInt()), - 9) .arg(clientMap.value("name").toString(), -30); qStdOut() << clientLinePrint << "\n"; } } exit(0); }); m_monitorClient->refresh(); }