Add /api/v1/FileProxy, support for Telegram file linking

This commit is contained in:
2025-01-22 18:10:56 +01:00
parent 90fbf5033c
commit dc8e531079
5 changed files with 137 additions and 41 deletions

View File

@@ -10,13 +10,27 @@ def get_message_wrapper(context:EventContext, data:InputMessageData):
if check_bot_admin(data.user) and (message_id := data.command.arguments.message_id) and (room_id := (data.command.arguments.room_id or data.room.id)):
return get_message(context, {"message_id": message_id, "room": {"id": room_id}})
# TODO work with links to messages
# TODO dump and getmessage should work with links to messages!
def cDump(context:EventContext, data:InputMessageData):
if not (message := (data.quoted or get_message_wrapper(context, data))):
return send_status_400(context, data.user.settings.language)
text = data_to_json(message, indent=" ")
return send_message(context, {"text_html": f'<pre>{html_escape(text)}</pre>'})
def cGetLink(context:EventContext, data:InputMessageData):
if not (message := (data.quoted or get_message_wrapper(context, data))):
return send_status_400(context, data.user.settings.language)
text = ''
if (url := message.message_url):
text += f"Message: {url}\n"
if (media := message.media) and (url := media.url):
link = get_media_link(url, type=media.type, timestamp=message.timestamp, access_token=tuple(WebTokens)[0])
text += f"Media: {link or url}\n"
if not text:
return send_status_400(context, data.user.settings.language)
return send_message(context, {"text_plain": text})
def cGetMessage(context:EventContext, data:InputMessageData):
if not (message := get_message_wrapper(context, data)):
return send_status_400(context, data.user.settings.language)
@@ -27,6 +41,10 @@ register_module(name="Dumper", group="Geek", endpoints=[
"message_id": True,
"room_id": True,
}),
SafeNamespace(names=["getlink"], handler=cGetLink, quoted=True, arguments={
"message_id": True,
"room_id": True,
}),
SafeNamespace(names=["getmessage"], handler=cGetMessage, arguments={
"message_id": True,
"room_id": True,