mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Add signal-protocol locking
This commit is contained in:
parent
bfbc8edcad
commit
519cf295f3
@ -1,13 +1,24 @@
|
|||||||
|
#include <pthread.h>
|
||||||
#include <signal/signal_protocol.h>
|
#include <signal/signal_protocol.h>
|
||||||
|
|
||||||
#include "config/account.h"
|
#include "config/account.h"
|
||||||
#include "ui/ui.h"
|
#include "ui/ui.h"
|
||||||
|
#include "omemo/omemo.h"
|
||||||
#include "omemo/crypto.h"
|
#include "omemo/crypto.h"
|
||||||
|
|
||||||
|
static void lock(void *user_data);
|
||||||
|
static void unlock(void *user_data);
|
||||||
|
|
||||||
|
struct omemo_context_t {
|
||||||
|
pthread_mutexattr_t attr;
|
||||||
|
pthread_mutex_t lock;
|
||||||
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
omemo_init(ProfAccount *account)
|
omemo_init(ProfAccount *account)
|
||||||
{
|
{
|
||||||
signal_context *global_context;
|
signal_context *signal_ctx;
|
||||||
|
omemo_context *ctx = malloc(sizeof(omemo_context));
|
||||||
signal_crypto_provider crypto_provider = {
|
signal_crypto_provider crypto_provider = {
|
||||||
.random_func = omemo_random_func,
|
.random_func = omemo_random_func,
|
||||||
.hmac_sha256_init_func = omemo_hmac_sha256_init_func,
|
.hmac_sha256_init_func = omemo_hmac_sha256_init_func,
|
||||||
@ -27,14 +38,33 @@ omemo_init(ProfAccount *account)
|
|||||||
cons_show("Error initializing Omemo crypto");
|
cons_show("Error initializing Omemo crypto");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signal_context_create(&global_context, NULL) != 0) {
|
pthread_mutexattr_init(&ctx->attr);
|
||||||
|
pthread_mutexattr_settype(&ctx->attr, PTHREAD_MUTEX_RECURSIVE);
|
||||||
|
pthread_mutex_init(&ctx->lock, &ctx->attr);
|
||||||
|
|
||||||
|
if (signal_context_create(&signal_ctx, ctx) != 0) {
|
||||||
cons_show("Error initializing Omemo context");
|
cons_show("Error initializing Omemo context");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signal_context_set_crypto_provider(global_context, &crypto_provider) != 0) {
|
if (signal_context_set_crypto_provider(signal_ctx, &crypto_provider) != 0) {
|
||||||
cons_show("Error initializing Omemo crypto");
|
cons_show("Error initializing Omemo crypto");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//signal_context_set_locking_functions(global_context, lock_function, unlock_function);
|
|
||||||
|
signal_context_set_locking_functions(signal_ctx, lock, unlock);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
lock(void *user_data)
|
||||||
|
{
|
||||||
|
omemo_context *ctx = (omemo_context *)user_data;
|
||||||
|
pthread_mutex_lock(&ctx->lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
unlock(void *user_data)
|
||||||
|
{
|
||||||
|
omemo_context *ctx = (omemo_context *)user_data;
|
||||||
|
pthread_mutex_unlock(&ctx->lock);
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
#include "config/account.h"
|
#include "config/account.h"
|
||||||
|
|
||||||
|
typedef struct omemo_context_t omemo_context;
|
||||||
|
|
||||||
void omemo_init(ProfAccount *account);
|
void omemo_init(ProfAccount *account);
|
||||||
|
Loading…
Reference in New Issue
Block a user