Software /
code /
prosody
Comparison
plugins/mod_blocklist.lua @ 10052:0c35f353db68 0.11
mod_blocklist: Trigger resend of presence when unblocking a contact (fixes #1380)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Thu, 20 Jun 2019 21:20:00 +0200 |
parent | 9248:1d6a2cc389eb |
child | 10053:4b2cc8a60449 |
comparison
equal
deleted
inserted
replaced
10051:7d312e77c857 | 10052:0c35f353db68 |
---|---|
126 -- > When the user blocks communications with the contact, the user's | 126 -- > When the user blocks communications with the contact, the user's |
127 -- > server MUST send unavailable presence information to the contact (but | 127 -- > server MUST send unavailable presence information to the contact (but |
128 -- > only if the contact is allowed to receive presence notifications [...] | 128 -- > only if the contact is allowed to receive presence notifications [...] |
129 -- So contacts we need to do that for are added to the set below. | 129 -- So contacts we need to do that for are added to the set below. |
130 local send_unavailable = is_blocking and {}; | 130 local send_unavailable = is_blocking and {}; |
131 local send_available = not is_blocking and {}; | |
131 | 132 |
132 -- Because blocking someone currently also blocks the ability to reject | 133 -- Because blocking someone currently also blocks the ability to reject |
133 -- subscription requests, we'll preemptively reject such | 134 -- subscription requests, we'll preemptively reject such |
134 local remove_pending = is_blocking and {}; | 135 local remove_pending = is_blocking and {}; |
135 | 136 |
145 if is_contact_subscribed(username, module.host, jid) then | 146 if is_contact_subscribed(username, module.host, jid) then |
146 send_unavailable[jid] = true; | 147 send_unavailable[jid] = true; |
147 elseif is_contact_pending_in(username, module.host, jid) then | 148 elseif is_contact_pending_in(username, module.host, jid) then |
148 remove_pending[jid] = true; | 149 remove_pending[jid] = true; |
149 end | 150 end |
151 elseif is_contact_subscribed(username, module.host, jid) then | |
152 send_available[jid] = true; | |
150 end | 153 end |
151 end | 154 end |
152 | 155 |
153 if is_blocking and not next(new) then | 156 if is_blocking and not next(new) then |
154 -- <block/> element does not contain at least one <item/> child element | 157 -- <block/> element does not contain at least one <item/> child element |
201 roster[false].pending[jid] = nil; | 204 roster[false].pending[jid] = nil; |
202 end | 205 end |
203 save_roster(username, module.host, roster); | 206 save_roster(username, module.host, roster); |
204 -- Not much we can do about save failing here | 207 -- Not much we can do about save failing here |
205 end | 208 end |
209 else | |
210 local user_bare = username .. "@" .. module.host; | |
211 for jid in pairs(send_available) do | |
212 module:send(st.presence({ type = "probe", to = user_bare, from = jid })); | |
213 end | |
206 end | 214 end |
207 | 215 |
208 local blocklist_push = st.iq({ type = "set", id = "blocklist-push" }) | 216 local blocklist_push = st.iq({ type = "set", id = "blocklist-push" }) |
209 :add_child(action); -- I am lazy | 217 :add_child(action); -- I am lazy |
210 | 218 |