summaryrefslogtreecommitdiff
path: root/saltoqd/systemmanager.cpp
blob: bd5a563d76a810c2d0b9b5ac9f0d1677bb72d9f8 (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
#include <time.h>
#include "systemmanager.h"
#include "voicecallmanager.h"

SystemManager::SystemManager(ToqManager *toq) :
	QObject(toq), _toq(toq)
{
	_toq->setEndpointListener(ToqConnection::SystemEndpoint, this);
}

void SystemManager::handleMessage(const ToqConnection::Message &msg)
{
	Q_ASSERT(msg.destination == ToqConnection::SystemEndpoint);
	switch (msg.type) {
	case 0:
		handleGetTimeMessage(msg);
		break;
	case 7:
		handleSilenceMessage(msg);
		break;
	default:
		qWarning() << "Unknown system message" << msg.type;
		break;
	}
}

void SystemManager::handleGetTimeMessage(const ToqConnection::Message &msg)
{
	QJsonObject reply, detail;

	// Seems that QTimeZone is completely broken on Jolla ("timed/localtime")
	time_t now;
	tm now_info;
	time(&now);
	localtime_r(&now, &now_info);

	int offset = now_info.tm_gmtoff;
	// Seems that the watch manually adds 1h if we are on DST.
	if (now_info.tm_isdst) offset -= 3600;

	detail.insert("epoch_time", qint64(now));
	detail.insert("time_zone", offset);
	detail.insert("dst", int(now_info.tm_isdst));

	reply.insert("result", int(0));
	reply.insert("description", QLatin1String("current time"));
	reply.insert("time", detail);

	_toq->sendReply(msg, 0x4000, reply);
}

void SystemManager::handleSilenceMessage(const ToqConnection::Message &msg)
{
	QJsonObject reply;

	reply.insert("result", int(0));
	reply.insert("description", QLatin1String("Set to Silence Mode Request received"));

	VoiceCallManager::setSilentMode(msg.payload.object()["silence_mode"].toInt());

	_toq->sendReply(msg, 0x4007, reply);
}