diff options
Diffstat (limited to 'jobs/syncjob.cpp')
-rw-r--r-- | jobs/syncjob.cpp | 133 |
1 files changed, 0 insertions, 133 deletions
diff --git a/jobs/syncjob.cpp b/jobs/syncjob.cpp deleted file mode 100644 index 435dfd0e..00000000 --- a/jobs/syncjob.cpp +++ /dev/null @@ -1,133 +0,0 @@ -/****************************************************************************** - * Copyright (C) 2016 Felix Rohrbach <kde@fxrh.de> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2.1 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - */ - -#include "syncjob.h" - -#include <QtCore/QElapsedTimer> - -using namespace QMatrixClient; - -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), - QStringLiteral("_matrix/client/r0/sync")) -{ - setLoggingCategory(SYNCJOB); - QUrlQuery query; - if( !filter.isEmpty() ) - query.addQueryItem("filter", filter); - if( !presence.isEmpty() ) - query.addQueryItem("set_presence", presence); - if( timeout >= 0 ) - query.addQueryItem("timeout", QString::number(timeout)); - if( !since.isEmpty() ) - query.addQueryItem("since", since); - setRequestQuery(query); - - setMaxRetries(std::numeric_limits<int>::max()); -} - -QString SyncData::nextBatch() const -{ - return nextBatch_; -} - -SyncDataList&& SyncData::takeRoomData() -{ - return std::move(roomData); -} - -SyncBatch<Event>&& SyncData::takeAccountData() -{ - return std::move(accountData); -} - -BaseJob::Status SyncJob::parseJson(const QJsonDocument& data) -{ - return d.parseJson(data); -} - -BaseJob::Status SyncData::parseJson(const QJsonDocument &data) -{ - QElapsedTimer et; et.start(); - - auto json = data.object(); - nextBatch_ = json.value("next_batch").toString(); - // TODO: presence - accountData.fromJson(json); - - QJsonObject rooms = json.value("rooms").toObject(); - JoinStates::Int ii = 1; // ii is used to make a JoinState value - for (size_t i = 0; i < JoinStateStrings.size(); ++i, ii <<= 1) - { - const auto rs = rooms.value(JoinStateStrings[i]).toObject(); - // We have a Qt container on the right and an STL one on the left - roomData.reserve(static_cast<size_t>(rs.size())); - for(auto roomIt = rs.begin(); roomIt != rs.end(); ++roomIt) - roomData.emplace_back(roomIt.key(), JoinState(ii), - roomIt.value().toObject()); - } - qCDebug(PROFILER) << "*** SyncData::parseJson(): batch with" - << rooms.size() << "room(s) in" << et; - return BaseJob::Success; -} - -const QString SyncRoomData::UnreadCountKey = - QStringLiteral("x-qmatrixclient.unread_count"); - -SyncRoomData::SyncRoomData(const QString& roomId_, JoinState joinState_, - const QJsonObject& room_) - : roomId(roomId_) - , joinState(joinState_) - , state(joinState == JoinState::Invite ? "invite_state" : "state") - , timeline("timeline") - , ephemeral("ephemeral") - , accountData("account_data") -{ - switch (joinState) { - case JoinState::Invite: - state.fromJson(room_); - break; - case JoinState::Join: - state.fromJson(room_); - timeline.fromJson(room_); - ephemeral.fromJson(room_); - accountData.fromJson(room_); - break; - case JoinState::Leave: - state.fromJson(room_); - timeline.fromJson(room_); - break; - default: - qCWarning(SYNCJOB) << "SyncRoomData: Unknown JoinState value, ignoring:" << int(joinState); - } - - auto timelineJson = room_.value("timeline").toObject(); - timelineLimited = timelineJson.value("limited").toBool(); - timelinePrevBatch = timelineJson.value("prev_batch").toString(); - - auto unreadJson = room_.value("unread_notifications").toObject(); - unreadCount = unreadJson.value(UnreadCountKey).toInt(-2); - highlightCount = unreadJson.value("highlight_count").toInt(); - notificationCount = unreadJson.value("notification_count").toInt(); - if (highlightCount > 0 || notificationCount > 0) - qCDebug(SYNCJOB) << "Highlights: " << highlightCount - << " Notifications:" << notificationCount; -} |