X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcore.cpp;h=03d22d4c89ddffeb0470c85eca234b5afa61fcc4;hp=32b34f53c08e48698b01865b574d10fc6d342457;hb=c0bbc724cda7acf652d9d2ce80605ebb53c4a2ff;hpb=0c9cd0eef379e1d3e10a75cc8506a7e65f95fd67 diff --git a/src/core/core.cpp b/src/core/core.cpp index 32b34f53..03d22d4c 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -64,14 +64,12 @@ void Core::init() { CoreSettings cs; - // TODO migrate old db settings - if(!(configured = initStorage(cs.storageSettings().toMap()))) { qWarning("Core is currently not configured!"); // try to migrate old settings QVariantMap old = cs.oldDbSettings().toMap(); - if(old.count() && old["Type"].toString() == "SQlite") { + if(old.count() && old["Type"].toString().toUpper() == "SQLITE") { QVariantMap newSettings; newSettings["Backend"] = "SQLite"; if((configured = initStorage(newSettings))) { @@ -86,7 +84,7 @@ void Core::init() { } Core::~Core() { - foreach(QTcpSocket *socket, blocksizes.keys()) { + foreach(QTcpSocket *socket, blocksizes.keys()) { qDebug() << "disconnecting" << socket << blocksizes.keys(); socket->disconnectFromHost(); // disconnect local (i.e. non-authed) clients } qDeleteAll(sessions); @@ -106,6 +104,10 @@ void Core::saveState() { } void Core::restoreState() { + if(!instance()->configured) { + qWarning() << qPrintable(tr("Cannot restore a state for an unconfigured core!")); + return; + } if(instance()->sessions.count()) { qWarning() << qPrintable(tr("Calling restoreState() even though active sessions exist!")); return; @@ -139,7 +141,7 @@ QString Core::setupCore(const QVariant &setupData_) { return tr("Could not setup storage!"); } CoreSettings s; - //s.setStorageSettings(msg); + s.setStorageSettings(setupData); qDebug() << qPrintable(tr("Creating admin user...")); mutex.lock(); storage->addUser(user, password); @@ -203,9 +205,9 @@ void Core::syncStorage() { } /*** Storage Access ***/ -bool Core::createNetworkId(UserId user, NetworkInfo &info) { +bool Core::createNetwork(UserId user, NetworkInfo &info) { QMutexLocker locker(&mutex); - NetworkId networkId = instance()->storage->createNetworkId(user, info); + NetworkId networkId = instance()->storage->createNetwork(user, info); if(!networkId.isValid()) return false; @@ -213,14 +215,34 @@ bool Core::createNetworkId(UserId user, NetworkInfo &info) { return true; } +bool Core::updateNetwork(UserId user, const NetworkInfo &info) { + QMutexLocker locker(&mutex); + return instance()->storage->updateNetwork(user, info); +} + +bool Core::removeNetwork(UserId user, const NetworkId &networkId) { + QMutexLocker locker(&mutex); + return instance()->storage->removeNetwork(user, networkId); +} + +QList Core::networks(UserId user) { + QMutexLocker locker(&mutex); + return instance()->storage->networks(user); +} + NetworkId Core::networkId(UserId user, const QString &network) { QMutexLocker locker(&mutex); return instance()->storage->getNetworkId(user, network); } -BufferInfo Core::bufferInfo(UserId user, const NetworkId &networkId, const QString &buffer) { +BufferInfo Core::bufferInfo(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer) { + QMutexLocker locker(&mutex); + return instance()->storage->getBufferInfo(user, networkId, type, buffer); +} + +BufferInfo Core::getBufferInfo(UserId user, const BufferId &bufferId) { QMutexLocker locker(&mutex); - return instance()->storage->getBufferInfo(user, networkId, buffer); + return instance()->storage->getBufferInfo(user, bufferId); } MsgId Core::storeMessage(const Message &message) { @@ -248,6 +270,26 @@ QList Core::requestBuffers(UserId user, QDateTime since) { return instance()->storage->requestBuffers(user, since); } +bool Core::removeBuffer(const UserId &user, const BufferId &bufferId) { + QMutexLocker locker(&mutex); + return instance()->storage->removeBuffer(user, bufferId); +} + +BufferId Core::renameBuffer(const UserId &user, const NetworkId &networkId, const QString &newName, const QString &oldName) { + QMutexLocker locker(&mutex); + return instance()->storage->renameBuffer(user, networkId, newName, oldName); +} + +void Core::setBufferLastSeen(UserId user, const BufferId &bufferId, const QDateTime &seenDate) { + QMutexLocker locker(&mutex); + return instance()->storage->setBufferLastSeen(user, bufferId, seenDate); +} + +QHash Core::bufferLastSeenDates(UserId user) { + QMutexLocker locker(&mutex); + return instance()->storage->bufferLastSeenDates(user); +} + /*** Network Management ***/ bool Core::startListening(uint port) { @@ -288,6 +330,7 @@ void Core::clientHasData() { while(SignalProxy::readDataFromDevice(socket, blocksizes[socket], item)) { QVariantMap msg = item.toMap(); processClientMessage(socket, msg); + if(!blocksizes.contains(socket)) break; // this socket is no longer ours to handle! } } @@ -402,43 +445,6 @@ void Core::clientDisconnected() { // Suggestion: kill sessions if they are not connected to any network and client. } -/* -void Core::processCoreSetup(QTcpSocket *socket, QVariantMap &msg) { - if(msg["HasSettings"].toBool()) { - QVariantMap auth; - auth["User"] = msg["User"]; - auth["Password"] = msg["Password"]; - msg.remove("User"); - msg.remove("Password"); - qDebug() << "Initializing storage provider" << msg["Type"].toString(); - - if(!initStorage(msg, true)) { - // notify client to start wizard again - qWarning("Core is currently not configured!"); - QVariantMap reply; - reply["StartWizard"] = true; - reply["StorageProviders"] = availableStorageProviders(); - SignalProxy::writeDataToDevice(socket, reply); - } else { - // write coresettings - CoreSettings s; - s.setDatabaseSettings(msg); - // write admin user to database & make the core listen again to connections - storage->addUser(auth["User"].toString(), auth["Password"].toString()); - startListening(); - // continue the normal procedure - //processClientInit(socket, auth); - } - } else { - // notify client to start wizard - QVariantMap reply; - reply["StartWizard"] = true; - reply["StorageProviders"] = availableStorageProviders(); - SignalProxy::writeDataToDevice(socket, reply); - } -} -*/ - void Core::setupClientSession(QTcpSocket *socket, UserId uid) { // Find or create session for validated user SessionThread *sess;