Fix two null pointer dereferences

This commit is contained in:
Kevin Wolf
2023-02-20 19:00:54 +00:00
committed by Tobias Fella
parent 2dd3197beb
commit 084b89f3dc
2 changed files with 7 additions and 1 deletions

View File

@@ -229,10 +229,13 @@ void RoomListModel::handleNotifications()
continue;
}
oldNotifications += notification["event"].toObject()["event_id"].toString();
auto room = m_connection->room(notification["room_id"].toString());
auto currentRoom = RoomManager::instance().currentRoom();
bool roomIsActive = currentRoom && room->id() == currentRoom->id();
// If room exists, room is NOT active OR the application is NOT active, show notification
if (room && !(room->id() == RoomManager::instance().currentRoom()->id() && QGuiApplication::applicationState() == Qt::ApplicationActive)) {
if (room && !(roomIsActive && QGuiApplication::applicationState() == Qt::ApplicationActive)) {
// The room might have been deleted (for example rejected invitation).
auto sender = room->user(notification["event"].toObject()["sender"].toString());