some ideas over delay manager
This commit is contained in:
parent
77dd28b600
commit
2d8f32c257
@ -3,22 +3,30 @@ if(WIN32)
|
|||||||
set(SIGNALCATCHER_SOURCE signalcatcher_win32.cpp)
|
set(SIGNALCATCHER_SOURCE signalcatcher_win32.cpp)
|
||||||
endif(WIN32)
|
endif(WIN32)
|
||||||
|
|
||||||
target_sources(squawk PRIVATE
|
set(SOURCE_FILES
|
||||||
account.cpp
|
account.cpp
|
||||||
account.h
|
|
||||||
adapterfunctions.cpp
|
adapterfunctions.cpp
|
||||||
adapterfunctions.h
|
|
||||||
conference.cpp
|
conference.cpp
|
||||||
conference.h
|
|
||||||
contact.cpp
|
contact.cpp
|
||||||
contact.h
|
|
||||||
rosteritem.cpp
|
rosteritem.cpp
|
||||||
rosteritem.h
|
|
||||||
${SIGNALCATCHER_SOURCE}
|
${SIGNALCATCHER_SOURCE}
|
||||||
signalcatcher.h
|
|
||||||
squawk.cpp
|
squawk.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(HEADER_FILES
|
||||||
|
account.h
|
||||||
|
adapterfunctions.h
|
||||||
|
conference.h
|
||||||
|
contact.h
|
||||||
|
rosteritem.h
|
||||||
|
signalcatcher.h
|
||||||
squawk.h
|
squawk.h
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_sources(squawk PRIVATE
|
||||||
|
${SOURCE_FILES}
|
||||||
|
${HEADER_FILES}
|
||||||
|
)
|
||||||
|
|
||||||
target_include_directories(squawk PRIVATE ${LMDB_INCLUDE_DIRS})
|
target_include_directories(squawk PRIVATE ${LMDB_INCLUDE_DIRS})
|
||||||
|
|
||||||
|
@ -1,6 +1,16 @@
|
|||||||
target_sources(squawk PRIVATE
|
set(SOURCE_FILES
|
||||||
networkaccess.cpp
|
networkaccess.cpp
|
||||||
networkaccess.h
|
|
||||||
clientcache.cpp
|
clientcache.cpp
|
||||||
clientcache.h
|
delaymanager.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(HEADER_FILES
|
||||||
|
networkaccess.h
|
||||||
|
clientcache.h
|
||||||
|
delaymanager.h
|
||||||
|
)
|
||||||
|
|
||||||
|
target_sources(squawk PRIVATE
|
||||||
|
${SOURCE_FILES}
|
||||||
|
${HEADER_FILES}
|
||||||
)
|
)
|
||||||
|
136
core/components/delaymanager.cpp
Normal file
136
core/components/delaymanager.cpp
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
// Squawk messenger.
|
||||||
|
// Copyright (C) 2019 Yury Gubich <blue@macaw.me>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include "delaymanager.h"
|
||||||
|
|
||||||
|
Core::DelayManager::DelayManager(uint16_t mpj, QObject* parent) :
|
||||||
|
QObject(parent),
|
||||||
|
maxParallelJobs(mpj),
|
||||||
|
nextJobId(0),
|
||||||
|
scheduledJobs(),
|
||||||
|
runningJobs(),
|
||||||
|
pendingVCards(),
|
||||||
|
requestedVCards()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
Core::DelayManager::~DelayManager() {}
|
||||||
|
|
||||||
|
void Core::DelayManager::requestInfo(const QString& jid) {
|
||||||
|
bool needToRequest = false;
|
||||||
|
std::pair<std::set<QString>::const_iterator, bool> result = pendingVCards.insert(jid);
|
||||||
|
if (result.second) { //if there is a clear evidence that we have not alredy been asked to request a VCard - just request it
|
||||||
|
needToRequest = true;
|
||||||
|
} else {
|
||||||
|
std::map<QString, uint16_t>::const_iterator itr = requestedVCards.find(jid);
|
||||||
|
if (itr != requestedVCards.end()) { //first check if the card is already requested, and if it is make sure we reply to user after we receive it
|
||||||
|
runningJobs[itr->second].first = TaskType::infoForUser;
|
||||||
|
} else {
|
||||||
|
needToRequest = true;
|
||||||
|
for (Job& job : scheduledJobs) { //looks like we need to manually check all the scheduled job and find the one with that jid there
|
||||||
|
if (job.first == TaskType::cardInternal || job.first == TaskType::infoForUser) { //to make sure we reply to user after we receive it
|
||||||
|
QString* jobJid = static_cast<QString*>(job.second);
|
||||||
|
if (*jobJid == jid) {
|
||||||
|
needToRequest = false;
|
||||||
|
job.first = TaskType::infoForUser;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (needToRequest) {
|
||||||
|
throw 8573; //something went terribly wrong here, the state is not correct;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (needToRequest)
|
||||||
|
scheduleJob(TaskType::infoForUser, new QString(jid));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::DelayManager::requestVCard(const QString& jid) {
|
||||||
|
std::pair<std::set<QString>::const_iterator, bool> result = pendingVCards.insert(jid);
|
||||||
|
if (result.second)
|
||||||
|
scheduleJob(TaskType::cardInternal, new QString(jid));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::DelayManager::scheduleJob(Core::DelayManager::TaskType type, void* data) {
|
||||||
|
if (runningJobs.size() < maxParallelJobs) {
|
||||||
|
uint16_t currentJobId = nextJobId++;
|
||||||
|
runningJobs.emplace(currentJobId, std::make_pair(type, data));
|
||||||
|
switch (type) {
|
||||||
|
case TaskType::cardInternal:
|
||||||
|
case TaskType::infoForUser: {
|
||||||
|
QString* jid = static_cast<QString*>(data);
|
||||||
|
requestedVCards.emplace(*jid, currentJobId);
|
||||||
|
emit requestVCard(*jid);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
scheduledJobs.emplace_back(type, data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::DelayManager::executeJob(Core::DelayManager::Job job) {
|
||||||
|
uint16_t currentJobId = nextJobId++;
|
||||||
|
runningJobs.emplace(currentJobId, job);
|
||||||
|
switch (job.first) {
|
||||||
|
case TaskType::cardInternal:
|
||||||
|
case TaskType::infoForUser: {
|
||||||
|
QString* jid = static_cast<QString*>(job.second);
|
||||||
|
requestedVCards.emplace(*jid, currentJobId);
|
||||||
|
emit requestVCard(*jid);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Core::DelayManager::jobIsDone(uint16_t jobId) {
|
||||||
|
std::map<uint16_t, Job>::const_iterator itr = runningJobs.find(jobId);
|
||||||
|
if (itr == runningJobs.end()) {
|
||||||
|
throw 8574; //not supposed to happen, never
|
||||||
|
}
|
||||||
|
runningJobs.erase(itr);
|
||||||
|
if (scheduledJobs.size() > 0) {
|
||||||
|
Job job = scheduledJobs.front();
|
||||||
|
scheduledJobs.pop_front();
|
||||||
|
executeJob(job);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Core::DelayManager::receivedVCard(const QString& jid, const Shared::VCard& card) {
|
||||||
|
std::map<QString, uint16_t>::const_iterator cardItr = requestedVCards.find(jid);
|
||||||
|
if (cardItr == requestedVCards.end()) {
|
||||||
|
throw 8575; //never supposed to happen, the state is not correct;
|
||||||
|
} else {
|
||||||
|
uint16_t jobId = cardItr->second;
|
||||||
|
requestedVCards.erase(cardItr);
|
||||||
|
pendingVCards.erase(jid);
|
||||||
|
const Job& job = runningJobs[jobId];
|
||||||
|
switch (job.first) {
|
||||||
|
case TaskType::cardInternal:
|
||||||
|
jobIsDone(jobId);
|
||||||
|
break;
|
||||||
|
case TaskType::infoForUser:
|
||||||
|
//all that stuff with further requesting
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw 8576;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
71
core/components/delaymanager.h
Normal file
71
core/components/delaymanager.h
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
// Squawk messenger.
|
||||||
|
// Copyright (C) 2019 Yury Gubich <blue@macaw.me>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#ifndef CORE_DELAYMANAGER_H
|
||||||
|
#define CORE_DELAYMANAGER_H
|
||||||
|
|
||||||
|
#include <list>
|
||||||
|
#include <set>
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
#include <shared/vcard.h>
|
||||||
|
#include <shared/info.h>
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
|
||||||
|
class DelayManager : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
enum class TaskType {
|
||||||
|
cardInternal,
|
||||||
|
infoForUser
|
||||||
|
}
|
||||||
|
public:
|
||||||
|
DelayManager(uint16_t maxParallelJobs = 5, QObject* parent = nullptr);
|
||||||
|
~DelayManager();
|
||||||
|
|
||||||
|
void requestVCard(const QString& jid);
|
||||||
|
void requestInfo(const QString& jid);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void requestVCard(const QString& jid);
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
void receivedVCard(const QString& jid, const Shared::VCard& card);
|
||||||
|
|
||||||
|
private:
|
||||||
|
typedef std::pair<TaskType, void*> Job;
|
||||||
|
|
||||||
|
void scheduleJob(TaskType type, void* data);
|
||||||
|
void executeJob(Job job);
|
||||||
|
void jobIsDone(uint16_t jobId);
|
||||||
|
|
||||||
|
private:
|
||||||
|
uint16_t maxParallelJobs;
|
||||||
|
uint16_t nextJobId;
|
||||||
|
std::list<Job> scheduledJobs;
|
||||||
|
std::map<uint16_t, Job> runningJobs;
|
||||||
|
|
||||||
|
std::set<QString> pendingVCards;
|
||||||
|
std::map<QString, uint16_t> requestedVCards;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // CORE_DELAYMANAGER_H
|
@ -1,14 +1,22 @@
|
|||||||
target_sources(squawk PRIVATE
|
set(SOURCE_FILES
|
||||||
messagehandler.cpp
|
messagehandler.cpp
|
||||||
messagehandler.h
|
|
||||||
rosterhandler.cpp
|
rosterhandler.cpp
|
||||||
rosterhandler.h
|
|
||||||
vcardhandler.cpp
|
vcardhandler.cpp
|
||||||
vcardhandler.h
|
|
||||||
discoveryhandler.cpp
|
discoveryhandler.cpp
|
||||||
discoveryhandler.h
|
|
||||||
omemohandler.cpp
|
omemohandler.cpp
|
||||||
omemohandler.h
|
|
||||||
trusthandler.cpp
|
trusthandler.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(HEADER_FILES
|
||||||
|
messagehandler.h
|
||||||
|
rosterhandler.h
|
||||||
|
vcardhandler.h
|
||||||
|
discoveryhandler.h
|
||||||
|
omemohandler.h
|
||||||
trusthandler.h
|
trusthandler.h
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_sources(squawk PRIVATE
|
||||||
|
${SOURCE_FILES}
|
||||||
|
${HEADER_FILES}
|
||||||
|
)
|
||||||
|
@ -1,7 +1,19 @@
|
|||||||
target_sources(squawk PRIVATE
|
set(SOURCE_FILES
|
||||||
omemo.cpp
|
omemo.cpp
|
||||||
omemo.h
|
|
||||||
omemo.ui
|
|
||||||
keydelegate.cpp
|
keydelegate.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(UI_FILES
|
||||||
|
omemo.ui
|
||||||
|
)
|
||||||
|
|
||||||
|
set(HEADER_FILES
|
||||||
|
omemo.h
|
||||||
keydelegate.h
|
keydelegate.h
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_sources(squawk PRIVATE
|
||||||
|
${SOURCE_FILES}
|
||||||
|
${UI_FILES}
|
||||||
|
${HEADER_FILES}
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user