# webhook_handler.py import sqlite3 import json def handle_webhook(data, key_callback_vk, db_name): # Преобразуем строку key_callback_vk в JSON key_callback_dict = json.loads(key_callback_vk) # Проверяем тип события if data['type'] == 'confirmation': # Получаем номер сообщества из данных group_id = str(data['group_id']) # Возвращаем соответствующий пароль return key_callback_dict.get(group_id, 'unknown') # Обработка события подписки на рассылку if data['type'] == 'message_allow': user_id = data['object']['user_id'] group_id = data['group_id'] print(f"User {user_id} subscribed to the mailing list of group {group_id}") # Записываем информацию о подписке в базу данных conn = sqlite3.connect(db_name) cursor = conn.cursor() # Проверяем, существует ли запись для данного пользователя cursor.execute("SELECT canal FROM contacts WHERE vk_id = ?", (user_id,)) result = cursor.fetchone() if result: # Обновляем запись, если пользователь уже существует canal_data = json.loads(result[0]) if result[0] else {} canal_data[str(group_id)] = '1' canal_json = json.dumps(canal_data) cursor.execute("UPDATE contacts SET canal = ? WHERE vk_id = ?", (canal_json, user_id)) else: # Создаем новую запись, если пользователь не существует canal_data = {str(group_id): '1'} canal_json = json.dumps(canal_data) cursor.execute("INSERT INTO contacts (vk_id, canal) VALUES (?, ?)", (user_id, canal_json)) conn.commit() conn.close() return 'ok' # Обработка события отписки от рассылки if data['type'] == 'message_deny': user_id = data['object']['user_id'] group_id = data['group_id'] print(f"User {user_id} unsubscribed from the mailing list of group {group_id}") # Записываем информацию об отписке в базу данных conn = sqlite3.connect(db_name) cursor = conn.cursor() # Проверяем, существует ли запись для данного пользователя cursor.execute("SELECT canal FROM contacts WHERE vk_id = ?", (user_id,)) result = cursor.fetchone() if result: # Обновляем запись, если пользователь уже существует canal_data = json.loads(result[0]) if result[0] else {} canal_data[str(group_id)] = '0' canal_json = json.dumps(canal_data) cursor.execute("UPDATE contacts SET canal = ? WHERE vk_id = ?", (canal_json, user_id)) else: # Создаем новую запись, если пользователь не существует canal_data = {str(group_id): '0'} canal_json = json.dumps(canal_data) cursor.execute("INSERT INTO contacts (vk_id, canal) VALUES (?, ?)", (user_id, canal_json)) conn.commit() conn.close() return 'ok' # Если тип события неизвестен, возвращаем ошибку return 'unknown event', 400