From 9cd5d8e0b9f52efd8af766bc34e27b07efb2eb4d Mon Sep 17 00:00:00 2001 From: gy9vin Date: Fri, 2 Jan 2026 19:23:52 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A4=D0=B8=D0=BA=D1=81=20=D0=BF=D1=80=D0=BE?= =?UTF-8?q?=D0=BC=D0=BE=D0=BA=D0=BE=D0=B4=D0=BE=D0=B2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/services/promocode_service.py | 20 +------------------- 1 file changed, 1 insertion(+), 19 deletions(-) diff --git a/app/services/promocode_service.py b/app/services/promocode_service.py index 548519b3..0e57adf4 100644 --- a/app/services/promocode_service.py +++ b/app/services/promocode_service.py @@ -54,8 +54,7 @@ class PromoCodeService: # Проверка "только для первой покупки" if getattr(promocode, 'first_purchase_only', False): - has_purchase = await self._user_has_paid_purchase(db, user_id) - if has_purchase: + if getattr(user, 'has_had_paid_subscription', False): return {"success": False, "error": "not_first_purchase"} balance_before_kopeks = user.balance_kopeks @@ -234,20 +233,3 @@ class PromoCodeService: effects.append("ℹ️ У вас уже есть активная подписка") return "\n".join(effects) if effects else "✅ Промокод активирован" - - async def _user_has_paid_purchase(self, db: AsyncSession, user_id: int) -> bool: - """Проверяет была ли у пользователя хотя бы одна успешная платная покупка.""" - from sqlalchemy import select, func - from app.database.models import Transaction - - result = await db.execute( - select(func.count(Transaction.id)) - .where( - Transaction.user_id == user_id, - Transaction.status == "success", - Transaction.amount_kopeks > 0, # Платные транзакции - Transaction.type.in_(["subscription", "balance_topup", "renewal"]) - ) - ) - count = result.scalar() - return count > 0