generated from kyegomez/Python-Package-Template
-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtelegram_api.py
176 lines (143 loc) · 5.21 KB
/
telegram_api.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
import os
import sys
import logging
from telegram.ext import (
ApplicationBuilder,
ContextTypes,
CommandHandler,
MessageHandler,
filters,
)
from telegram import Update
from mcs.main import medical_coder
from dotenv import load_dotenv
# Load environment variables
load_dotenv()
# Set up logging
logging.basicConfig(
level=logging.INFO,
format="%(asctime)s - %(levelname)s - %(message)s",
handlers=[logging.StreamHandler()],
)
logger = logging.getLogger(__name__)
def check_mention(update: Update) -> bool:
"""Check if the bot was mentioned in the message"""
message = update.message
bot_username = update.get_bot().username
# Check for @mentions
if message.entities:
for entity in message.entities:
if entity.type == "mention":
mention = message.text[
entity.offset : entity.offset + entity.length
]
if mention.lower() == f"@{bot_username.lower()}":
return True
# Check for text_mentions
if message.entities:
for entity in message.entities:
if entity.type == "text_mention" and entity.user.is_bot:
if (
entity.user.username.lower()
== bot_username.lower()
):
return True
return False
async def process_message(update: Update) -> str:
"""Clean up message by removing bot mention"""
message = update.message.text
bot_username = update.get_bot().username
# Remove @username
cleaned_message = message.replace(f"@{bot_username}", "").strip()
# If the message starts with the bot's username without @, remove it too
if cleaned_message.lower().startswith(bot_username.lower()):
cleaned_message = cleaned_message[len(bot_username) :].strip()
return cleaned_message
async def start(update: Update, context: ContextTypes.DEFAULT_TYPE):
"""Handle /start command - only works in DMs"""
if update.message.chat.type != "private":
return
welcome_message = "👋 Hello! I am your medical coding assistant bot. Send me any medical coding question!"
await update.message.reply_text(welcome_message)
logger.info(f"Start command from user {update.effective_user.id}")
async def help(update: Update, context: ContextTypes.DEFAULT_TYPE):
"""Handle /help command - only works in DMs"""
if update.message.chat.type != "private":
return
help_message = (
"Just send me any medical coding question and I'll help you!\n"
"Commands:\n"
"/start - Start the bot\n"
"/help - Show this help message\n\n"
"In groups, tag me with @botname to get my attention!"
)
await update.message.reply_text(help_message)
logger.info(f"Help command from user {update.effective_user.id}")
async def handle_message(
update: Update, context: ContextTypes.DEFAULT_TYPE
):
"""Handle incoming messages - works in DMs and when mentioned in groups"""
# Check if it's a DM or mention
if update.message.chat.type != "private" and not check_mention(
update
):
return
user_id = update.effective_user.id
logger.info(
f"Message received from {user_id} in {update.message.chat.type} chat"
)
try:
# Clean up the message
cleaned_message = await process_message(update)
if not cleaned_message:
return
# Process with medical coder
response = medical_coder.run(
cleaned_message
+ "Respond with a cute girly vibe as if you were a waifu extremely happy and concerned about the user"
+ "Respond in the language of the user's request"
)
# Send response
await update.message.reply_text(response)
logger.info(f"Sent response to user {user_id}")
except Exception as e:
logger.error(
f"Error processing message: {str(e)}", exc_info=True
)
await update.message.reply_text(
"Sorry, I encountered an error while processing your request. Please try again."
)
def main():
# Get token from environment variable
token = os.getenv("TELEGRAM_KEY")
if not token:
logger.error(
"TELEGRAM_KEY not found in environment variables"
)
sys.exit(1)
try:
# Create application
application = ApplicationBuilder().token(token).build()
# Add handlers
application.add_handler(CommandHandler("start", start))
application.add_handler(CommandHandler("help", help))
application.add_handler(
MessageHandler(
filters.TEXT & ~filters.COMMAND, handle_message
)
)
# Run the bot
logger.info("Bot started successfully")
application.run_polling(allowed_updates=Update.ALL_TYPES)
except Exception as e:
logger.error(f"Critical error: {str(e)}", exc_info=True)
sys.exit(1)
if __name__ == "__main__":
try:
logger.info("Starting bot application")
main()
except KeyboardInterrupt:
logger.info("Bot stopped by user")
except Exception as e:
logger.error(f"Unhandled exception: {str(e)}", exc_info=True)
sys.exit(1)