aboutsummaryrefslogtreecommitdiffstats
path: root/bot/utils/messages.py
diff options
context:
space:
mode:
authorGravatar ToxicKidz <[email protected]>2021-05-10 09:45:32 -0400
committerGravatar ToxicKidz <[email protected]>2021-05-10 09:45:32 -0400
commite15d1eca771901280297bee15d5ee901c965d0d7 (patch)
treee4c05ee7ab13aa852c68e81464999b5bd054a356 /bot/utils/messages.py
parentchore: Use ctx instead of ctx.channel (diff)
parentMerge pull request #725 from python-discord/change-to-fetch-user (diff)
fix: Resolve Merge Conflicts
Diffstat (limited to 'bot/utils/messages.py')
-rw-r--r--bot/utils/messages.py19
1 files changed, 19 insertions, 0 deletions
diff --git a/bot/utils/messages.py b/bot/utils/messages.py
new file mode 100644
index 00000000..a6c035f9
--- /dev/null
+++ b/bot/utils/messages.py
@@ -0,0 +1,19 @@
+import re
+from typing import Optional
+
+
+def sub_clyde(username: Optional[str]) -> Optional[str]:
+ """
+ Replace "e"/"E" in any "clyde" in `username` with a Cyrillic "е"/"E" and return the new string.
+
+ Discord disallows "clyde" anywhere in the username for webhooks. It will return a 400.
+ Return None only if `username` is None.
+ """
+ def replace_e(match: re.Match) -> str:
+ char = "е" if match[2] == "e" else "Е"
+ return match[1] + char
+
+ if username:
+ return re.sub(r"(clyd)(e)", replace_e, username, flags=re.I)
+ else:
+ return username # Empty string or None