Merge pull request 'master' (#39) from master into dev

Reviewed-on: #39
This commit is contained in:
emmatveev 2024-12-21 19:27:36 +03:00
commit 96eef035c5
3 changed files with 14 additions and 28 deletions

View File

@ -22,7 +22,6 @@ services:
networks:
- configurator
- queues-development
- locks-development
environment:
STAGE: "development"
command: mailbox
@ -39,5 +38,3 @@ networks:
external: true
queues-development:
external: true
locks-development:
external: true

View File

@ -22,7 +22,6 @@ services:
networks:
- configurator
- queues
- locks
environment:
STAGE: "production"
command: mailbox
@ -39,5 +38,3 @@ networks:
external: true
queues:
external: true
locks:
external: true

View File

@ -1,5 +1,5 @@
import telebot
import threading
import multiprocessing
import time
from daemons import base
@ -10,45 +10,37 @@ from utils import queues
class Daemon(base.Daemon):
def __init__(self):
super().__init__()
self.telegram_bots: dict[str, dict[str, telebot.TeleBot|None]] = {}
self.threads: dict[str, dict[str, threading.Thread|None]] = {}
self.processes: dict[str, multiprocessing.Process|None] = {}
def execute(self):
while True:
bots = platform.platform_client.get_config('bots')
for project_name, project in bots.items():
if project_name not in self.telegram_bots:
self.telegram_bots[project_name] = {}
self.threads[project_name] = {}
for bot_name, bot_info in project.items():
if bot_name not in self.telegram_bots[project_name]:
self.telegram_bots[project_name][bot_name] = None
self.threads[project_name][bot_name] = None
bot = self.telegram_bots[project_name][bot_name]
key = f'{project_name}_{bot_name}'
proc = self.processes.get(key)
if bot_info.get('poll_enabled'):
if bot is not None and self.threads[project_name][bot_name].is_alive():
if proc and proc.is_alive():
print(f'process for {project_name} {bot_name} is alive')
continue
print(f'starting process for {project_name} {bot_name}')
bot = telebot.TeleBot(bot_info['secrets']['telegram_token'])
thread = self.start_polling(bot, bot_info['queue'])
self.telegram_bots[project_name][bot_name] = bot
self.threads[project_name][bot_name] = thread
process = multiprocessing.Process(target=self.start_polling, args=(bot_info['secrets']['telegram_token'], bot_info['queue']))
process.start()
self.processes[key] = process
print(f'started process for {project_name} {bot_name}')
else:
if bot is None:
if proc is None:
print(f'process for {project_name} {bot_name} is not alive')
continue
print(f'terminating process for {project_name} {bot_name}')
bot.stop_bot()
self.telegram_bots[project_name][bot_name] = None
proc.terminate()
self.processes[key] = None
print(f'terminated process for {project_name} {bot_name}')
time.sleep(10)
def start_polling(self, bot: telebot.TeleBot, queue: str) -> threading.Thread:
def start_polling(self, token: str, queue: str):
bot = telebot.TeleBot(token)
@bot.message_handler(content_types=['audio', 'photo', 'voice', 'video', 'document', 'animation', 'text', 'location', 'contact', 'sticker', 'video_note'])
def do_action(message: telebot.types.Message):
queues.set_task(self.stub, queue, message.json, 1)
thread = threading.Thread(target=bot.polling)
thread.start()
return thread
bot.polling()