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 76 77 78 79 80 81 82 83
|
/*
* Copyright (C) 2019 ~ 2020 UnionTech Software Technology Co.,Ltd
*
* Author: linxun <linxun@uniontech.com>
* Maintainer: linxun <linxun@uniontech.com>
* This program 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
* any later version.
*
* This program 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 program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "logviewerservice.h"
#include "logviewerwatcher.h"
#include <DLog>
#include <QCoreApplication>
#include <QDBusConnection>
#include <QDBusError>
#include <QDebug>
//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");
qDebug() << "main start" << PATH;
if (PATH.isEmpty()) {
PATH = "/usr/bin";
}
PATH += ":/usr/sbin";
PATH += ":/sbin";
qputenv("PATH", PATH.toLatin1());
QCoreApplication a(argc, argv);
a.setOrganizationName("deepin");
a.setApplicationName("deepin-log-viewer-service");
QDir dirCheck;
QString LogPath = QString("%1/%2/%3/Log/")
.arg("/var/log")
.arg(qApp->organizationName())
.arg(qApp->applicationName());
if (!dirCheck.exists(LogPath)) {
dirCheck.mkpath(LogPath);
}
QString serviceLogPath=LogPath+QString("deepin-log-viewer-service.log");
Dtk::Core::DLogManager::setlogFilePath(serviceLogPath);
Dtk::Core::DLogManager::registerConsoleAppender();
Dtk::Core::DLogManager::registerFileAppender();
QDBusConnection systemBus = QDBusConnection::systemBus();
if (!systemBus.registerService(LogViewrServiceName)) {
qCritical() << "registerService failed:" << systemBus.lastError();
exit(0x0001);
}
LogViewerWatcher watcher;
LogViewerService service;
//service.getFileInfo("lpr");
//service.readLog("etc/apt/sources.list");
qDebug() << "systemBus.registerService success" << Dtk::Core::DLogManager::getlogFilePath();
if (!systemBus.registerObject(LogViewrPath,
&service,
QDBusConnection::ExportAllSlots | QDBusConnection::ExportAllSignals)) {
qCritical() << "registerObject failed:" << systemBus.lastError();
exit(0x0002);
}
return a.exec();
}
|