From 90a8583ad0f2b487269d634e8700175e6c58b6dc Mon Sep 17 00:00:00 2001 From: Tulir Asokan Date: Sun, 29 Oct 2023 11:56:31 +0200 Subject: [PATCH] Include partial quote target text in Matrix event --- mautrix_telegram/formatter/__init__.py | 2 +- mautrix_telegram/formatter/from_telegram.py | 21 ++++++++++++++++--- .../portal_util/message_convert.py | 12 +++++++++++ 3 files changed, 31 insertions(+), 4 deletions(-) diff --git a/mautrix_telegram/formatter/__init__.py b/mautrix_telegram/formatter/__init__.py index 8a0799c0..53e40d45 100644 --- a/mautrix_telegram/formatter/__init__.py +++ b/mautrix_telegram/formatter/__init__.py @@ -1,2 +1,2 @@ from .from_matrix import matrix_reply_to_telegram, matrix_to_telegram -from .from_telegram import telegram_to_matrix +from .from_telegram import telegram_text_to_matrix_html, telegram_to_matrix diff --git a/mautrix_telegram/formatter/from_telegram.py b/mautrix_telegram/formatter/from_telegram.py index 937c856d..d012117d 100644 --- a/mautrix_telegram/formatter/from_telegram.py +++ b/mautrix_telegram/formatter/from_telegram.py @@ -176,6 +176,21 @@ async def _convert_custom_emoji( entities[i] = ReuploadedCustomEmoji(entity, custom_emojis[entity.document_id]) +async def telegram_text_to_matrix_html( + source: au.AbstractUser, + text: str, + entities: list[TypeMessageEntity], + client: MautrixTelegramClient | None = None, +) -> str: + if not entities: + return escape(text).replace("\n", "
") + await _convert_custom_emoji(source, entities, client=client) + text = add_surrogate(text) + html = await _telegram_entities_to_matrix_catch(text, entities) + html = del_surrogate(html) + return html + + async def telegram_to_matrix( evt: Message | SponsoredMessage, source: au.AbstractUser, @@ -192,10 +207,10 @@ async def telegram_to_matrix( ) entities = override_entities or evt.entities if entities: - await _convert_custom_emoji(source, entities, client=client) content.format = Format.HTML - html = await _telegram_entities_to_matrix_catch(add_surrogate(content.body), entities) - content.formatted_body = del_surrogate(html) + content.formatted_body = await telegram_text_to_matrix_html( + source, content.body, entities, client=client + ) if require_html: content.ensure_has_html() diff --git a/mautrix_telegram/portal_util/message_convert.py b/mautrix_telegram/portal_util/message_convert.py index c4bf61ef..b89e9dc6 100644 --- a/mautrix_telegram/portal_util/message_convert.py +++ b/mautrix_telegram/portal_util/message_convert.py @@ -262,6 +262,17 @@ async def _set_reply( return elif isinstance(evt.reply_to, MessageReplyStoryHeader): return + + if evt.reply_to.quote and content.msgtype.is_text: + content.ensure_has_html() + quote_html = await formatter.telegram_text_to_matrix_html( + source, evt.reply_to.quote_text, evt.reply_to.quote_entities + ) + content.formatted_body = ( + f"
{quote_html}
" + f"{content.formatted_body}" + ) + space = ( evt.peer_id.channel_id if isinstance(evt, Message) and isinstance(evt.peer_id, PeerChannel) @@ -275,6 +286,7 @@ async def _set_reply( if isinstance(evt.reply_to.reply_to_peer_id, PeerChannel) else source.tgid ) + reply_to_id = TelegramID(evt.reply_to.reply_to_msg_id) msg = await DBMessage.get_one_by_tgid(reply_to_id, space) no_fallback = no_fallback or self.config["bridge.disable_reply_fallbacks"]