1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-10-13 20:13:38 -04:00

Add /rooms cache

This commit is contained in:
James Booth 2018-02-05 20:01:54 +00:00
parent 8db2389df6
commit 26a182945f
11 changed files with 111 additions and 14 deletions

View File

@ -162,7 +162,9 @@ static Autocomplete alias_ac;
static Autocomplete aliases_ac; static Autocomplete aliases_ac;
static Autocomplete join_property_ac; static Autocomplete join_property_ac;
static Autocomplete room_ac; static Autocomplete room_ac;
static Autocomplete rooms_ac; static Autocomplete rooms_all_ac;
static Autocomplete rooms_list_ac;
static Autocomplete rooms_cache_ac;
static Autocomplete affiliation_ac; static Autocomplete affiliation_ac;
static Autocomplete role_ac; static Autocomplete role_ac;
static Autocomplete privilege_cmd_ac; static Autocomplete privilege_cmd_ac;
@ -593,9 +595,19 @@ cmd_ac_init(void)
autocomplete_add(room_ac, "destroy"); autocomplete_add(room_ac, "destroy");
autocomplete_add(room_ac, "config"); autocomplete_add(room_ac, "config");
rooms_ac = autocomplete_new(); rooms_all_ac = autocomplete_new();
autocomplete_add(rooms_ac, "service"); autocomplete_add(rooms_all_ac, "service");
autocomplete_add(rooms_ac, "filter"); autocomplete_add(rooms_all_ac, "filter");
autocomplete_add(rooms_all_ac, "cache");
rooms_list_ac = autocomplete_new();
autocomplete_add(rooms_list_ac, "service");
autocomplete_add(rooms_list_ac, "filter");
rooms_cache_ac = autocomplete_new();
autocomplete_add(rooms_cache_ac, "on");
autocomplete_add(rooms_cache_ac, "off");
autocomplete_add(rooms_cache_ac, "clear");
affiliation_ac = autocomplete_new(); affiliation_ac = autocomplete_new();
autocomplete_add(affiliation_ac, "owner"); autocomplete_add(affiliation_ac, "owner");
@ -1011,7 +1023,9 @@ cmd_ac_reset(ProfWin *window)
autocomplete_reset(aliases_ac); autocomplete_reset(aliases_ac);
autocomplete_reset(join_property_ac); autocomplete_reset(join_property_ac);
autocomplete_reset(room_ac); autocomplete_reset(room_ac);
autocomplete_reset(rooms_ac); autocomplete_reset(rooms_all_ac);
autocomplete_reset(rooms_list_ac);
autocomplete_reset(rooms_cache_ac);
autocomplete_reset(affiliation_ac); autocomplete_reset(affiliation_ac);
autocomplete_reset(role_ac); autocomplete_reset(role_ac);
autocomplete_reset(privilege_cmd_ac); autocomplete_reset(privilege_cmd_ac);
@ -1131,7 +1145,9 @@ cmd_ac_uninit(void)
autocomplete_free(aliases_ac); autocomplete_free(aliases_ac);
autocomplete_free(join_property_ac); autocomplete_free(join_property_ac);
autocomplete_free(room_ac); autocomplete_free(room_ac);
autocomplete_free(rooms_ac); autocomplete_free(rooms_all_ac);
autocomplete_free(rooms_list_ac);
autocomplete_free(rooms_cache_ac);
autocomplete_free(affiliation_ac); autocomplete_free(affiliation_ac);
autocomplete_free(role_ac); autocomplete_free(role_ac);
autocomplete_free(privilege_cmd_ac); autocomplete_free(privilege_cmd_ac);
@ -3111,16 +3127,28 @@ _rooms_autocomplete(ProfWin *window, const char *const input, gboolean previous)
gboolean space_at_end = g_str_has_suffix(input, " "); gboolean space_at_end = g_str_has_suffix(input, " ");
int num_args = g_strv_length(args); int num_args = g_strv_length(args);
if (num_args <= 1) { if (num_args <= 1) {
found = autocomplete_param_with_ac(input, "/rooms", rooms_ac, TRUE, previous); found = autocomplete_param_with_ac(input, "/rooms", rooms_all_ac, TRUE, previous);
if (found) { if (found) {
g_strfreev(args); g_strfreev(args);
return found; return found;
} }
} }
if ((num_args == 1 && g_strcmp0(args[0], "cache") == 0 && space_at_end) ||
(num_args == 2 && g_strcmp0(args[0], "cache") == 0)) {
found = autocomplete_param_with_ac(input, "/rooms cache", rooms_cache_ac, TRUE, previous);
if (found) {
g_strfreev(args);
return found;
}
}
if ((num_args >= 2) && g_strcmp0(args[0], "cache") == 0) {
g_strfreev(args);
return NULL;
}
if ((num_args == 2 && space_at_end) || (num_args == 3 && !space_at_end)) { if ((num_args == 2 && space_at_end) || (num_args == 3 && !space_at_end)) {
GString *beginning = g_string_new("/rooms"); GString *beginning = g_string_new("/rooms");
g_string_append_printf(beginning, " %s %s", args[0], args[1]); g_string_append_printf(beginning, " %s %s", args[0], args[1]);
found = autocomplete_param_with_ac(input, beginning->str, rooms_ac, TRUE, previous); found = autocomplete_param_with_ac(input, beginning->str, rooms_list_ac, TRUE, previous);
g_string_free(beginning, TRUE); g_string_free(beginning, TRUE);
if (found) { if (found) {
g_strfreev(args); g_strfreev(args);

View File

@ -797,14 +797,17 @@ static struct cmd_t command_defs[] =
"/rooms", "/rooms",
"/rooms filter <text>", "/rooms filter <text>",
"/rooms service <service>", "/rooms service <service>",
"/rooms service <service> filter <text>") "/rooms service <service> filter <text>",
"/rooms cache on|off|clear")
CMD_DESC( CMD_DESC(
"List the chat rooms available at the specified conference service. " "List the chat rooms available at the specified conference service. "
"If no argument is supplied, the account preference 'muc.service' is used, 'conference.<domain-part>' by default. " "If no argument is supplied, the account preference 'muc.service' is used, 'conference.<domain-part>' by default. "
"The filter argument only shows rooms that contain the provided text, case insensitive.") "The filter argument only shows rooms that contain the provided text, case insensitive.")
CMD_ARGS( CMD_ARGS(
{ "service <service>", "The conference service to query." }, { "service <service>", "The conference service to query." },
{ "filter <text>", "The text to filter results by."}) { "filter <text>", "The text to filter results by."},
{ "cache on|off", "Enable or disable caching of rooms list response."},
{ "cache clear", "Clear the rooms response cache if enabled."})
CMD_EXAMPLES( CMD_EXAMPLES(
"/rooms", "/rooms",
"/rooms filter development", "/rooms filter development",

View File

@ -2876,7 +2876,7 @@ cmd_roster(ProfWin *window, const char *const command, gchar **args)
if (conn_status == JABBER_CONNECTED) { if (conn_status == JABBER_CONNECTED) {
rosterwin_roster(); rosterwin_roster();
} }
return TRUE; return TRUE;
} else { } else {
cons_bad_cmd_usage(command); cons_bad_cmd_usage(command);
return TRUE; return TRUE;
@ -2888,7 +2888,7 @@ cmd_roster(ProfWin *window, const char *const command, gchar **args)
if (conn_status == JABBER_CONNECTED) { if (conn_status == JABBER_CONNECTED) {
rosterwin_roster(); rosterwin_roster();
} }
return TRUE; return TRUE;
} else { } else {
cons_bad_cmd_usage(command); cons_bad_cmd_usage(command);
return TRUE; return TRUE;
@ -4410,6 +4410,28 @@ cmd_rooms(ProfWin *window, const char *const command, gchar **args)
return TRUE; return TRUE;
} }
filter = g_strdup(args[1]); filter = g_strdup(args[1]);
} else if (g_strcmp0(args[0], "cache") == 0) {
if (g_strv_length(args) != 2) {
cons_bad_cmd_usage(command);
cons_show("");
return TRUE;
} else if (g_strcmp0(args[1], "on") == 0) {
prefs_set_boolean(PREF_ROOM_LIST_CACHE, TRUE);
cons_show("Rooms list cache enabled.");
return TRUE;
} else if (g_strcmp0(args[1], "off") == 0) {
prefs_set_boolean(PREF_ROOM_LIST_CACHE, FALSE);
cons_show("Rooms list cache disabled.");
return TRUE;
} else if (g_strcmp0(args[1], "clear") == 0) {
iq_rooms_cache_clear();
cons_show("Rooms list cache cleared.");
return TRUE;
} else {
cons_bad_cmd_usage(command);
cons_show("");
return TRUE;
}
} else { } else {
cons_bad_cmd_usage(command); cons_bad_cmd_usage(command);
cons_show(""); cons_show("");

View File

@ -1615,6 +1615,7 @@ _get_group(preference_t pref)
case PREF_PGP_LOG: case PREF_PGP_LOG:
return PREF_GROUP_PGP; return PREF_GROUP_PGP;
case PREF_BOOKMARK_INVITE: case PREF_BOOKMARK_INVITE:
case PREF_ROOM_LIST_CACHE:
return PREF_GROUP_MUC; return PREF_GROUP_MUC;
case PREF_PLUGINS_SOURCEPATH: case PREF_PLUGINS_SOURCEPATH:
return PREF_GROUP_PLUGINS; return PREF_GROUP_PLUGINS;
@ -1822,6 +1823,8 @@ _get_key(preference_t pref)
return "bookmark.invite"; return "bookmark.invite";
case PREF_PLUGINS_SOURCEPATH: case PREF_PLUGINS_SOURCEPATH:
return "sourcepath"; return "sourcepath";
case PREF_ROOM_LIST_CACHE:
return "rooms.cache";
default: default:
return NULL; return NULL;
} }
@ -1870,6 +1873,7 @@ _get_default_boolean(preference_t pref)
case PREF_NOTIFY_MENTION_WHOLE_WORD: case PREF_NOTIFY_MENTION_WHOLE_WORD:
case PREF_TRAY_READ: case PREF_TRAY_READ:
case PREF_BOOKMARK_INVITE: case PREF_BOOKMARK_INVITE:
case PREF_ROOM_LIST_CACHE:
return TRUE; return TRUE;
default: default:
return FALSE; return FALSE;

