We now send WHO every 60 seconds for all channels we are in. This keeps the nicklist,
[quassel.git] / src / core / core.cpp
index 69f34c3..03d22d4 100644 (file)
@@ -84,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);
@@ -141,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);
@@ -240,6 +240,11 @@ BufferInfo Core::bufferInfo(UserId user, const NetworkId &networkId, BufferInfo:
   return instance()->storage->getBufferInfo(user, networkId, type, buffer);
 }
 
+BufferInfo Core::getBufferInfo(UserId user, const BufferId &bufferId) {
+  QMutexLocker locker(&mutex);
+  return instance()->storage->getBufferInfo(user, bufferId);
+}
+
 MsgId Core::storeMessage(const Message &message) {
   QMutexLocker locker(&mutex);
   return instance()->storage->logMessage(message);
@@ -265,6 +270,26 @@ QList<BufferInfo> 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<BufferId, QDateTime> Core::bufferLastSeenDates(UserId user) {
+  QMutexLocker locker(&mutex);
+  return instance()->storage->bufferLastSeenDates(user);
+}
+
 /*** Network Management ***/
 
 bool Core::startListening(uint port) {
@@ -305,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!
   }
 }