1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
// SPDX-FileCopyrightText: 2019 - 2023 UnionTech Software Technology Co., Ltd.
//
// SPDX-License-Identifier: GPL-3.0-or-later
#include "logviewerservice.h"
#include "logviewerwatcher.h"
#include <DLog>
#include <QCoreApplication>
#include <QDBusConnection>
#include <QDBusError>
#include <QDebug>
#include <QLoggingCategory>
Q_DECLARE_LOGGING_CATEGORY(logService)
//service name
const QString LogViewrServiceName = "com.deepin.logviewer";
//service path
const QString LogViewrPath = "/com/deepin/logviewer";
int main(int argc, char *argv[])
{
//set env otherwise utils excutecmd excute command failed
QString PATH = qgetenv("PATH");
if (PATH.isEmpty()) {
PATH = "/usr/bin";
}
PATH += ":/usr/sbin";
PATH += ":/sbin";
qputenv("PATH", PATH.toLatin1());
qCDebug(logService) << "log-viewer-service start, PATH" << PATH;
QCoreApplication a(argc, argv);
a.setOrganizationName("deepin");
a.setApplicationName("deepin-log-viewer-service");
//#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 8, 0))
#if 0
Dtk::Core::DLogManager::registerJournalAppender();
#ifdef QT_DEBUG
Dtk::Core::DLogManager::registerConsoleAppender();
#endif
#else
QDir dirCheck;
QString LogPath = QString("%1/%2/%3/")
.arg("/var/log")
.arg(qApp->organizationName())
.arg(qApp->applicationName());
if (!dirCheck.exists(LogPath)) {
dirCheck.mkpath(LogPath);
}
QString serviceLogPath=LogPath+QString("%1.log").arg(qApp->applicationName());
Dtk::Core::DLogManager::setlogFilePath(serviceLogPath);
Dtk::Core::DLogManager::registerConsoleAppender();
Dtk::Core::DLogManager::registerFileAppender();
#endif
QDBusConnection systemBus = QDBusConnection::systemBus();
if (!systemBus.registerService(LogViewrServiceName)) {
qCCritical(logService) << "registerService failed:" << systemBus.lastError();
exit(0x0001);
}
LogViewerWatcher watcher;
LogViewerService service;
if (!systemBus.registerObject(LogViewrPath,
&service,
QDBusConnection::ExportAllSlots | QDBusConnection::ExportAllSignals)) {
qCCritical(logService) << "registerObject failed:" << systemBus.lastError();
exit(0x0002);
}
return a.exec();
}
|