View File

@ -143,6 +143,7 @@ typedef enum {
PREF_CONSOLE_CHAT, PREF_CONSOLE_CHAT,
PREF_BOOKMARK_INVITE, PREF_BOOKMARK_INVITE,
PREF_PLUGINS_SOURCEPATH, PREF_PLUGINS_SOURCEPATH,
PREF_ROOM_LIST_CACHE,
} preference_t; } preference_t;
typedef struct prof_alias_t { typedef struct prof_alias_t {

View File

@ -1247,6 +1247,16 @@ cons_occupants_setting(void)
cons_show("Occupants size (/occupants) : %d", size); cons_show("Occupants size (/occupants) : %d", size);
} }
void
cons_rooms_cache_setting(void)
{
if (prefs_get_boolean(PREF_ROOM_LIST_CACHE)) {
cons_show("Room list cache (/rooms cache) : ON");
} else {
cons_show("Room list cache (/rooms cache) : OFF");
}
}
void void
cons_autoconnect_setting(void) cons_autoconnect_setting(void)
{ {
@ -1906,6 +1916,7 @@ cons_show_connection_prefs(void)
cons_reconnect_setting(); cons_reconnect_setting();
cons_autoping_setting(); cons_autoping_setting();
cons_autoconnect_setting(); cons_autoconnect_setting();
cons_rooms_cache_setting();
cons_alert(); cons_alert();
} }

