Files
abot/db/sign_in_redis.py
2025-09-17 14:26:55 +08:00

97 lines
3.7 KiB
Python

# -*- coding: utf-8 -*-
from datetime import datetime
from typing import Dict, Optional
from db.connection import DBConnectionManager
class SignInRedisDB:
"""签到系统Redis相关操作"""
def __init__(self, db_manager: DBConnectionManager):
self.db_manager = db_manager
self.prefix = "group:sign_in:"
def get_redis_connection(self):
"""获取Redis连接"""
return self.db_manager.get_redis_connection()
def load_signin_count(self) -> Dict[str, int]:
"""加载签到人数数据"""
signin_count = {}
with self.get_redis_connection() as redis_client:
keys = redis_client.keys(f'{self.prefix}*')
for key in keys:
if isinstance(key, bytes):
key = key.decode('utf-8')
if key == f'{self.prefix}last_reset_date':
continue
group_id = key.replace(self.prefix, '')
count = redis_client.get(key)
if count is not None:
if isinstance(count, bytes):
count = count.decode('utf-8')
signin_count[group_id] = int(count)
return signin_count
def save_signin_count(self, group_id: str, count: int) -> bool:
"""保存签到人数"""
try:
with self.get_redis_connection() as redis_client:
redis_client.set(f'{self.prefix}{group_id}', count)
return True
except Exception:
return False
def get_last_reset_date(self) -> Optional[datetime.date]:
"""获取最后重置日期"""
with self.get_redis_connection() as redis_client:
date_str = redis_client.get(f'{self.prefix}last_reset_date')
if date_str:
if isinstance(date_str, bytes):
date_str = date_str.decode('utf-8')
return datetime.strptime(date_str, '%Y-%m-%d').date()
return None
def save_last_reset_date(self, date: datetime.date) -> bool:
"""保存最后重置日期"""
try:
with self.get_redis_connection() as redis_client:
redis_client.set(f'{self.prefix}last_reset_date', date.strftime('%Y-%m-%d'))
return True
except Exception:
return False
def reset_daily_counts(self) -> bool:
"""重置每日签到计数"""
try:
with self.get_redis_connection() as redis_client:
keys = redis_client.keys(f'{self.prefix}*')
for key in keys:
if isinstance(key, bytes):
key = key.decode('utf-8')
if key != f'{self.prefix}last_reset_date':
redis_client.delete(key)
return True
except Exception:
return False
def get_user_total_sign_count_key(self, wx_id: str, group_id: str) -> str:
"""获取用户总签到次数的Redis键"""
return f"{self.prefix}sign:total:{wx_id}:{group_id}"
def increment_user_sign_count(self, wx_id: str, group_id: str) -> int:
"""增加用户签到总次数"""
key = self.get_user_total_sign_count_key(wx_id, group_id)
return self.redis.incr(key)
def get_user_total_sign_count(self, wx_id: str, group_id: str) -> int:
"""获取用户签到总次数"""
key = self.get_user_total_sign_count_key(wx_id, group_id)
count = self.redis.get(key)
return int(count) if count else 0
def set_user_total_sign_count(self, wx_id: str, group_id: str, count: int) -> bool:
"""设置用户签到总次数"""
key = self.get_user_total_sign_count_key(wx_id, group_id)
return self.redis.set(key, count)