C++11 library providing functionality common to all adapters.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

56 lines
1.6 KiB

#pragma once
#include <vector>
#include <functional>
#include <mutex>
#include "Adapter.hh"
#include "Semaphore.hh"
#include "passphrase_cache.hh"
namespace pEp {
// use this class when implementing a desktop adapter
// register different interfaces with add()
// then use CallbackDispatcher::start_sync() to start Sync
// and CallbackDispatcher::stop_sync() to stop Sync
class CallbackDispatcher {
using proc = std::function<void()>;
struct callbacks {
::messageToSend_t messageToSend;
::notifyHandshake_t notifyHandshake;
proc on_startup;
proc on_shutdown;
std::vector<callbacks> targets;
Semaphore semaphore;
void add(
::messageToSend_t messageToSend,
::notifyHandshake_t notifyHandshake,
proc on_startup = nullptr,
proc on_shutdown = nullptr
void remove(::messageToSend_t messageToSend);
static void start_sync();
static void stop_sync();
static PEP_STATUS messageToSend(::message *msg);
static PEP_STATUS notifyHandshake(::pEp_identity *me,
::pEp_identity *partner, ::sync_handshake_signal signal);
void on_startup();
void on_shutdown();
PEP_STATUS _messageToSend(::message *msg);
PEP_STATUS _notifyHandshake(::pEp_identity *me,
::pEp_identity *partner, ::sync_handshake_signal signal);
friend const char *PassphraseCache::add(const std::string& passphrase);
extern CallbackDispatcher callback_dispatcher;