1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-12-04 14:46:46 -05:00

Added OTR opportunistic pattern intercept.

When a message is received, OTRL_MESSAGE_TAG_BASE + OTRL_MESSAGE_TAG_V1 or OTRL_MESSAGE_TAG_V2
is searched for, if it is, the client attempts to start an OTR session.

Tested between profanity clients: WORKED
Tested between profanity and pidgin: NOT WORKING (not sure if pidgin checks for the whitespace)
This commit is contained in:
lightb 2014-04-22 16:01:57 -04:00
parent f95ae8b0dd
commit 6450e2a704

View File

@ -32,6 +32,7 @@
#ifdef HAVE_LIBOTR #ifdef HAVE_LIBOTR
#include "otr/otr.h" #include "otr/otr.h"
#include <libotr/proto.h>
#endif #endif
#include "ui/ui.h" #include "ui/ui.h"
@ -205,6 +206,17 @@ void
handle_incoming_message(char *from, char *message, gboolean priv) handle_incoming_message(char *from, char *message, gboolean priv)
{ {
#ifdef HAVE_LIBOTR #ifdef HAVE_LIBOTR
//check for OTR whitespace (opportunistic)
char *policy = prefs_get_string(PREF_OTR_POLICY);
if (strcmp(policy, "opportunistic") == 0) {
if (strstr(message,OTRL_MESSAGE_TAG_BASE)) {
if (strstr(message, OTRL_MESSAGE_TAG_V2) || strstr(message, OTRL_MESSAGE_TAG_V1)) {
char *otr_query_message = otr_start_query();
cons_show("OTR Whitespace pattern detected. Attempting to start OTR session...", message);
message_send(otr_query_message, from);
}
}
}
gboolean was_decrypted = FALSE; gboolean was_decrypted = FALSE;
char *newmessage; char *newmessage;
if (!priv) { if (!priv) {