Files
crm.clientright.ru/ticket_form/monitor_redis.py
Fedor de011efba9 fix: исправлен конфликт имён переменных в loadDraft (claimId -> finalClaimId)
- Исправлена ошибка ReferenceError при загрузке черновиков
- Переименована локальная переменная claimId в finalClaimId для избежания конфликта с параметром функции
- Обновлена логика извлечения claim_id из разных источников (claim.claim_id, payload.claim_id, body.claim_id, claim.id)
- Добавлен fallback на параметр claimId функции для надёжности
2025-11-19 23:33:52 +03:00

58 lines
1.9 KiB
Python
Executable File

#!/usr/bin/env python3
"""
Redis Channel Monitor - слушает события на каналах ocr_events:*
"""
import redis
import json
import sys
from datetime import datetime
def monitor_redis_channels():
try:
# Подключаемся к Redis
r = redis.Redis(host='crm.clientright.ru', port=6379, decode_responses=True)
# Создаем PubSub объект
pubsub = r.pubsub()
# Подписываемся на pattern
pubsub.psubscribe('ocr_events:*')
print(f"🔊 Слушаем Redis каналы: ocr_events:*")
print(f"⏰ Начало мониторинга: {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}")
print("=" * 80)
print()
# Слушаем сообщения
for message in pubsub.listen():
if message['type'] == 'pmessage':
channel = message['channel']
data = message['data']
timestamp = datetime.now().strftime('%H:%M:%S.%f')[:-3]
print(f"{timestamp}")
print(f"📢 Канал: {channel}")
# Пытаемся распарсить JSON
try:
parsed_data = json.loads(data)
print(f"📦 Данные:")
print(json.dumps(parsed_data, indent=2, ensure_ascii=False))
except json.JSONDecodeError:
print(f"📦 Данные (raw): {data}")
print("-" * 80)
print()
except KeyboardInterrupt:
print("\n\n⛔ Мониторинг остановлен")
sys.exit(0)
except Exception as e:
print(f"❌ Ошибка: {e}")
sys.exit(1)
if __name__ == '__main__':
monitor_redis_channels()