99 lines
2.6 KiB
Python
99 lines
2.6 KiB
Python
"""OTA API 路由,处理 ESP32/8266 设备的在线升级请求。"""
|
|
|
|
from fastapi import APIRouter, Query, status
|
|
from starlette.status import HTTP_204_NO_CONTENT
|
|
|
|
from middleware.dependencies import SessionDep, DeviceDep
|
|
from model import DefaultResponse
|
|
from model.firmware import FirmwareCheckUpdateRequest, FirmwareCheckUpdateResponse
|
|
from services import ota as ota_service
|
|
|
|
Router = APIRouter(prefix='/api/ota', tags=['OTA升级'])
|
|
|
|
|
|
@Router.post(
|
|
path='/check-update',
|
|
summary='检查固件更新',
|
|
description='设备通过 mTLS 认证后查询是否有新版本固件',
|
|
response_model=DefaultResponse,
|
|
response_description='更新检查结果'
|
|
)
|
|
async def check_update(
|
|
session: SessionDep,
|
|
device: DeviceDep,
|
|
request_data: FirmwareCheckUpdateRequest,
|
|
) -> DefaultResponse:
|
|
"""
|
|
检查固件更新。
|
|
|
|
设备需要提供有效的 mTLS 客户端证书,证书 CN 字段为设备序列号。
|
|
"""
|
|
result = await ota_service.check_firmware_update(
|
|
session=session,
|
|
device=device,
|
|
chip_type=request_data.chip_type,
|
|
current_version=request_data.current_version,
|
|
)
|
|
return DefaultResponse(data=result)
|
|
|
|
|
|
@Router.get(
|
|
path='/download/{firmware_id}',
|
|
summary='下载固件包',
|
|
description='下载指定的固件更新包',
|
|
)
|
|
async def download_firmware(
|
|
session: SessionDep,
|
|
device: DeviceDep,
|
|
firmware_id: str,
|
|
):
|
|
"""
|
|
下载固件包。
|
|
|
|
需要有效的设备证书,且下载会记录统计信息。
|
|
"""
|
|
return await ota_service.get_firmware_file(
|
|
session=session,
|
|
firmware_id=firmware_id,
|
|
device=device,
|
|
)
|
|
|
|
|
|
@Router.post(
|
|
path='/report-version',
|
|
summary='上报设备版本',
|
|
description='设备上报当前运行的固件版本',
|
|
status_code=HTTP_204_NO_CONTENT,
|
|
response_description='上报成功'
|
|
)
|
|
async def report_version(
|
|
session: SessionDep,
|
|
device: DeviceDep,
|
|
version: str = Query(..., description='当前版本号'),
|
|
):
|
|
"""
|
|
上报设备当前运行的固件版本。
|
|
"""
|
|
await ota_service.update_device_version(
|
|
session=session,
|
|
device=device,
|
|
version=version,
|
|
)
|
|
|
|
|
|
@Router.post(
|
|
path='/report-lost',
|
|
summary='上报设备丢失',
|
|
description='设备上报丢失状态',
|
|
status_code=HTTP_204_NO_CONTENT,
|
|
response_description='上报成功'
|
|
)
|
|
async def report_lost(
|
|
session: SessionDep,
|
|
device: DeviceDep,
|
|
):
|
|
"""
|
|
设备上报丢失状态(复用现有丢失处理逻辑)。
|
|
"""
|
|
await ota_service.report_device_lost(session=session, device=device)
|