mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-21 20:45:51 +03:00
Merge pull request #6970 from nextcloud/bugfix/prevent-renotification
Make sure we do not renotify notifications when we have received the same etag as during the last check
This commit is contained in:
commit
4cd63d89d3
2 changed files with 12 additions and 0 deletions
|
@ -78,6 +78,17 @@ void ServerNotificationHandler::slotNotificationsReceived(const QJsonDocument &j
|
|||
return;
|
||||
}
|
||||
|
||||
// In theory the server should five us a 304 Not Modified if there are no new notifications.
|
||||
// But in practice, the server doesn't always do that. So we need to compare the ETag headers.
|
||||
const auto postFetchEtagHeader = _accountState->notificationsEtagResponseHeader();
|
||||
if (!_preFetchEtagHeader.isEmpty() || _preFetchEtagHeader == postFetchEtagHeader) {
|
||||
qCInfo(lcServerNotification) << "Notifications ETag header is the same as before, no new notifications.";
|
||||
deleteLater();
|
||||
emit jobFinished();
|
||||
return;
|
||||
}
|
||||
_preFetchEtagHeader = postFetchEtagHeader;
|
||||
|
||||
auto notifies = json.object().value("ocs").toObject().value("data").toArray();
|
||||
|
||||
auto *ai = qvariant_cast<AccountState *>(sender()->property(propertyAccountStateC));
|
||||
|
|
|
@ -30,6 +30,7 @@ private slots:
|
|||
private:
|
||||
QPointer<JsonApiJob> _notificationJob;
|
||||
AccountState *_accountState;
|
||||
QString _preFetchEtagHeader;
|
||||
};
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue