summaryrefslogtreecommitdiffstats
path: root/services/qt4/dbus-info-service/service.cpp
blob: 150df16caf582698b1010362312f4bea37e1d65d (plain)
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

#include <QtCore/QDateTime>
#include <QtCore/QTextStream>
#include <QtCore/QStringList>
#include <QtDBus/QDBusMetaType>

#include "service.h"

SystemInfo::SystemInfo(QObject *parent)
	: QDBusAbstractAdaptor(parent),
	  m_syslog(200),
	  m_dbusMonitor(50),
	  m_syslogFile("/var/log/syslog")
{
	if (m_syslogFile.open(QIODevice::ReadOnly)) {
		m_syslog.setDevice(&m_syslogFile);
	}

	m_dbusMonitorProcess.start("/usr/bin/dbus-monitor");
	m_dbusMonitor.setDevice(&m_dbusMonitorProcess);

	qDBusRegisterMetaType<QMap<QString, QVariant> >();
	startTimer(1000);
}

uint SystemInfo::Date()
{
	return QDateTime::currentDateTime().toTime_t();
}

void SystemInfo::Noop()
{
}

QString SystemInfo::Ping(QString text)
{
	return text;
}

int SystemInfo::CpuLoad()
{
	return m_cpuLoad;
}

void SystemInfo::timerEvent(QTimerEvent *)
{
	int cpuCount = -1;
	QFile file("/proc/stat");
	if (!file.open(QIODevice::ReadOnly))
		return;
	QTextStream stream(&file);
	do {
		QString line = stream.readLine();
		const QStringList list = line.trimmed().split(" ",  QString::SkipEmptyParts);
		if (list[0].left(3) == "cpu")
			++cpuCount;
		if ((list.count() < 6) || list[0] != "cpu")
			continue;

		int value = 0;
		for (int i = 0; i < list.length()-1; ++i) {
			if (i == 3) // idle
				continue;
			value += list[i+1].toInt();
		}
		m_cpuLoad = value - m_oldStat;
		m_oldStat = value;
	} while(!stream.atEnd());
	m_cpuLoad /= cpuCount;

	m_syslog.update();
	m_dbusMonitor.update();
}

Q_DECLARE_METATYPE(QStringList)

QMap<QString, QVariant> SystemInfo::Syslog(int last)
{
	QMap<QString, QVariant> ret;

	m_syslog.update();

	ret["last"] = QVariant(m_syslog.last());
	ret["data"] = QVariant(m_syslog.get(last));
	return ret;
}

QMap<QString, QVariant> SystemInfo::DBusMonitor(int last)
{
	QMap<QString, QVariant> ret;

	m_dbusMonitor.update();

	ret["last"] = QVariant(m_dbusMonitor.last());
	ret["data"] = QVariant(m_dbusMonitor.get(last));
	return ret;
}