Интеграция биллинг при покупке подписки
This commit is contained in:
@@ -43,7 +43,7 @@ async def buy_subscription(
|
||||
|
||||
logger.info(f"Результат buy_sub: {result}")
|
||||
|
||||
if result == "ERROR" or result is None:
|
||||
if result == "ERROR":
|
||||
raise HTTPException(status_code=500, detail="Internal server error")
|
||||
elif result == "INSUFFICIENT_FUNDS":
|
||||
raise HTTPException(status_code=400, detail="INSUFFICIENT_FUNDS")
|
||||
@@ -51,12 +51,24 @@ async def buy_subscription(
|
||||
raise HTTPException(status_code=400, detail="TARIFF_NOT_FOUND")
|
||||
elif result == "ACTIVE_SUBSCRIPTION_EXISTS":
|
||||
raise HTTPException(status_code=400, detail="ACTIVE_SUBSCRIPTION_EXISTS")
|
||||
elif result == "USER_NOT_FOUND":
|
||||
raise HTTPException(status_code=404, detail="USER_NOT_FOUND")
|
||||
elif result == "SUBSCRIPTION_CREATION_FAILED":
|
||||
raise HTTPException(status_code=500, detail="Failed to create subscription")
|
||||
elif result == "PAYMENT_FAILED_AFTER_SUBSCRIPTION":
|
||||
raise HTTPException(status_code=402, detail="SUBSCRIPTION_CREATED_BUT_PAYMENT_FAILED")
|
||||
elif result == "SUBSCRIPTION_CREATED_BUT_PAYMENT_FAILED":
|
||||
raise HTTPException(status_code=402, detail="SUBSCRIPTION_CREATED_BUT_PAYMENT_FAILED")
|
||||
|
||||
# Если успешно, генерируем URI
|
||||
if isinstance(result, dict) and result.get('status') == 'OK':
|
||||
uri_result = await database_manager.generate_uri(request_data.telegram_id)
|
||||
logger.info(f"Результат генерации URI: {uri_result}")
|
||||
return {"status": "success", "subscription_id": result.get('subscription_id'), "uri": uri_result[0]}
|
||||
return {
|
||||
"status": "success",
|
||||
"subscription_id": result.get('subscription_id'),
|
||||
"uri": uri_result[0] if uri_result and isinstance(uri_result, list) else uri_result
|
||||
}
|
||||
else:
|
||||
return {"status": "success", "message": "Subscription created"}
|
||||
|
||||
@@ -68,6 +80,7 @@ async def buy_subscription(
|
||||
raise HTTPException(status_code=500, detail=f"Unexpected error: {str(e)}")
|
||||
|
||||
|
||||
|
||||
# Эндпоинт для получения последней подписки
|
||||
@router.get("/subscription/{telegram_id}/last", response_model=SubscriptionResponse)
|
||||
async def last_subscription(telegram_id: int, database_manager: DatabaseManager = Depends(get_database_manager)):
|
||||
|
||||
@@ -98,37 +98,6 @@ async def get_user(
|
||||
logger.exception(f"Неожиданная ошибка при получении пользователя с telegram_id {telegram_id}: {e}")
|
||||
raise HTTPException(status_code=500, detail=str(e))
|
||||
|
||||
|
||||
|
||||
@router.post("/user/{telegram_id}/balance/{amount}", summary="Обновить баланс")
|
||||
async def update_balance(
|
||||
telegram_id: int,
|
||||
amount: float,
|
||||
db_manager: DatabaseManager = Depends(get_database_manager)
|
||||
):
|
||||
"""
|
||||
Обновляет баланс пользователя.
|
||||
"""
|
||||
logger.info(f"Получен запрос на обновление баланса: telegram_id={telegram_id}, amount={amount}")
|
||||
try:
|
||||
result = await db_manager.update_balance(telegram_id, amount)
|
||||
if result == "ERROR":
|
||||
logger.error(f"Ошибка обновления баланса для пользователя {telegram_id}")
|
||||
raise HTTPException(status_code=500, detail="Failed to update balance")
|
||||
|
||||
logger.info(f"Баланс пользователя {telegram_id} успешно обновлен на {amount}")
|
||||
return {"message": "Balance updated successfully"}
|
||||
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))
|
||||
|
||||
|
||||
@router.get("/user/{telegram_id}/transactions", summary="Последние транзакции пользователя")
|
||||
async def last_transactions(
|
||||
telegram_id: int,
|
||||
@@ -139,7 +108,7 @@ async def last_transactions(
|
||||
"""
|
||||
logger.info(f"Получен запрос на транзакции для пользователя: {telegram_id}")
|
||||
try:
|
||||
logger.debug(f"Вызов метода get_transaction с user_id={telegram_id}")
|
||||
logger.info(f"Вызов метода get_transaction с user_id={telegram_id}")
|
||||
transactions = await db_manager.get_transaction(telegram_id)
|
||||
|
||||
if transactions == "ERROR":
|
||||
@@ -149,7 +118,7 @@ async def last_transactions(
|
||||
response = []
|
||||
logger.info(f"Формирование ответа для пользователя {telegram_id}: {response}")
|
||||
return response
|
||||
logger.debug(f"Транзакции для {telegram_id}: {transactions}")
|
||||
logger.info(f"Транзакции для {telegram_id}: {transactions}")
|
||||
response = [
|
||||
{
|
||||
"id": tx.id,
|
||||
|
||||
Reference in New Issue
Block a user