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

Add hidden MAM setting and trigger MAM retrievel when opening new window

Only when we start the conversation.
Not yet when we get messaged and a new window is opened.
Need to have sorting of messages in the window buffer then, I guess.
Also MAM IQ should only be send one time in such a case.

If MAM is enabled history from sql backend will not be shown.

`mam` in profrc enables experimental MAM.
Can change soon again. Don't rely on stuff in this stage ;)
This commit is contained in:
Michael Vetter 2020-04-12 00:37:20 +02:00
parent 98200ebd43
commit 51518497e5
3 changed files with 17 additions and 8 deletions

View File

@ -1799,6 +1799,7 @@ _get_group(preference_t pref)
case PREF_REVEAL_OS: case PREF_REVEAL_OS:
case PREF_TLS_CERTPATH: case PREF_TLS_CERTPATH:
case PREF_CORRECTION_ALLOW: case PREF_CORRECTION_ALLOW:
case PREF_MAM:
return PREF_GROUP_CONNECTION; return PREF_GROUP_CONNECTION;
case PREF_OTR_LOG: case PREF_OTR_LOG:
case PREF_OTR_POLICY: case PREF_OTR_POLICY:
@ -2070,6 +2071,8 @@ _get_key(preference_t pref)
return "avatar.cmd"; return "avatar.cmd";
case PREF_SLASH_GUARD: case PREF_SLASH_GUARD:
return "slashguard"; return "slashguard";
case PREF_MAM:
return "mam";
default: default:
return NULL; return NULL;
} }

View File

@ -170,6 +170,7 @@ typedef enum {
PREF_HISTORY_COLOR_MUC, PREF_HISTORY_COLOR_MUC,
PREF_AVATAR_CMD, PREF_AVATAR_CMD,
PREF_SLASH_GUARD, PREF_SLASH_GUARD,
PREF_MAM,
} preference_t; } preference_t;
typedef struct prof_alias_t { typedef struct prof_alias_t {

View File

@ -57,7 +57,7 @@
#include "omemo/omemo.h" #include "omemo/omemo.h"
#endif #endif
/*static void _chatwin_history(ProfChatWin *chatwin, const char *const contact_barejid);*/ static void _chatwin_history(ProfChatWin *chatwin, const char *const contact_barejid);
static void _chatwin_set_last_message(ProfChatWin *chatwin, const char *const id, const char *const message); static void _chatwin_set_last_message(ProfChatWin *chatwin, const char *const id, const char *const message);
ProfChatWin* ProfChatWin*
@ -66,8 +66,8 @@ chatwin_new(const char *const barejid)
ProfWin *window = wins_new_chat(barejid); ProfWin *window = wins_new_chat(barejid);
ProfChatWin *chatwin = (ProfChatWin *)window; ProfChatWin *chatwin = (ProfChatWin *)window;
if (prefs_get_boolean(PREF_CHLOG) && prefs_get_boolean(PREF_HISTORY)) { if (!prefs_get_boolean(PREF_MAM) && prefs_get_boolean(PREF_CHLOG) && prefs_get_boolean(PREF_HISTORY)) {
//_chatwin_history(chatwin, barejid); _chatwin_history(chatwin, barejid);
} }
// if the contact is offline, show a message // if the contact is offline, show a message
@ -87,7 +87,9 @@ chatwin_new(const char *const barejid)
} }
#endif #endif
if (prefs_get_boolean(PREF_MAM)) {
iq_mam_request(chatwin); iq_mam_request(chatwin);
}
return chatwin; return chatwin;
} }
@ -285,8 +287,13 @@ chatwin_incoming_msg(ProfChatWin *chatwin, ProfMessage *message, gboolean win_cr
chatwin->unread++; chatwin->unread++;
if (prefs_get_boolean(PREF_CHLOG) && prefs_get_boolean(PREF_HISTORY)) { //TODO: so far we don't ask for MAM when incoming message occurs.
// _chatwin_history(chatwin, chatwin->barejid); //Need to figure out:
//1) only send IQ once
//2) sort incoming messages on timestamp
//for now if experimental MAM is enabled we dont show no history from sql either
if (!prefs_get_boolean(PREF_MAM) && prefs_get_boolean(PREF_CHLOG) && prefs_get_boolean(PREF_HISTORY)) {
_chatwin_history(chatwin, chatwin->barejid);
} }
// show users status first, when receiving message via delayed delivery // show users status first, when receiving message via delayed delivery
@ -485,7 +492,6 @@ chatwin_unset_outgoing_char(ProfChatWin *chatwin)
} }
} }
/*
static void static void
_chatwin_history(ProfChatWin *chatwin, const char *const contact_barejid) _chatwin_history(ProfChatWin *chatwin, const char *const contact_barejid)
{ {
@ -503,7 +509,6 @@ _chatwin_history(ProfChatWin *chatwin, const char *const contact_barejid)
g_slist_free_full(history, (GDestroyNotify)message_free); g_slist_free_full(history, (GDestroyNotify)message_free);
} }
} }
*/
static void static void
_chatwin_set_last_message(ProfChatWin *chatwin, const char *const id, const char *const message) _chatwin_set_last_message(ProfChatWin *chatwin, const char *const id, const char *const message)