View File

@ -316,6 +316,7 @@ void cons_autoaway_setting(void);
void cons_reconnect_setting(void); void cons_reconnect_setting(void);
void cons_autoping_setting(void); void cons_autoping_setting(void);
void cons_autoconnect_setting(void); void cons_autoconnect_setting(void);
void cons_room_cache_setting(void);
void cons_inpblock_setting(void); void cons_inpblock_setting(void);
void cons_winpos_setting(void); void cons_winpos_setting(void);
void cons_show_contact_online(PContact contact, Resource *resource, GDateTime *last_activity); void cons_show_contact_online(PContact contact, Resource *resource, GDateTime *last_activity);

View File

@ -133,6 +133,7 @@ static void _item_destroy(DiscoItem *item);
static gboolean autoping_wait = FALSE; static gboolean autoping_wait = FALSE;
static GTimer *autoping_time = NULL; static GTimer *autoping_time = NULL;
static GHashTable *id_handlers; static GHashTable *id_handlers;
static GHashTable *rooms_cache = NULL;
static int static int
_iq_handler(xmpp_conn_t *const conn, xmpp_stanza_t *const stanza, void *const userdata) _iq_handler(xmpp_conn_t *const conn, xmpp_stanza_t *const stanza, void *const userdata)
@ -236,6 +237,7 @@ iq_handlers_init(void)
g_hash_table_destroy(id_handlers); g_hash_table_destroy(id_handlers);
} }
id_handlers = g_hash_table_new_full(g_str_hash, g_str_equal, free, NULL); id_handlers = g_hash_table_new_full(g_str_hash, g_str_equal, free, NULL);
rooms_cache = g_hash_table_new_full(g_str_hash, g_str_equal, free, (GDestroyNotify)xmpp_stanza_release);
} }
void void
@ -296,9 +298,25 @@ iq_set_autoping(const int seconds)
xmpp_timed_handler_add(conn, _autoping_timed_send, millis, ctx); xmpp_timed_handler_add(conn, _autoping_timed_send, millis, ctx);
} }
void
iq_rooms_cache_clear(void)
{
if (rooms_cache) {
g_hash_table_remove_all(rooms_cache);
}
}
void void
iq_room_list_request(gchar *conferencejid, gchar *filter) iq_room_list_request(gchar *conferencejid, gchar *filter)
{ {
if (g_hash_table_contains(rooms_cache, conferencejid)) {
log_debug("Rooms request cached for: %s", conferencejid);
_room_list_id_handler(g_hash_table_lookup(rooms_cache, conferencejid), filter);
return;
}
log_debug("Rooms request not cached for: %s", conferencejid);
xmpp_ctx_t * const ctx = connection_get_ctx(); xmpp_ctx_t * const ctx = connection_get_ctx();
char *id = create_unique_id("confreq"); char *id = create_unique_id("confreq");
xmpp_stanza_t *iq = stanza_create_disco_items_iq(ctx, id, conferencejid); xmpp_stanza_t *iq = stanza_create_disco_items_iq(ctx, id, conferencejid);
@ -905,6 +923,10 @@ _room_list_id_handler(xmpp_stanza_t *const stanza, void *const userdata)
const char *id = xmpp_stanza_get_id(stanza); const char *id = xmpp_stanza_get_id(stanza);
const char *from = xmpp_stanza_get_from(stanza); const char *from = xmpp_stanza_get_from(stanza);
if (prefs_get_boolean(PREF_ROOM_LIST_CACHE) && !g_hash_table_contains(rooms_cache, from)) {
g_hash_table_insert(rooms_cache, strdup(from), xmpp_stanza_copy(stanza));
}
log_debug("Response to query: %s", id); log_debug("Response to query: %s", id);
xmpp_stanza_t *query = xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_QUERY); xmpp_stanza_t *query = xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_QUERY);
@ -981,7 +1003,9 @@ _room_list_id_handler(xmpp_stanza_t *const stanza, void *const userdata)
cons_show(" No rooms found matching filter: %s", filter); cons_show(" No rooms found matching filter: %s", filter);
} }
g_pattern_spec_free(glob); if (glob) {
g_pattern_spec_free(glob);
}
g_free(filter); g_free(filter);
return 0; return 0;

