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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/**
* Copyright (C) 2014, Pelagicore
*
* Author: Jonatan PĂ„lsson <jonatan.palsson@pelagicore.com>
*
* This file is part of the GENIVI project Browser Proof-Of-Concept
* For further information, see http://genivi.org/
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#include <QDBusMetaType>
#include <QtQml>
#include <QDBusReply>
#include "errorloggerdbus.h"
#include "../common/browserdefs.h"
ErrorLoggerDbus::ErrorLoggerDbus(QObject *parent) :
QObject(parent), m_instanceId("1")
{
qDebug() << __PRETTY_FUNCTION__;
registertypes();
}
void ErrorLoggerDbus::registertypes() {
qDBusRegisterMetaType<conn::brw::ErrorItemList>();
qDBusRegisterMetaType<conn::brw::ErrorItem>();
qDBusRegisterMetaType<conn::brw::ERROR_SORT_TYPE>();
qDBusRegisterMetaType<conn::brw::ERROR_IDS>();
}
void ErrorLoggerDbus::connectdbussession(QString id) {
qDebug() << __PRETTY_FUNCTION__ << id;
m_instanceId = id;
QString *dbusservicename = new QString("genivi.poc.browser" + m_instanceId);
m_errorlogger = new conn::brw::IErrorLogger(*dbusservicename, "/Browser/IErrorLogger",
QDBusConnection::sessionBus(), this);
if(!m_errorlogger->isValid()) {
qDebug() << "failed create object /Browser/IErrorLogger";
}
connect(m_errorlogger, SIGNAL(onNewErrorItem(conn::brw::ErrorItem)),
this, SIGNAL(onNewErrorItem(conn::brw::ErrorItem)));
connect(m_errorlogger, SIGNAL(onErrorListChanged(void)),
this, SIGNAL(onErrorListChanged(void)));
}
uint ErrorLoggerDbus::getItemsCount(qlonglong start, qlonglong end) {
qDebug() << __PRETTY_FUNCTION__;
uint ret = 0;
if (!m_errorlogger){
qDebug() << "ErrorLogger not initialized, call connectdbussession first";
return ret;
}
QDBusReply<uint> reply = m_errorlogger->getItemsCount(start, end);
if(reply.isValid()) {
ret = reply.value();
qDebug() << "ERROR_IDS " << ret;
} else {
QDBusError error = reply.error();
qDebug() << "ERROR " << error.name() << error.message();
}
return ret;
}
conn::brw::ErrorItemList ErrorLoggerDbus::getItems(qlonglong timeFrom,
qlonglong timeTo,
conn::brw::ERROR_SORT_TYPE type,
uint startIndex,
uint itemsCount) {
qDebug() << __PRETTY_FUNCTION__;
conn::brw::ErrorItemList list;
if (!m_errorlogger){
qDebug() << "ErrorLogger not initialized, call connectdbussession first";
return list;
}
QDBusReply<conn::brw::ERROR_IDS> reply =
m_errorlogger->getItems(timeFrom, timeTo, type, startIndex, itemsCount, list);
if(reply.isValid()) {
conn::brw::ERROR_IDS ret;
ret = reply.value();
qDebug() << "ERROR_IDS " << ret;
} else {
QDBusError error = reply.error();
qDebug() << "ERROR " << error.name() << error.message();
}
for (int i = 0; i < list.size(); i++) {
qDebug() << "Error item:" << list.at(i).strDescription;
}
return list;
}
|