/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright (C) 2018 Simon Stürz * * * * This file is part of nymea-networkmanager. * * * * nymea-networkmanager 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. * * * * nymea-networkmanager 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 nymea-networkmanager. If not, see . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include #include #include #include "core.h" #include "application.h" #include "loggingcategories.h" static const char *const normal = "\033[0m"; static const char *const warning = "\e[33m"; static const char *const error = "\e[31m"; static QHash s_loggingFilters; static void loggingCategoryFilter(QLoggingCategory *category) { // If this is a known category if (s_loggingFilters.contains(category->categoryName())) { category->setEnabled(QtDebugMsg, s_loggingFilters.value(category->categoryName())); category->setEnabled(QtWarningMsg, true); category->setEnabled(QtCriticalMsg, true); category->setEnabled(QtFatalMsg, true); } else { //Disable default debug messages, print only >= warnings category->setEnabled(QtDebugMsg, false); category->setEnabled(QtWarningMsg, true); category->setEnabled(QtCriticalMsg, true); category->setEnabled(QtFatalMsg, true); } } static void consoleLogHandler(QtMsgType type, const QMessageLogContext& context, const QString& message) { switch (type) { case QtInfoMsg: fprintf(stdout, " I | %s: %s\n", context.category, message.toUtf8().data()); break; case QtDebugMsg: fprintf(stdout, " I | %s: %s\n", context.category, message.toUtf8().data()); break; case QtWarningMsg: fprintf(stdout, "%s W | %s: %s%s\n", warning, context.category, message.toUtf8().data(), normal); break; case QtCriticalMsg: fprintf(stdout, "%s C | %s: %s%s\n", error, context.category, message.toUtf8().data(), normal); break; case QtFatalMsg: fprintf(stdout, "%s F | %s: %s%s\n", error, context.category, message.toUtf8().data(), normal); break; } fflush(stdout); } int main(int argc, char *argv[]) { qInstallMessageHandler(consoleLogHandler); Application application(argc, argv); application.setApplicationName("nymea-networkmanager"); application.setOrganizationName("nymea"); application.setApplicationVersion("0.1.0"); // Command line parser QCommandLineParser parser; parser.addHelpOption(); parser.addVersionOption(); parser.setApplicationDescription(QString("\nThis daemon allows to configure a wifi network using a bluetooth low energy connection." \ "\n\nCopyright %1 2018 Simon Stürz ").arg(QChar(0xA9))); QCommandLineOption debugOption(QStringList() << "d" << "debug", "Enable more debug output."); parser.addOption(debugOption); QCommandLineOption advertiseNameOption(QStringList() << "a" << "advertise-name", "The name of the bluetooth server. Default \"nymea\".", "NAME"); advertiseNameOption.setDefaultValue("nymea"); parser.addOption(advertiseNameOption); QCommandLineOption platformNameOption(QStringList() << "p" << "platform-name", "The name of the platform this daemon is running. Default \"nymea-box\".", "NAME"); platformNameOption.setDefaultValue("nymea-box"); parser.addOption(platformNameOption); QCommandLineOption timeoutOption(QStringList() << "t" << "timeout", "The timeout of the bluetooth server. Minimum value is 10. Default \"60\".", "SECONDS"); timeoutOption.setDefaultValue("60"); parser.addOption(timeoutOption); QCommandLineOption modeOption(QStringList() << "m" << "mode", "Run the daemon in a specific mode. Default \"offline\".\n\n" \ "- offline: this mode starts the bluetooth server once the device is offline and not connected to any LAN network.\n\n" \ "- always: this mode enables the bluetooth server as long the application is running.\n\n" \ "- start: this mode starts the bluetooth server for 3 minutes on start and shuts down after a connection.\n\n", "offline | always | start"); parser.addOption(modeOption); QCommandLineOption testingOption(QStringList() << "t" << "testing", "Advertise the bluetoothserver alyways for testing."); parser.addOption(testingOption); parser.process(application); // Enable debug categories s_loggingFilters.insert("Application", true); s_loggingFilters.insert("BluetoothServer", parser.isSet(debugOption)); s_loggingFilters.insert("NetworkManager", parser.isSet(debugOption) ); s_loggingFilters.insert("NymeaService", parser.isSet(debugOption)); QLoggingCategory::installFilter(loggingCategoryFilter); bool timeoutValueOk = false; int timeout = parser.value(timeoutOption).toInt(&timeoutValueOk); if (!timeoutValueOk) { qCCritical(dcApplication()) << QString("Invalid timeout value passed: \"%1\". Please pass an integer >= 10").arg(parser.value(timeoutOption)); parser.showHelp(1); } if (timeout < 10) { qCCritical(dcApplication()) << QString("Invalid timeout value passed: \"%1\". The minimal timeout is 10 [s].").arg(parser.value(timeoutOption)); parser.showHelp(1); } Core::Mode mode = Core::ModeOffline; if (parser.isSet(modeOption)) { if (parser.value(modeOption).toLower() == "offline") { mode = Core::ModeOffline; } else if (parser.value(modeOption).toLower() == "always") { mode = Core::ModeAlways; } else if (parser.value(modeOption).toLower() == "start") { mode = Core::ModeStart; } else { qCWarning(dcApplication()).noquote() << QString("The given mode \"%1\" does not match the allowed modes.").arg(parser.value(modeOption)); parser.showHelp(1); } } qCDebug(dcApplication()) << "====================================="; qCDebug(dcApplication()) << "Starting nymea-networkmanager" << application.applicationVersion(); qCDebug(dcApplication()) << "====================================="; qCDebug(dcApplication()) << "Advertising name:" << parser.value(advertiseNameOption); qCDebug(dcApplication()) << "Platform name:" << parser.value(platformNameOption); qCDebug(dcApplication()) << "Mode:" << parser.value(modeOption); qCDebug(dcApplication()) << "Timeout:" << parser.value(timeoutOption); // Start core Core::instance()->setMode(mode); Core::instance()->setAdvertisingTimeout(timeout); Core::instance()->setAdvertiseName(parser.value(advertiseNameOption)); Core::instance()->setPlatformName(parser.value(platformNameOption)); Core::instance()->setTestingEnabled(parser.isSet(testingOption)); Core::instance()->run(); return application.exec(); }