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
|
// SPDX-FileCopyrightText: 2016 Kitsune Ral <Kitsune-Ral@users.sf.net>
// SPDX-License-Identifier: LGPL-2.1-or-later
#include "syncjob.h"
using namespace Quotient;
static size_t jobId = 0;
SyncJob::SyncJob(const QString& since, const QString& filter, int timeout,
const QString& presence)
: BaseJob(HttpVerb::Get, QStringLiteral("SyncJob-%1").arg(++jobId),
"_matrix/client/r0/sync")
{
setLoggingCategory(SYNCJOB);
QUrlQuery query;
if (!filter.isEmpty())
query.addQueryItem(QStringLiteral("filter"), filter);
if (!presence.isEmpty())
query.addQueryItem(QStringLiteral("set_presence"), presence);
if (timeout >= 0)
query.addQueryItem(QStringLiteral("timeout"), QString::number(timeout));
if (!since.isEmpty())
query.addQueryItem(QStringLiteral("since"), since);
setRequestQuery(query);
setMaxRetries(std::numeric_limits<int>::max());
}
SyncJob::SyncJob(const QString& since, const Filter& filter, int timeout,
const QString& presence)
: SyncJob(since,
QJsonDocument(toJson(filter)).toJson(QJsonDocument::Compact),
timeout, presence)
{}
BaseJob::Status SyncJob::prepareResult()
{
d.parseJson(jsonData());
if (Q_LIKELY(d.unresolvedRooms().isEmpty()))
return Success;
Q_ASSERT(d.unresolvedRooms().isEmpty());
qCCritical(MAIN).noquote() << "Rooms missing after processing sync "
"response, possibly a bug in SyncData: "
<< d.unresolvedRooms().join(',');
return IncorrectResponse;
}
|