View File

@ -161,6 +161,7 @@ gboolean presence_sub_request_exists(const char *const bare_jid);
void iq_enable_carbons(void); void iq_enable_carbons(void);
void iq_disable_carbons(void); void iq_disable_carbons(void);
void iq_send_software_version(const char *const fulljid); void iq_send_software_version(const char *const fulljid);
void iq_rooms_cache_clear(void);
void iq_room_list_request(gchar *conferencejid, gchar *filter); void iq_room_list_request(gchar *conferencejid, gchar *filter);
void iq_disco_info_request(gchar *jid); void iq_disco_info_request(gchar *jid);
void iq_disco_items_request(gchar *jid); void iq_disco_items_request(gchar *jid);

View File

@ -445,6 +445,7 @@ void cons_autoaway_setting(void) {}
void cons_reconnect_setting(void) {} void cons_reconnect_setting(void) {}
void cons_autoping_setting(void) {} void cons_autoping_setting(void) {}
void cons_autoconnect_setting(void) {} void cons_autoconnect_setting(void) {}
void cons_rooms_cache_setting(void) {}
void cons_inpblock_setting(void) {} void cons_inpblock_setting(void) {}
void cons_winpos_setting(void) {} void cons_winpos_setting(void) {}
void cons_tray_setting(void) {} void cons_tray_setting(void) {}

View File

@ -204,6 +204,7 @@ void iq_room_role_set(const char * const room, const char * const nick, char *ro
void iq_room_role_list(const char * const room, char *role) {} void iq_room_role_list(const char * const room, char *role) {}
void iq_last_activity_request(gchar *jid) {} void iq_last_activity_request(gchar *jid) {}
void iq_autoping_check(void) {} void iq_autoping_check(void) {}
void iq_rooms_cache_clear(void) {}
// caps functions // caps functions
void caps_add_feature(char *feature) {} void caps_add_feature(char *feature) {}