X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.cpp;h=7bfbb1a1f55c1a53fe0267e474e16ec181b9b3f4;hp=0cde45d10bc6a2820e7a0490b28efd0fb1edef59;hb=a0445f05a1e9aee1a82727a2847dd7ffe81de224;hpb=d28b9ec38b6ea0bc473200fc2f1e65abd1b56bd6 diff --git a/src/core/sqlitestorage.cpp b/src/core/sqlitestorage.cpp index 0cde45d1..7bfbb1a1 100644 --- a/src/core/sqlitestorage.cpp +++ b/src/core/sqlitestorage.cpp @@ -21,9 +21,10 @@ #include "sqlitestorage.h" #include - #include +#include "network.h" + SqliteStorage::SqliteStorage(QObject *parent) : AbstractSqlStorage(parent) { @@ -75,7 +76,7 @@ UserId SqliteStorage::addUser(const QString &user, const QString &password) { query.bindValue(":username", user); query.exec(); query.first(); - UserId uid = query.value(0).toUInt(); + UserId uid = query.value(0).toInt(); emit userAdded(uid, user); return uid; } @@ -86,7 +87,7 @@ void SqliteStorage::updateUser(UserId user, const QString &password) { QSqlQuery query(logDb()); query.prepare(queryString("update_userpassword")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.bindValue(":password", cryptopass); query.exec(); } @@ -94,7 +95,7 @@ void SqliteStorage::updateUser(UserId user, const QString &password) { void SqliteStorage::renameUser(UserId user, const QString &newName) { QSqlQuery query(logDb()); query.prepare(queryString("update_username")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.bindValue(":username", newName); query.exec(); emit userRenamed(user, newName); @@ -111,7 +112,7 @@ UserId SqliteStorage::validateUser(const QString &user, const QString &password) query.exec(); if(query.first()) { - return query.value(0).toUInt(); + return query.value(0).toInt(); } else { return 0; } @@ -120,97 +121,89 @@ UserId SqliteStorage::validateUser(const QString &user, const QString &password) void SqliteStorage::delUser(UserId user) { QSqlQuery query(logDb()); query.prepare(queryString("delete_backlog_by_uid")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.exec(); query.prepare(queryString("delete_buffers_by_uid")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.exec(); query.prepare(queryString("delete_networks_by_uid")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.exec(); query.prepare(queryString("delete_quasseluser")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.exec(); // I hate the lack of foreign keys and on delete cascade... :( emit userRemoved(user); } -void SqliteStorage::createBuffer(UserId user, const QString &network, const QString &buffer) { - QSqlQuery *createBufferQuery = cachedQuery("insert_buffer"); - createBufferQuery->bindValue(":userid", user); - createBufferQuery->bindValue(":userid2", user); // Qt can't handle same placeholder twice (maybe sqlites fault) - createBufferQuery->bindValue(":networkname", network); - createBufferQuery->bindValue(":buffername", buffer); - createBufferQuery->exec(); - - if(createBufferQuery->lastError().isValid()) { - if(createBufferQuery->lastError().number() == 19) { // Null Constraint violation - QSqlQuery *createNetworkQuery = cachedQuery("insert_network"); - createNetworkQuery->bindValue(":userid", user); - createNetworkQuery->bindValue(":networkname", network); - createNetworkQuery->exec(); - createBufferQuery->exec(); - Q_ASSERT(!createNetworkQuery->lastError().isValid()); - Q_ASSERT(!createBufferQuery->lastError().isValid()); - } else { - // do panic! - qDebug() << "failed to create Buffer: ErrNo:" << createBufferQuery->lastError().number() << "ErrMsg:" << createBufferQuery->lastError().text(); - Q_ASSERT(false); - } +NetworkId SqliteStorage::createNetworkId(UserId user, const NetworkInfo &info) { + NetworkId networkId; + QSqlQuery query(logDb()); + query.prepare(queryString("insert_network")); + query.bindValue(":userid", user.toInt()); + query.bindValue(":networkname", info.networkName); + query.exec(); + + networkId = getNetworkId(user, info.networkName); + if(!networkId.isValid()) { + watchQuery(&query); } + return networkId; } NetworkId SqliteStorage::getNetworkId(UserId user, const QString &network) { QSqlQuery query(logDb()); query.prepare("SELECT networkid FROM network " "WHERE userid = :userid AND networkname = :networkname"); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.bindValue(":networkname", network); query.exec(); if(query.first()) - return query.value(0).value(); - else { - createBuffer(user, network, ""); - query.exec(); - if(query.first()) - return query.value(0).value(); - else { - qWarning() << "NETWORK NOT FOUND:" << network << "for User:" << user; - return 0; - } - } + return query.value(0).toInt(); + else + return NetworkId(); } -BufferInfo SqliteStorage::getBufferInfo(UserId user, const QString &network, const QString &buffer) { - BufferInfo bufferid; - // TODO: get rid of this hackaround - NetworkId networkId = getNetworkId(user, network); - - QSqlQuery *getBufferInfoQuery = cachedQuery("select_bufferByName"); - getBufferInfoQuery->bindValue(":networkname", network); - getBufferInfoQuery->bindValue(":userid", user); - getBufferInfoQuery->bindValue(":userid2", user); // Qt can't handle same placeholder twice... though I guess it's sqlites fault - getBufferInfoQuery->bindValue(":buffername", buffer); - getBufferInfoQuery->exec(); - - if(!getBufferInfoQuery->first()) { - createBuffer(user, network, buffer); - getBufferInfoQuery->exec(); - if(getBufferInfoQuery->first()) { - bufferid = BufferInfo(getBufferInfoQuery->value(0).value(), networkId, 0, network, buffer); - emit bufferInfoUpdated(user, bufferid); +void SqliteStorage::createBuffer(UserId user, const NetworkId &networkId, const QString &buffer) { + QSqlQuery *query = cachedQuery("insert_buffer"); + query->bindValue(":userid", user.toInt()); + query->bindValue(":networkid", networkId.toInt()); + query->bindValue(":buffername", buffer); + query->exec(); + + watchQuery(query); +} + +BufferInfo SqliteStorage::getBufferInfo(UserId user, const NetworkId &networkId, const QString &buffer) { + QSqlQuery *query = cachedQuery("select_bufferByName"); + query->bindValue(":networkid", networkId.toInt()); + query->bindValue(":userid", user.toInt()); + query->bindValue(":buffername", buffer); + query->exec(); + + if(!query->first()) { + createBuffer(user, networkId, buffer); + query->exec(); + if(!query->first()) { + watchQuery(query); + qWarning() << "unable to create BufferInfo for:" << user << networkId << buffer; + return BufferInfo(); } - } else { - bufferid = BufferInfo(getBufferInfoQuery->value(0).value(), networkId, 0, network, buffer); } - Q_ASSERT(!getBufferInfoQuery->next()); + BufferInfo bufferInfo = BufferInfo(query->value(0).toInt(), networkId, 0, buffer); + if(query->next()) { + qWarning() << "SqliteStorage::getBufferInfo(): received more then one Buffer!"; + qWarning() << " Query:" << query->lastQuery(); + qWarning() << " bound Values:" << query->boundValues(); + Q_ASSERT(false); + } - return bufferid; + return bufferInfo; } QList SqliteStorage::requestBuffers(UserId user, QDateTime since) { @@ -221,13 +214,13 @@ QList SqliteStorage::requestBuffers(UserId user, QDateTime since) { QList bufferlist; QSqlQuery query(logDb()); query.prepare(queryString("select_buffers")); - query.bindValue(":userid", user); + query.bindValue(":userid", user.toInt()); query.bindValue(":time", time); query.exec(); watchQuery(&query); while(query.next()) { - bufferlist << BufferInfo(query.value(0).value(), query.value(2).value(), 0, query.value(3).toString(), query.value(1).toString()); + bufferlist << BufferInfo(query.value(0).toInt(), query.value(2).toInt(), 0, query.value(1).toString()); } return bufferlist; } @@ -235,7 +228,7 @@ QList SqliteStorage::requestBuffers(UserId user, QDateTime since) { MsgId SqliteStorage::logMessage(Message msg) { QSqlQuery *logMessageQuery = cachedQuery("insert_message"); logMessageQuery->bindValue(":time", msg.timestamp().toTime_t()); - logMessageQuery->bindValue(":bufferid", msg.buffer().uid()); + logMessageQuery->bindValue(":bufferid", msg.buffer().uid().toInt()); logMessageQuery->bindValue(":type", msg.type()); logMessageQuery->bindValue(":flags", msg.flags()); logMessageQuery->bindValue(":sender", msg.sender()); @@ -259,13 +252,13 @@ MsgId SqliteStorage::logMessage(Message msg) { QSqlQuery *getLastMessageIdQuery = cachedQuery("select_lastMessage"); getLastMessageIdQuery->bindValue(":time", msg.timestamp().toTime_t()); - getLastMessageIdQuery->bindValue(":bufferid", msg.buffer().uid()); + getLastMessageIdQuery->bindValue(":bufferid", msg.buffer().uid().toInt()); getLastMessageIdQuery->bindValue(":type", msg.type()); getLastMessageIdQuery->bindValue(":sender", msg.sender()); getLastMessageIdQuery->exec(); if(getLastMessageIdQuery->first()) { - return getLastMessageIdQuery->value(0).value(); + return getLastMessageIdQuery->value(0).toInt(); } else { // somethin went wrong... :( qDebug() << getLastMessageIdQuery->lastQuery() << "time/bufferid/type/sender:" << msg.timestamp().toTime_t() << msg.buffer().uid() << msg.type() << msg.sender(); Q_ASSERT(false); @@ -276,28 +269,30 @@ MsgId SqliteStorage::logMessage(Message msg) { QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int offset) { QList messagelist; // we have to determine the real offset first - QSqlQuery *requestMsgsOffsetQuery = cachedQuery("select_messagesOffset"); - requestMsgsOffsetQuery->bindValue(":bufferid", buffer.uid()); - requestMsgsOffsetQuery->bindValue(":messageid", offset); - requestMsgsOffsetQuery->exec(); - requestMsgsOffsetQuery->first(); - offset = requestMsgsOffsetQuery->value(0).toInt(); + QSqlQuery *offsetQuery = cachedQuery("select_messagesOffset"); + offsetQuery->bindValue(":bufferid", buffer.uid().toInt()); + offsetQuery->bindValue(":messageid", offset); + offsetQuery->exec(); + offsetQuery->first(); + offset = offsetQuery->value(0).toInt(); // now let's select the messages - QSqlQuery *requestMsgsQuery = cachedQuery("select_messages"); - requestMsgsQuery->bindValue(":bufferid", buffer.uid()); - requestMsgsQuery->bindValue(":bufferid2", buffer.uid()); // Qt can't handle the same placeholder used twice - requestMsgsQuery->bindValue(":limit", lastmsgs); - requestMsgsQuery->bindValue(":offset", offset); - requestMsgsQuery->exec(); - while(requestMsgsQuery->next()) { - Message msg(QDateTime::fromTime_t(requestMsgsQuery->value(1).toInt()), + QSqlQuery *msgQuery = cachedQuery("select_messages"); + msgQuery->bindValue(":bufferid", buffer.uid().toInt()); + msgQuery->bindValue(":limit", lastmsgs); + msgQuery->bindValue(":offset", offset); + msgQuery->exec(); + + watchQuery(msgQuery); + + while(msgQuery->next()) { + Message msg(QDateTime::fromTime_t(msgQuery->value(1).toInt()), buffer, - (Message::Type)requestMsgsQuery->value(2).toUInt(), - requestMsgsQuery->value(5).toString(), - requestMsgsQuery->value(4).toString(), - requestMsgsQuery->value(3).toUInt()); - msg.setMsgId(requestMsgsQuery->value(0).value()); + (Message::Type)msgQuery->value(2).toUInt(), + msgQuery->value(5).toString(), + msgQuery->value(4).toString(), + msgQuery->value(3).toUInt()); + msg.setMsgId(msgQuery->value(0).toInt()); messagelist << msg; } return messagelist; @@ -307,29 +302,30 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, int lastmsgs, int o QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, int offset) { QList messagelist; // we have to determine the real offset first - QSqlQuery *requestMsgsSinceOffsetQuery = cachedQuery("select_messagesSinceOffset"); - requestMsgsSinceOffsetQuery->bindValue(":bufferid", buffer.uid()); - requestMsgsSinceOffsetQuery->bindValue(":since", since.toTime_t()); - requestMsgsSinceOffsetQuery->exec(); - requestMsgsSinceOffsetQuery->first(); - offset = requestMsgsSinceOffsetQuery->value(0).toInt(); + QSqlQuery *offsetQuery = cachedQuery("select_messagesSinceOffset"); + offsetQuery->bindValue(":bufferid", buffer.uid().toInt()); + offsetQuery->bindValue(":since", since.toTime_t()); + offsetQuery->exec(); + offsetQuery->first(); + offset = offsetQuery->value(0).toInt(); // now let's select the messages - QSqlQuery *requestMsgsSinceQuery = cachedQuery("select_messagesSince"); - requestMsgsSinceQuery->bindValue(":bufferid", buffer.uid()); - requestMsgsSinceQuery->bindValue(":bufferid2", buffer.uid()); - requestMsgsSinceQuery->bindValue(":since", since.toTime_t()); - requestMsgsSinceQuery->bindValue(":offset", offset); - requestMsgsSinceQuery->exec(); - - while(requestMsgsSinceQuery->next()) { - Message msg(QDateTime::fromTime_t(requestMsgsSinceQuery->value(1).toInt()), + QSqlQuery *msgQuery = cachedQuery("select_messagesSince"); + msgQuery->bindValue(":bufferid", buffer.uid().toInt()); + msgQuery->bindValue(":since", since.toTime_t()); + msgQuery->bindValue(":offset", offset); + msgQuery->exec(); + + watchQuery(msgQuery); + + while(msgQuery->next()) { + Message msg(QDateTime::fromTime_t(msgQuery->value(1).toInt()), buffer, - (Message::Type)requestMsgsSinceQuery->value(2).toUInt(), - requestMsgsSinceQuery->value(5).toString(), - requestMsgsSinceQuery->value(4).toString(), - requestMsgsSinceQuery->value(3).toUInt()); - msg.setMsgId(requestMsgsSinceQuery->value(0).value()); + (Message::Type)msgQuery->value(2).toUInt(), + msgQuery->value(5).toString(), + msgQuery->value(4).toString(), + msgQuery->value(3).toUInt()); + msg.setMsgId(msgQuery->value(0).toInt()); messagelist << msg; } @@ -339,20 +335,22 @@ QList SqliteStorage::requestMsgs(BufferInfo buffer, QDateTime since, in QList SqliteStorage::requestMsgRange(BufferInfo buffer, int first, int last) { QList messagelist; - QSqlQuery *requestMsgRangeQuery = cachedQuery("select_messageRange"); - requestMsgRangeQuery->bindValue(":bufferid", buffer.uid()); - requestMsgRangeQuery->bindValue(":bufferid2", buffer.uid()); - requestMsgRangeQuery->bindValue(":firstmsg", first); - requestMsgRangeQuery->bindValue(":lastmsg", last); - - while(requestMsgRangeQuery->next()) { - Message msg(QDateTime::fromTime_t(requestMsgRangeQuery->value(1).toInt()), + QSqlQuery *rangeQuery = cachedQuery("select_messageRange"); + rangeQuery->bindValue(":bufferid", buffer.uid().toInt()); + rangeQuery->bindValue(":firstmsg", first); + rangeQuery->bindValue(":lastmsg", last); + rangeQuery->exec(); + + watchQuery(rangeQuery); + + while(rangeQuery->next()) { + Message msg(QDateTime::fromTime_t(rangeQuery->value(1).toInt()), buffer, - (Message::Type)requestMsgRangeQuery->value(2).toUInt(), - requestMsgRangeQuery->value(5).toString(), - requestMsgRangeQuery->value(4).toString(), - requestMsgRangeQuery->value(3).toUInt()); - msg.setMsgId(requestMsgRangeQuery->value(0).value()); + (Message::Type)rangeQuery->value(2).toUInt(), + rangeQuery->value(5).toString(), + rangeQuery->value(4).toString(), + rangeQuery->value(3).toUInt()); + msg.setMsgId(rangeQuery->value(0).toInt()); messagelist << msg; }