4 Commits

Author SHA1 Message Date
miloszowi
e44f4b75a5 0.3.2 - fixed a bug with missing + in replier 2024-02-28 11:32:57 +01:00
miloszowi
e242584974 0.3.1 - Fixed telegram restricted characters 2024-02-28 11:27:07 +01:00
miloszowi
878091deae fixed bug when /join@everyone_mention_bot was treated as a message handler action 2023-11-25 14:58:58 +00:00
Miłosz Guglas
a6b441b197 Merge pull request #5 from miloszowi/develop
0.3.0 Release
2022-03-10 16:08:02 +01:00
3 changed files with 18 additions and 6 deletions

View File

@@ -1,6 +1,12 @@
# Change Log # Change Log
All notable changes to this project will be documented in this file. All notable changes to this project will be documented in this file.
## [0.3.2] - 28.02.2023
### Changed
- fixed bug with missing '+' in replier
## [0.3.1] - 28.02.2023
### Changed
- fixed markdown replier to respect restricted characters provided in the [api docs](https://core.telegram.org/bots/api#markdownv2-style)
## [0.3.0] - 12.11.2021 ## [0.3.0] - 12.11.2021
### Added ### Added
- Dynamic mentioning by `@` character - Dynamic mentioning by `@` character

View File

@@ -38,7 +38,7 @@ class InboundMessage:
GroupNameValidator.validate(group_name) GroupNameValidator.validate(group_name)
# done upon resolving a message handler action # done upon resolving a message handler action
if '@' in message_content: if '@' in message_content and '@everyone_mention_bot' not in message_content:
searched_message_part = [part for part in message_content.split(' ') if '@' in part][0] searched_message_part = [part for part in message_content.split(' ') if '@' in part][0]
group_name = re.sub(r'\W+', '', searched_message_part).lower() group_name = re.sub(r'\W+', '', searched_message_part).lower()

View File

@@ -8,24 +8,30 @@ from logger import Logger
class Replier: class Replier:
@staticmethod @staticmethod
def interpolate(content: str, inbound_message: InboundMessage): def interpolate(content: str, inbound_message: InboundMessage):
return content.format( formatted = content.format(
mention_markdown(inbound_message.user_id, inbound_message.username), mention_markdown(inbound_message.user_id, inbound_message.username),
inbound_message.group_name inbound_message.group_name
) )
telegramRestrictionCharacters = ['_', '*', '[', ']', '(', ')', '~', '`', '>', '#', '+', '-', '=', '|', '{', '}', '.', '!']
for character in telegramRestrictionCharacters:
formatted.replace(character, "\\" + character)
return formatted
@staticmethod @staticmethod
def markdown(update: Update, message: str, reply_markup: Optional[InlineKeyboardMarkup] = None) -> None: def markdown(update: Update, message: str, reply_markup: Optional[InlineKeyboardMarkup] = None) -> None:
try: try:
update.effective_message.reply_markdown_v2(message, reply_markup=reply_markup) update.effective_message.reply_markdown_v2(message, reply_markup=reply_markup)
except Exception as err: except Exception as err:
Logger.error(str(err)) Logger.error("replier.markdown error: " + str(err))
@staticmethod @staticmethod
def html(update: Update, html: str, reply_markup: Optional[InlineKeyboardMarkup] = None) -> None: def html(update: Update, html: str, reply_markup: Optional[InlineKeyboardMarkup] = None) -> None:
try: try:
update.effective_message.reply_html(html, reply_markup=reply_markup, disable_web_page_preview=True) update.effective_message.reply_html(html, reply_markup=reply_markup, disable_web_page_preview=True)
except Exception as err: except Exception as err:
Logger.error(str(err)) Logger.error("replier.html error: " + str(err))