From a19f988301332680e23fd81031935eb1312d3173 Mon Sep 17 00:00:00 2001 From: fiaxh Date: Tue, 31 Jul 2018 17:49:10 +0200 Subject: Support MUC avatars --- libdino/src/service/muc_manager.vala | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) (limited to 'libdino/src/service') diff --git a/libdino/src/service/muc_manager.vala b/libdino/src/service/muc_manager.vala index cd4ff852..e9ad1b81 100644 --- a/libdino/src/service/muc_manager.vala +++ b/libdino/src/service/muc_manager.vala @@ -98,7 +98,14 @@ public class MucManager : StreamInteractionModule, Object { public Gee.List? get_occupants(Jid jid, Account account) { if (is_groupchat(jid, account)) { - return stream_interactor.get_module(PresenceManager.IDENTITY).get_full_jids(jid, account); + Gee.List ret = new ArrayList(Jid.equals_func); + Gee.List? full_jids = stream_interactor.get_module(PresenceManager.IDENTITY).get_full_jids(jid, account); + if (full_jids != null) { + ret.add_all(full_jids); + // Remove eventual presence from bare jid + ret.remove(jid); + } + return ret; } return null; } @@ -107,10 +114,7 @@ public class MucManager : StreamInteractionModule, Object { Gee.List? occupants = get_occupants(jid, account); Jid? own_jid = get_own_jid(jid, account); if (occupants != null && own_jid != null) { - Gee.List occupants_ = new ArrayList(Jid.equals_func); - occupants_.add_all(occupants); - occupants_.remove(own_jid); - return occupants_; + occupants.remove(own_jid); } return occupants; } @@ -207,6 +211,11 @@ public class MucManager : StreamInteractionModule, Object { return null; } + public bool has_avatar(Jid muc_jid, Account account) { + Gee.List? full_jids = stream_interactor.get_module(PresenceManager.IDENTITY).get_full_jids(muc_jid, account); + return full_jids != null && full_jids.contains(muc_jid); + } + private Xep.Muc.Flag? get_muc_flag(Account account) { XmppStream? stream = stream_interactor.get_stream(account); if (stream != null) { -- cgit v1.2.3-70-g09d2