Replace mentioned user IDs and emote IDs with names
This commit is contained in:
parent
7de214342b
commit
b6bf341127
1 changed files with 43 additions and 17 deletions
60
main.py
60
main.py
|
@ -48,26 +48,50 @@ async def on_message(message):
|
||||||
if message.author.bot:
|
if message.author.bot:
|
||||||
return
|
return
|
||||||
|
|
||||||
message_ = f"<{message.author.name}> {message.content}"
|
# Replace IDs in mentions with the tagged user's name
|
||||||
|
content = await process(message.content, "emote_")
|
||||||
|
content = await process(content, "mention")
|
||||||
|
|
||||||
|
message_ = f"<{message.author.name}> {content}"
|
||||||
|
|
||||||
if str(message.channel.id) == config["channel_id"]:
|
if str(message.channel.id) == config["channel_id"]:
|
||||||
await message_send(message_)
|
await message_send(message_)
|
||||||
|
|
||||||
|
|
||||||
async def emote(message):
|
async def process(message, category):
|
||||||
# Extract emotes from message
|
# Replace emote names with emote IDs (Matrix -> Discord)
|
||||||
emote_list = []
|
if category == "emote":
|
||||||
for item in message.split():
|
start = end = ":"
|
||||||
if item[0] == item[-1] == ":":
|
start_ = 1
|
||||||
emote_list.append(item[1:-1])
|
|
||||||
|
|
||||||
# Replace emotes with IDs
|
# Replace emote IDs with emote names (Discord -> Matrix)
|
||||||
for emote in emote_list:
|
elif category == "emote_":
|
||||||
emote = discord.utils.get(discord_client.emojis, name=emote)
|
start = "<:"
|
||||||
if emote is not None:
|
start_ = 2
|
||||||
emote = str(emote)
|
end = ">"
|
||||||
replace_emote = emote.split(":")[1]
|
|
||||||
message = message.replace(f":{replace_emote}:", emote)
|
# Replace mentioned user IDs with names (Discord -> Matrix)
|
||||||
|
elif category == "mention":
|
||||||
|
start = "<@!"
|
||||||
|
start_ = 3
|
||||||
|
end = ">"
|
||||||
|
|
||||||
|
for item in message.split():
|
||||||
|
if item.startswith(start) and item.endswith(end):
|
||||||
|
item_ = item[start_:-1]
|
||||||
|
|
||||||
|
if category == "emote":
|
||||||
|
emote = discord.utils.get(discord_client.emojis, name=item_)
|
||||||
|
if emote is not None:
|
||||||
|
message = message.replace(item, str(emote))
|
||||||
|
|
||||||
|
elif category == "emote_":
|
||||||
|
emote_name = item_.split(":")[0]
|
||||||
|
message = message.replace(item, f":{emote_name}:")
|
||||||
|
|
||||||
|
elif category == "mention":
|
||||||
|
user = discord_client.get_user(int(item_))
|
||||||
|
message = message.replace(item, f"@{user.name}")
|
||||||
|
|
||||||
return message
|
return message
|
||||||
|
|
||||||
|
@ -85,7 +109,7 @@ async def webhook_send(author, avatar, message):
|
||||||
hook = await channel.create_webhook(name=hook_name)
|
hook = await channel.create_webhook(name=hook_name)
|
||||||
|
|
||||||
# Replace emote names
|
# Replace emote names
|
||||||
message = await emote(message)
|
message = await process(message, "emote")
|
||||||
|
|
||||||
await hook.send(username=author, avatar_url=avatar, content=message)
|
await hook.send(username=author, avatar_url=avatar, content=message)
|
||||||
|
|
||||||
|
@ -110,6 +134,7 @@ async def create_matrix_client():
|
||||||
# Sync forever
|
# Sync forever
|
||||||
await matrix_client.sync_forever(timeout=timeout)
|
await matrix_client.sync_forever(timeout=timeout)
|
||||||
|
|
||||||
|
await matrix_client.logout()
|
||||||
await matrix_client.close()
|
await matrix_client.close()
|
||||||
|
|
||||||
|
|
||||||
|
@ -125,7 +150,8 @@ async def message_send(message):
|
||||||
|
|
||||||
|
|
||||||
async def message_callback(room, event):
|
async def message_callback(room, event):
|
||||||
message = event.formatted_body or event.body
|
message = event.body
|
||||||
|
|
||||||
if not message:
|
if not message:
|
||||||
return
|
return
|
||||||
|
|
||||||
|
@ -144,7 +170,7 @@ async def message_callback(room, event):
|
||||||
|
|
||||||
avatar = user.avatar_url.split("/")[-1]
|
avatar = user.avatar_url.split("/")[-1]
|
||||||
avatar = "https://matrix.org/_matrix/media/r0/download/" \
|
avatar = "https://matrix.org/_matrix/media/r0/download/" \
|
||||||
+ f"{homeserver}/{avatar}"
|
f"{homeserver}/{avatar}"
|
||||||
break
|
break
|
||||||
|
|
||||||
await webhook_send(author, avatar, message)
|
await webhook_send(author, avatar, message)
|
||||||
|
|
Loading…
Reference in a new issue