twitch-tgbot/main.py

134 lines
4.6 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/usr/bin/python3
import time
import config_python
from twitchAPI.twitch import Twitch
import logging
from logging.handlers import TimedRotatingFileHandler
from termcolor import colored
import os
import sys
import telebot
streamer = config_python.streamer
app_id = config_python.appid
app_secret = config_python.appsecret
log_format = logging.Formatter('%(asctime)s %(levelname)s:%(message)s')
log_file = 'output.log'
def stream_message_worker(data: dict):
# Если это стрим, а не повтор, значит все в порядке
if data['type'] == 'live':
# Для удобства выносим в переменные
game_name = data['game_name']
stream_title = data['title']
stream_viewers = str(data['viewer_count'])
# Готовим сообщение
message = stream_title + '\n' + \
"Игра: " + game_name + '\n' + \
"Зрителей: " + stream_viewers
log.info(message)
# Если файл с айди существует, читаем его и редактируем сообщение из него
if os.path.exists('msgid'):
with open('msgid', 'r') as f:
msgid = f.read()
if msgid == '':
msgid = 0
else:
msgid = 0
if msgid == 0:
send_message = bot.send_message(config_python.tgchat, message)
print(send_message)
msgid = send_message.message_id
with open('msgid', 'w') as f:
f.write(str(msgid))
else:
try:
edit_msg = bot.edit_message_text(message, config_python.tgchat, int(msgid))
except telebot.apihelper.ApiTelegramException as e:
log.error(e)
# Если стрим не идет
def no_stream_msg_worker():
log.info(streamer + " Не стримит")
# Проверяем наличие файла
if os.path.exists('msgid'):
# Если файл существует - читаем
with open('msgid', 'r') as f:
msgid = f.read()
if msgid == '':
# Если пустой - удаляем
os.remove('msgid')
else:
# Если не пустой, то удаляем сообщение по айдишнику
try:
# Удаляем сообщение
edit_msg = bot.delete_message(config_python.tgchat, int(msgid))
except telebot.apihelper.ApiTelegramException as e:
log.error(e)
# В конце удаляем айди сообщения
os.remove('msgid')
def check_alive():
"""
1. Проверка на наличие стрима
1.1 Если нет - удалить lock файл, если он есть
1.2 Если есть - создать lock файл, запустить записывалку
"""
# Получаем инфо о стримере, если не получается, выходим с ошибкой
resolved_id = twitch_client.get_users(logins=[streamer])
if not resolved_id['data']:
log.error(
colored(
"Аккаунт " + streamer + " не найден",
'red',
)
)
# Достаем ID стримера из инфо
user_id = resolved_id['data'][0]['id']
# Получаем стримы
user_stream = twitch_client.get_streams(user_id=user_id)
# Если стрим/повтор идет, то идем дальше
if user_stream['data']:
stream_message_worker(user_stream['data'][0])
else:
# Если стрим не идет, то запускаем функцию без параметров
no_stream_msg_worker()
def get_console_handler():
console_handler = logging.StreamHandler(sys.stdout)
console_handler.setFormatter(log_format)
return console_handler
def get_file_handler():
file_handler = TimedRotatingFileHandler(log_file, when='midnight')
file_handler.setFormatter(log_format)
return file_handler
def get_logger(logger_name):
logger = logging.getLogger(logger_name)
logger.setLevel(logging.DEBUG)
logger.addHandler(get_console_handler())
logger.addHandler(get_file_handler())
logger.propagate = False
return logger
if __name__ == '__main__':
log = get_logger("main")
log.info("Запущен")
twitch_client = Twitch(app_id, app_secret)
bot = telebot.TeleBot(config_python.tgtoken)
while True:
check_alive()
time.sleep(300)