On kick, get the actor 'nick', before trying the 'jid'
'nick' attribute has been introduced recently in the XEP. We still try the 'jid' attribute for backward compatibility. And also we don’t traceback anymore if any of these fields is not present.
This commit is contained in:
parent
4a091b3d2d
commit
0c507859fb
1 changed files with 4 additions and 2 deletions
|
@ -1641,9 +1641,11 @@ class MucTab(ChatTab):
|
||||||
When someone is kicked from a muc
|
When someone is kicked from a muc
|
||||||
"""
|
"""
|
||||||
self.users.remove(user)
|
self.users.remove(user)
|
||||||
by = presence.find('{%s}x/{%s}item/{%s}actor' % (NS_MUC_USER, NS_MUC_USER, NS_MUC_USER))
|
actor_elem = presence.find('{%s}x/{%s}item/{%s}actor' % (NS_MUC_USER, NS_MUC_USER, NS_MUC_USER))
|
||||||
reason = presence.find('{%s}x/{%s}item/{%s}reason' % (NS_MUC_USER, NS_MUC_USER, NS_MUC_USER))
|
reason = presence.find('{%s}x/{%s}item/{%s}reason' % (NS_MUC_USER, NS_MUC_USER, NS_MUC_USER))
|
||||||
by = by.attrib['jid'] if by is not None else None
|
by = None
|
||||||
|
if actor_elem is not None:
|
||||||
|
by = actor_elem.get('nick') or actor_elem.get('jid')
|
||||||
if from_nick == self.own_nick: # we are kicked
|
if from_nick == self.own_nick: # we are kicked
|
||||||
if by:
|
if by:
|
||||||
kick_msg = _('\x191}%(spec)s \x193}You\x19%(info_col)s} have been kicked by \x193}%(by)s') % {
|
kick_msg = _('\x191}%(spec)s \x193}You\x19%(info_col)s} have been kicked by \x193}%(by)s') % {
|
||||||
|
|
Loading…
Reference in a new issue