3 Commits

3 changed files with 28 additions and 10 deletions

View File

@@ -164,10 +164,25 @@ async def get_server_info():
"""Получение подробной информации о сервере""" """Получение подробной информации о сервере"""
import platform import platform
import sys import sys
import os
import psutil
# Получаем информацию о процессе
process = psutil.Process()
parent_process = process.parent()
# Получаем информацию о системе
cpu_cores = psutil.cpu_count()
memory_info = psutil.virtual_memory()
memory_mb = memory_info.total / (1024 * 1024) # Конвертируем в MB
return { return {
"message": "Svodka Parser API", "message": "Svodka Parser API",
"version": "1.0.0", "version": "1.0.0",
"process_id": process.pid,
"parent_id": parent_process.pid if parent_process else None,
"cpu_cores": cpu_cores,
"memory_mb": memory_mb,
"python_version": sys.version, "python_version": sys.version,
"platform": platform.platform(), "platform": platform.platform(),
"available_parsers": list(PARSERS.keys()) "available_parsers": list(PARSERS.keys())

View File

@@ -41,20 +41,20 @@ def get_async_report_service() -> AsyncReportService:
500: {"model": UploadErrorResponse, "description": "Внутренняя ошибка сервера"} 500: {"model": UploadErrorResponse, "description": "Внутренняя ошибка сервера"}
},) },)
async def upload_oper_spravka_tech_pos( async def upload_oper_spravka_tech_pos(
file: UploadFile = File(..., description="Excel файл оперативной справки техпос (.xlsx, .xlsm, .xls)") file: UploadFile = File(..., description="ZIP архив с файлами оперативной справки техпос (.zip)")
): ):
"""Загрузка и обработка отчета оперативной справки техпос""" """Загрузка и обработка отчета оперативной справки техпос"""
report_service = get_report_service() report_service = get_report_service()
try: try:
if not file.filename.endswith(('.xlsx', '.xlsm', '.xls')): if not file.filename.endswith('.zip'):
return JSONResponse( return JSONResponse(
status_code=status.HTTP_400_BAD_REQUEST, status_code=status.HTTP_400_BAD_REQUEST,
content=UploadErrorResponse( content=UploadErrorResponse(
message="Поддерживаются только Excel файлы (.xlsx, .xlsm, .xls)", message="Поддерживаются только ZIP архивы (.zip)",
error_code="INVALID_FILE_TYPE", error_code="INVALID_FILE_TYPE",
details={ details={
"expected_formats": [".xlsx", ".xlsm", ".xls"], "expected_formats": [".zip"],
"received_format": file.filename.split('.')[-1] if '.' in file.filename else "unknown" "received_format": file.filename.split('.')[-1] if '.' in file.filename else "unknown"
} }
).model_dump() ).model_dump()
@@ -115,9 +115,11 @@ async def get_oper_spravka_tech_pos_data(
result = report_service.get_data(request) result = report_service.get_data(request)
if result.success: if result.success:
# Извлекаем данные из result.data["value"]
data = result.data.get("value", []) if isinstance(result.data, dict) else result.data
return OperSpravkaTechPosResponse( return OperSpravkaTechPosResponse(
success=True, success=True,
data=result.data data=data
) )
else: else:
raise HTTPException(status_code=404, detail=result.message) raise HTTPException(status_code=404, detail=result.message)
@@ -136,20 +138,20 @@ async def get_oper_spravka_tech_pos_data(
500: {"model": UploadErrorResponse, "description": "Внутренняя ошибка сервера"} 500: {"model": UploadErrorResponse, "description": "Внутренняя ошибка сервера"}
},) },)
async def async_upload_oper_spravka_tech_pos( async def async_upload_oper_spravka_tech_pos(
file: UploadFile = File(..., description="Excel файл оперативной справки техпос (.xlsx, .xlsm, .xls)") file: UploadFile = File(..., description="ZIP архив с файлами оперативной справки техпос (.zip)")
): ):
"""Асинхронная загрузка и обработка отчета оперативной справки техпос""" """Асинхронная загрузка и обработка отчета оперативной справки техпос"""
async_service = get_async_report_service() async_service = get_async_report_service()
try: try:
if not file.filename.endswith(('.xlsx', '.xlsm', '.xls')): if not file.filename.endswith('.zip'):
return JSONResponse( return JSONResponse(
status_code=status.HTTP_400_BAD_REQUEST, status_code=status.HTTP_400_BAD_REQUEST,
content=UploadErrorResponse( content=UploadErrorResponse(
message="Поддерживаются только Excel файлы (.xlsx, .xlsm, .xls)", message="Поддерживаются только ZIP архивы (.zip)",
error_code="INVALID_FILE_TYPE", error_code="INVALID_FILE_TYPE",
details={ details={
"expected_formats": [".xlsx", ".xlsm", ".xls"], "expected_formats": [".zip"],
"received_format": file.filename.split('.')[-1] if '.' in file.filename else "unknown" "received_format": file.filename.split('.')[-1] if '.' in file.filename else "unknown"
} }
).model_dump() ).model_dump()

View File

@@ -12,3 +12,4 @@ requests>=2.31.0
# pytest-mock>=3.10.0 # pytest-mock>=3.10.0
httpx>=0.24.0 httpx>=0.24.0
numpy numpy
psutil>=5.9.0