Переделал модель БД под новую, переделал Репозиторий, переделал сервисы, убрал монгодб, изменил необходимые пакеты, марзбан я добавил, но не настроил. Весь старый бот вроде работает(только в рефералке не уверен)
This commit is contained in:
@@ -1,11 +1,12 @@
|
||||
from datetime import datetime
|
||||
from typing import Optional
|
||||
from uuid import UUID
|
||||
from sqlalchemy.future import select
|
||||
from sqlalchemy.exc import SQLAlchemyError
|
||||
from decimal import Decimal
|
||||
from sqlalchemy import asc, desc, update
|
||||
from sqlalchemy.orm import joinedload
|
||||
from instance.model import TicketMessage, User, Subscription, Transaction,SupportTicket
|
||||
from instance.model import Referral, User, Subscription, Transaction
|
||||
|
||||
|
||||
class PostgresRepository:
|
||||
@@ -13,13 +14,13 @@ class PostgresRepository:
|
||||
self.session_generator = session_generator
|
||||
self.logger = logger
|
||||
|
||||
async def create_user(self, telegram_id: str, username: str, referrer_id: str):
|
||||
async def create_user(self, telegram_id: int, username: str, invited_by: Optional[int]= None):
|
||||
"""
|
||||
Создаёт нового пользователя в PostgreSQL.
|
||||
"""
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
new_user = User(telegram_id=telegram_id, username=username, referrer_id=referrer_id)
|
||||
new_user = User(telegram_id=telegram_id, username=username, invited_by=invited_by)
|
||||
session.add(new_user)
|
||||
await session.commit()
|
||||
return new_user
|
||||
@@ -28,7 +29,7 @@ class PostgresRepository:
|
||||
await session.rollback()
|
||||
return None
|
||||
|
||||
async def get_active_subscription(self, telegram_id: str):
|
||||
async def get_active_subscription(self, telegram_id: int):
|
||||
"""
|
||||
Проверяет наличие активной подписки у пользователя.
|
||||
"""
|
||||
@@ -46,7 +47,7 @@ class PostgresRepository:
|
||||
self.logger.error(f"Ошибка проверки активной подписки для пользователя {telegram_id}: {e}")
|
||||
return None
|
||||
|
||||
async def get_user_by_telegram_id(self, telegram_id: str):
|
||||
async def get_user_by_telegram_id(self, telegram_id: int):
|
||||
"""
|
||||
Возвращает пользователя по Telegram ID.
|
||||
"""
|
||||
@@ -69,24 +70,24 @@ class PostgresRepository:
|
||||
:param amount: Сумма для добавления/вычитания.
|
||||
:return: True, если успешно, иначе False.
|
||||
"""
|
||||
self.logger.info(f"Обновление баланса пользователя: id={user.id}, current_balance={user.balance}, amount={amount}")
|
||||
self.logger.info(f"Обновление баланса пользователя: id={user.telegram_id}, current_balance={user.balance}, amount={amount}")
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
user = await session.get(User, user.id) # Загружаем пользователя в той же сессии
|
||||
user = await session.get(User, user.telegram_id) # Загружаем пользователя в той же сессии
|
||||
if not user:
|
||||
self.logger.warning(f"Пользователь с ID {user.id} не найден.")
|
||||
self.logger.warning(f"Пользователь с ID {user.telegram_id} не найден.")
|
||||
return False
|
||||
# Приведение amount к Decimal
|
||||
user.balance += Decimal(amount)
|
||||
await session.commit()
|
||||
self.logger.info(f"Баланс пользователя id={user.id} успешно обновлен: new_balance={user.balance}")
|
||||
self.logger.info(f"Баланс пользователя id={user.telegram_id} успешно обновлен: new_balance={user.balance}")
|
||||
return True
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Ошибка при обновлении баланса пользователя id={user.id}: {e}")
|
||||
self.logger.error(f"Ошибка при обновлении баланса пользователя id={user.telegram_id}: {e}")
|
||||
await session.rollback()
|
||||
return False
|
||||
|
||||
async def get_last_transactions(self, user_id: UUID, limit: int = 10):
|
||||
async def get_last_transactions(self, user_telegram_id: int, limit: int = 10):
|
||||
"""
|
||||
Возвращает последние транзакции пользователя.
|
||||
"""
|
||||
@@ -94,16 +95,16 @@ class PostgresRepository:
|
||||
try:
|
||||
result = await session.execute(
|
||||
select(Transaction)
|
||||
.where(Transaction.user_id == user_id)
|
||||
.where(Transaction.user_id == user_telegram_id)
|
||||
.order_by(desc(Transaction.created_at))
|
||||
.limit(limit)
|
||||
)
|
||||
return result.scalars().all()
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Ошибка получения транзакций пользователя {user_id}: {e}")
|
||||
self.logger.error(f"Ошибка получения транзакций пользователя {user_telegram_id}: {e}")
|
||||
return None
|
||||
|
||||
async def get_last_subscription_by_user_id(self, user_id: UUID, limit: int = 1):
|
||||
async def get_last_subscription_by_user_id(self, user_telegram_id: int, limit: int = 1):
|
||||
"""
|
||||
Извлекает последнюю подписку пользователя на основании user_id.
|
||||
|
||||
@@ -114,15 +115,16 @@ class PostgresRepository:
|
||||
try:
|
||||
result = await session.execute(
|
||||
select(Subscription)
|
||||
.where(Subscription.user_id == user_id)
|
||||
.where(Subscription.user_id == user_telegram_id)
|
||||
.order_by(desc(Subscription.created_at))
|
||||
.limit(limit)
|
||||
)
|
||||
subscriptions = list(result.scalars())
|
||||
result.scalars()
|
||||
self.logger.info(f"Найдены такие подписки: {subscriptions}")
|
||||
return subscriptions
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Ошибка при получении подписки для пользователя {user_id}: {e}")
|
||||
self.logger.error(f"Ошибка при получении подписки для пользователя {user_telegram_id}: {e}")
|
||||
return None
|
||||
|
||||
async def add_record(self, record):
|
||||
@@ -142,117 +144,58 @@ class PostgresRepository:
|
||||
await session.rollback()
|
||||
return None
|
||||
|
||||
async def list_active_tickets(self, user_id: UUID):
|
||||
async def add_referral(self, referrer_id: int, referral_id: int):
|
||||
"""
|
||||
Добавление реферальной связи между пользователями.
|
||||
"""
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
tickets = await session.execute(
|
||||
select(SupportTicket)
|
||||
# Проверить, существует ли уже такая реферальная связь
|
||||
existing_referral = await session.execute(
|
||||
select(Referral)
|
||||
.where(
|
||||
SupportTicket.user_id == user_id,
|
||||
SupportTicket.status.in_([status.upper() for status in ["pending", "open"]])
|
||||
)
|
||||
(Referral.inviter_id == referrer_id) &
|
||||
(Referral.invited_id == referral_id)
|
||||
)
|
||||
)
|
||||
result = list(tickets.scalars().all())
|
||||
self.logger.info(f"Получены активные тикеты: {result}")
|
||||
return result
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Произошла ошибка при поиске активных тикетов: {e}")
|
||||
return None
|
||||
existing_referral = existing_referral.scalars().first()
|
||||
|
||||
if existing_referral:
|
||||
raise ValueError("Referral relationship already exists")
|
||||
|
||||
async def get_ticket(self, ticket_id):
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
ticket = await session.execute(
|
||||
select(SupportTicket)
|
||||
.where(SupportTicket.id == ticket_id)
|
||||
)
|
||||
result = ticket.scalars().first()
|
||||
self.logger.info(f"Получен тикет {ticket_id}.")
|
||||
if result:
|
||||
serialized_result = {
|
||||
"id": result.id,
|
||||
"user_id": result.user_id,
|
||||
"subject": result.subject,
|
||||
"message": result.message,
|
||||
"status": result.status,
|
||||
"created_at": result.created_at.isoformat(),
|
||||
"updated_at": result.updated_at.isoformat(),
|
||||
}
|
||||
return serialized_result
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Произошла ошибка при поиске тикета {ticket_id}.")
|
||||
return None
|
||||
|
||||
async def get_ticket_messages(self, ticket_id: int):
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
# Выполняем запрос для получения сообщений, сортированных по дате
|
||||
result = await session.execute(
|
||||
select(TicketMessage)
|
||||
.where(TicketMessage.ticket_id == ticket_id)
|
||||
.order_by(asc(TicketMessage.created_at))
|
||||
)
|
||||
messages = result.scalars().all()
|
||||
self.logger.info(f"Получены сообщения для тикета {ticket_id}, {messages}")
|
||||
self.logger.info(messages)
|
||||
return messages
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Ошибка при получении сообщений для тикета {ticket_id}: {e}")
|
||||
return []
|
||||
|
||||
async def set_new_status(self,ticket_id: int, new_status: str):
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
# Выполняем обновление тикета
|
||||
result = await session.execute(
|
||||
update(SupportTicket)
|
||||
.where(SupportTicket.id == ticket_id)
|
||||
.values(status=new_status)
|
||||
.execution_options(synchronize_session="fetch")
|
||||
)
|
||||
if result.rowcount == 0:
|
||||
raise ValueError(f"Тикет с ID {ticket_id} не найден.")
|
||||
|
||||
await session.commit()
|
||||
self.logger.info(f"Статус тикета {ticket_id} обновлён на '{new_status}'.")
|
||||
return "OK"
|
||||
except SQLAlchemyError as e:
|
||||
self.logger.error(f"Ошибка обновления статуса тикета {ticket_id}: {e}")
|
||||
await session.rollback()
|
||||
return "ERROR"
|
||||
|
||||
async def add_referal(self,referrer_id: str, referral_id:str):
|
||||
"""
|
||||
Добавление рефералу пользователей
|
||||
"""
|
||||
async for session in self.session_generator():
|
||||
try:
|
||||
# Проверить, что пользователи существуют
|
||||
referrer = await session.execute(
|
||||
select(User)
|
||||
.where(User.id == referrer_id)
|
||||
.options(joinedload(User.referrals)) # Загрузка связанных объектов
|
||||
select(User).where(User.telegram_id == referrer_id)
|
||||
)
|
||||
referrer = referrer.scalars().first()
|
||||
|
||||
if not referrer:
|
||||
raise ValueError("Referrer not found")
|
||||
|
||||
# Проверить, существует ли уже такой реферал
|
||||
existing_referrals = [ref.id for ref in referrer.referrals]
|
||||
if referrer_id in existing_referrals:
|
||||
raise ValueError("Referral already exists")
|
||||
|
||||
# Найти реферала
|
||||
referral = await session.execute(
|
||||
select(User).where(User.id == referral_id)
|
||||
referral_user = await session.execute(
|
||||
select(User).where(User.telegram_id == referral_id)
|
||||
)
|
||||
referral = referral.scalars().first()
|
||||
|
||||
if not referral:
|
||||
referral_user = referral_user.scalars().first()
|
||||
|
||||
if not referral_user:
|
||||
raise ValueError("Referral user not found")
|
||||
|
||||
# Добавить реферала в список
|
||||
referrer.referrals.append(referral)
|
||||
await session.commit()
|
||||
except Exception as e:
|
||||
self.logger(f"Ошибка при добавлении рефералу пользователей")
|
||||
# Проверить, что пользователь не приглашает сам себя
|
||||
if referrer_id == referral_id:
|
||||
raise ValueError("User cannot refer themselves")
|
||||
|
||||
# Создать новую реферальную связь
|
||||
new_referral = Referral(
|
||||
inviter_id=referrer_id,
|
||||
invited_id=referral_id
|
||||
)
|
||||
|
||||
session.add(new_referral)
|
||||
await session.commit()
|
||||
|
||||
self.logger.info(f"Реферальная связь создана: {referrer_id} -> {referral_id}")
|
||||
|
||||
except Exception as e:
|
||||
await session.rollback()
|
||||
self.logger.error(f"Ошибка при добавлении реферальной связи: {str(e)}")
|
||||
raise
|
||||
Reference in New Issue
Block a user