Merge branch 'mam-onetoone-nick-fix' into 'master'

Fix mam own nick in one to one tabs

See merge request poezio/poezio!122
This commit is contained in:
Maxime Buquet 2020-05-25 18:49:32 +02:00
commit 5b8e46c9a7

View file

@ -46,8 +46,9 @@ def make_line(
tab: tabs.ChatTab, tab: tabs.ChatTab,
text: str, text: str,
time: datetime, time: datetime,
nick: str, jid: JID,
identifier: str = '', identifier: str = '',
deterministic: bool = True,
) -> Message: ) -> Message:
"""Adds a textual entry in the TextBuffer""" """Adds a textual entry in the TextBuffer"""
@ -55,9 +56,8 @@ def make_line(
time = time.replace(tzinfo=timezone.utc).astimezone(tz=None) time = time.replace(tzinfo=timezone.utc).astimezone(tz=None)
time = time.replace(tzinfo=None) time = time.replace(tzinfo=None)
deterministic = config.get_by_tabname('deterministic_nick_colors', tab.jid.bare)
if isinstance(tab, tabs.MucTab): if isinstance(tab, tabs.MucTab):
nick = nick.split('/')[1] nick = jid.resource
user = tab.get_user_by_name(nick) user = tab.get_user_by_name(nick)
if deterministic: if deterministic:
if user: if user:
@ -76,11 +76,12 @@ def make_line(
color = xhtml.colors.get(color) color = xhtml.colors.get(color)
color = (color, -1) color = (color, -1)
else: else:
if nick.split('/')[0] == tab.core.xmpp.boundjid.bare: if jid.bare == tab.core.xmpp.boundjid.bare:
nick = tab.core.own_nick
color = get_theme().COLOR_OWN_NICK color = get_theme().COLOR_OWN_NICK
else: else:
color = get_theme().COLOR_REMOTE_USER color = get_theme().COLOR_REMOTE_USER
nick = tab.get_nick() nick = tab.get_nick()
return Message( return Message(
txt=text, txt=text,
identifier=identifier, identifier=identifier,
@ -133,7 +134,7 @@ def _parse_message(msg: SMessage) -> Dict:
message = forwarded['stanza'] message = forwarded['stanza']
return { return {
'time': forwarded['delay']['stamp'], 'time': forwarded['delay']['stamp'],
'nick': str(message['from']), 'jid': message['from'],
'text': message['body'], 'text': message['body'],
'identifier': message['origin-id'] 'identifier': message['origin-id']
} }
@ -147,13 +148,17 @@ async def retrieve_messages(tab: tabs.ChatTab,
msg_count = 0 msg_count = 0
msgs = [] msgs = []
to_add = [] to_add = []
deterministic = config.get_by_tabname(
'deterministic_nick_colors',
tab.jid.bare
)
try: try:
async for rsm in results: async for rsm in results:
for msg in rsm['mam']['results']: for msg in rsm['mam']['results']:
if msg['mam_result']['forwarded']['stanza'] \ if msg['mam_result']['forwarded']['stanza'] \
.xml.find('{%s}%s' % ('jabber:client', 'body')) is not None: .xml.find('{%s}%s' % ('jabber:client', 'body')) is not None:
args = _parse_message(msg) args = _parse_message(msg)
msgs.append(make_line(tab, **args)) msgs.append(make_line(tab, deterministic=deterministic, **args))
for msg in reversed(msgs): for msg in reversed(msgs):
to_add.append(msg) to_add.append(msg)
msg_count += 1 msg_count += 1