добавил подсчёт количества рефералов

This commit is contained in:
2025-12-05 13:58:45 +03:00
parent eb9e00b27c
commit f16cb3bc2e
3 changed files with 56 additions and 1 deletions

View File

@@ -277,4 +277,24 @@ class PostgresRepository:
except SQLAlchemyError as e:
self.logger.error(f"Ошибка при поиске плана: {plan_id}: {e}")
await session.rollback()
return None
return None
async def get_referrals_count(self, user_telegram_id: int) -> int:
"""
Получить количество рефералов пользователя.
:param user_telegram_id: Telegram ID пользователя-пригласителя
:return: Количество рефералов
"""
async for session in self.session_generator():
try:
result = await session.execute(
select(Referral)
.where(Referral.inviter_id == user_telegram_id)
)
referrals = result.scalars().all()
return len(referrals)
except SQLAlchemyError as e:
self.logger.error(f"Ошибка при получении количества рефералов для пользователя {user_telegram_id}: {e}")
return 0