a-tuoheng-device/src/main/java/com/ruoyi/device/service/FlightService.java

97 lines
2.4 KiB
Java
Raw Normal View History

2026-02-25 13:06:56 +08:00
package com.ruoyi.device.service;
import com.ruoyi.device.mapper.entity.FlightEntity;
import java.util.Map;
/**
* 飞行服务接口
*
* @author ruoyi
* @date 2026-02-25
*/
public interface FlightService
{
/**
* 获取或创建当前正在进行的飞行记录
* 用于MQTT回调如果最新记录已返航则创建新记录
*
* @param deviceSn 设备SN号
* @return 飞行记录
*/
FlightEntity getOrCreateCurrentFlight(String deviceSn);
/**
* 获取或创建飞行记录通过messageID匹配
* 如果存在相同messageID的飞行记录返回该记录
* 如果不存在或messageID不同创建新记录
*
* @param deviceSn 设备SN号
* @param messageId 消息ID对应flightIdExternal
* @return 飞行记录
*/
FlightEntity getOrCreateFlightByMessageId(String deviceSn, String messageId);
/**
* 获取最新的飞行记录包括已返航的
* 用于WebSocket推送
*
* @param deviceSn 设备SN号
* @return 飞行记录
*/
FlightEntity getLatestFlight(String deviceSn);
/**
* 创建新的飞行记录
*
* @param deviceSn 设备SN号
* @return 飞行记录
*/
FlightEntity createFlight(String deviceSn);
/**
* 更新飞行ID外部ID
*
* @param flightId 飞行ID
* @param flightIdExternal 外部飞行ID
*/
void updateFlightIdExternal(Long flightId, String flightIdExternal);
/**
* 更新飞行状态
*
* @param flightId 飞行ID
* @param status 状态自检中飞行中已返航
*/
void updateFlightStatus(Long flightId, String status);
/**
* 更新返航时间
*
* @param flightId 飞行ID
*/
void updateReturnTime(Long flightId);
/**
* 获取飞行记录和日志用于WebSocket推送
*
* @param deviceSn 设备SN号
* @return 飞行记录和日志
*/
Map<String, Object> getLatestFlightWithLogs(String deviceSn);
/**
* 保存自检日志
*
* @param logEntity 自检日志实体
*/
void insertPreCheckLog(com.ruoyi.device.mapper.entity.PreCheckLogEntity logEntity);
/**
* 保存飞行日志
*
* @param logEntity 飞行日志实体
*/
void insertFlightLog(com.ruoyi.device.mapper.entity.FlightLogEntity logEntity);
}