X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.cpp;h=3176ec4b05318d8a8f472499504fc43f98cbda70;hp=1548085cd69b6b5abfa50b17a662c5be3c5a7c2b;hb=8ec76e512d20ce5d1dc76de556bb98a06b75d695;hpb=ef1ee865c342a16daab514a99110f56150ea95e7 diff --git a/src/core/sqlitestorage.cpp b/src/core/sqlitestorage.cpp index 1548085c..3176ec4b 100644 --- a/src/core/sqlitestorage.cpp +++ b/src/core/sqlitestorage.cpp @@ -558,26 +558,26 @@ BufferId SqliteStorage::renameBuffer(const UserId &user, const NetworkId &networ return BufferId(); } -void SqliteStorage::setBufferLastSeen(UserId user, const BufferId &bufferId, const QDateTime &seenDate) { +void SqliteStorage::setBufferLastSeenMsg(UserId user, const BufferId &bufferId, const MsgId &msgId) { QSqlQuery *query = cachedQuery("update_buffer_lastseen"); query->bindValue(":userid", user.toInt()); query->bindValue(":bufferid", bufferId.toInt()); - query->bindValue(":lastseen", seenDate.toTime_t()); + query->bindValue(":lastseenmsgid", msgId.toInt()); query->exec(); watchQuery(query); } -QHash SqliteStorage::bufferLastSeenDates(UserId user) { - QHash lastSeenHash; +QHash SqliteStorage::bufferLastSeenMsgIds(UserId user) { + QHash lastSeenHash; QSqlQuery query(logDb()); - query.prepare(queryString("select_buffer_lastseen_dates")); + query.prepare(queryString("select_buffer_lastseen_messages")); query.bindValue(":userid", user.toInt()); query.exec(); if(!watchQuery(&query)) return lastSeenHash; while(query.next()) { - lastSeenHash[query.value(0).toInt()] = QDateTime::fromTime_t(query.value(1).toUInt()); + lastSeenHash[query.value(0).toInt()] = query.value(1).toInt(); } return lastSeenHash; } @@ -612,11 +612,16 @@ MsgId SqliteStorage::logMessage(Message msg) { return msgId; } -QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int offset) { +QList SqliteStorage::requestMsgs(UserId user, BufferId bufferId, int lastmsgs, int offset) { QList messagelist; + + BufferInfo bufferInfo = getBufferInfo(user, bufferId); + if(!bufferInfo.isValid()) + return messagelist; + // we have to determine the real offset first QSqlQuery *offsetQuery = cachedQuery("select_messagesOffset"); - offsetQuery->bindValue(":bufferid", buffer.bufferId().toInt()); + offsetQuery->bindValue(":bufferid", bufferId.toInt()); offsetQuery->bindValue(":messageid", offset); offsetQuery->exec(); offsetQuery->first(); @@ -624,7 +629,7 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int o // now let's select the messages QSqlQuery *msgQuery = cachedQuery("select_messages"); - msgQuery->bindValue(":bufferid", buffer.bufferId().toInt()); + msgQuery->bindValue(":bufferid", bufferId.toInt()); msgQuery->bindValue(":limit", lastmsgs); msgQuery->bindValue(":offset", offset); msgQuery->exec(); @@ -633,7 +638,7 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int o while(msgQuery->next()) { Message msg(QDateTime::fromTime_t(msgQuery->value(1).toInt()), - buffer, + bufferInfo, (Message::Type)msgQuery->value(2).toUInt(), msgQuery->value(5).toString(), msgQuery->value(4).toString(), @@ -645,11 +650,16 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int o } -QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, int offset) { +QList SqliteStorage::requestMsgs(UserId user, BufferId bufferId, QDateTime since, int offset) { QList messagelist; + + BufferInfo bufferInfo = getBufferInfo(user, bufferId); + if(!bufferInfo.isValid()) + return messagelist; + // we have to determine the real offset first QSqlQuery *offsetQuery = cachedQuery("select_messagesSinceOffset"); - offsetQuery->bindValue(":bufferid", buffer.bufferId().toInt()); + offsetQuery->bindValue(":bufferid", bufferId.toInt()); offsetQuery->bindValue(":since", since.toTime_t()); offsetQuery->exec(); offsetQuery->first(); @@ -657,7 +667,7 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, in // now let's select the messages QSqlQuery *msgQuery = cachedQuery("select_messagesSince"); - msgQuery->bindValue(":bufferid", buffer.bufferId().toInt()); + msgQuery->bindValue(":bufferid", bufferId.toInt()); msgQuery->bindValue(":since", since.toTime_t()); msgQuery->bindValue(":offset", offset); msgQuery->exec(); @@ -666,7 +676,7 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, in while(msgQuery->next()) { Message msg(QDateTime::fromTime_t(msgQuery->value(1).toInt()), - buffer, + bufferInfo, (Message::Type)msgQuery->value(2).toUInt(), msgQuery->value(5).toString(), msgQuery->value(4).toString(), @@ -679,10 +689,15 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, in } -QList SqliteStorage::requestMsgRange(BufferInfo buffer, int first, int last) { +QList SqliteStorage::requestMsgRange(UserId user, BufferId bufferId, int first, int last) { QList messagelist; + + BufferInfo bufferInfo = getBufferInfo(user, bufferId); + if(!bufferInfo.isValid()) + return messagelist; + QSqlQuery *rangeQuery = cachedQuery("select_messageRange"); - rangeQuery->bindValue(":bufferid", buffer.bufferId().toInt()); + rangeQuery->bindValue(":bufferid", bufferId.toInt()); rangeQuery->bindValue(":firstmsg", first); rangeQuery->bindValue(":lastmsg", last); rangeQuery->exec(); @@ -691,7 +706,7 @@ QList SqliteStorage::requestMsgRange(BufferInfo buffer, int first, int while(rangeQuery->next()) { Message msg(QDateTime::fromTime_t(rangeQuery->value(1).toInt()), - buffer, + bufferInfo, (Message::Type)rangeQuery->value(2).toUInt(), rangeQuery->value(5).toString(), rangeQuery->value(4).toString(), @@ -731,7 +746,7 @@ bool SqliteStorage::init(const QVariantMap &settings) { return false; if(!checkMigratedQuery.first()) - return false; + return true; // table is empty -> no work to be done QString passType = checkMigratedQuery.value(0).toString().toLower(); if(passType == "text")