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

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

@@ -170,4 +170,27 @@ async def add_referal(
raise HTTPException(status_code=500, detail="Database error") raise HTTPException(status_code=500, detail="Database error")
except Exception as e: except Exception as e:
logger.exception(f"Неожиданная ошибка при добавлении рефералу {referrer_id}: {e}") logger.exception(f"Неожиданная ошибка при добавлении рефералу {referrer_id}: {e}")
raise HTTPException(status_code=500, detail=str(e))
@router.get("/user/{telegram_id}/referrals", summary="Получить колво рефералов")
async def get_referral_count(
telegram_id: int,
db_manager: DatabaseManager = Depends(get_database_manager)
):
try:
result = await db_manager.get_referrals_count(telegram_id)
if result == "ERROR":
logger.error(f"Ошибка получения рефералов для пользователя: {telegram_id}")
raise HTTPException(status_code=500, detail="Failed to get referrals")
logger.info(f"Количество приглашённых {result}")
return {"invited_count": result}
except HTTPException as http_ex:
logger.warning(f"HTTP ошибка: {http_ex.detail}")
raise http_ex
except SQLAlchemyError as db_ex:
logger.error(f"Ошибка базы данных при получении рефералов пользователя {telegram_id}: {db_ex}")
raise HTTPException(status_code=500, detail="Database error")
except Exception as e:
logger.exception(f"Неожиданная ошибка при получении рефералов {telegram_id}: {e}")
raise HTTPException(status_code=500, detail=str(e)) raise HTTPException(status_code=500, detail=str(e))

View File

@@ -61,6 +61,18 @@ class DatabaseManager:
""" """
return await self.postgres_repo.get_last_transactions(telegram_id, limit) return await self.postgres_repo.get_last_transactions(telegram_id, limit)
async def get_referrals_count(self,telegram_id: int) -> int:
"""
Docstring for get_referrals_count
:param self: Description
:param telegram_id: Description
:type telegram_id: int
:return: Description
:rtype: int
"""
return await self.postgres_repo.get_referrals_count(telegram_id)
# async def update_balance(self, telegram_id: int, amount: float): # async def update_balance(self, telegram_id: int, amount: float):
# """ # """
# Обновляет баланс пользователя и добавляет транзакцию. # Обновляет баланс пользователя и добавляет транзакцию.

View File

@@ -277,4 +277,24 @@ class PostgresRepository:
except SQLAlchemyError as e: except SQLAlchemyError as e:
self.logger.error(f"Ошибка при поиске плана: {plan_id}: {e}") self.logger.error(f"Ошибка при поиске плана: {plan_id}: {e}")
await session.rollback() 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