using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using DW5S.DTO; using DW5S.Entity; using DW5S.Repostory; using DW5S.Service; using DW5S.WebApi; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; namespace DW5S.App.Controllers { /// /// 取参考相关接口 /// public class FindRefController : BaseController { [Autowired] private readonly ILogger logger; [Autowired] private readonly UnitOfWork unitOfWork; /// /// 添加两星一地参考信号缓存 /// /// 返回请求结果 [HttpPost] public async Task AddX2D1RefCacheAsync(List dtos) { var id = dtos.First().TaskID.Value; try { var repsTask = unitOfWork.Of(); var runTask=await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running); if (runTask == null) { string msg = $"接收到两星一地无参参考信号参数,由于找不到执行中的任务忽略本次定位"; logger.LogWarning(msg); return Error(msg); } else { runTask = await repsTask.FirstOrDefaultAsync(p => p.Id == id); if (runTask == null) { string msg = $"找不到任务,ID={id}"; logger.LogWarning(msg); return Error(msg); } } TaskRefCache.Instance.AddRange(id, dtos); return Success(); } catch (Exception ex) { string msg = $"添加两星一地参考信号异常.ID={id}"; logger.LogWarning(ex, msg); return Error(msg); } } /// /// 添加两星一地目标信号缓存 /// /// 返回请求结果 [HttpPost] public async Task AddX2D1TarCacheAsync(List dtos) { var id = dtos.First().TaskID.Value; try { var repsTask = unitOfWork.Of(); var runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running); if (runTask == null) { string msg = $"接收到两星一地无参目标信号参数,由于找不到执行中的任务忽略本次定位"; logger.LogWarning(msg); return Error(msg); } else { runTask = await repsTask.FirstOrDefaultAsync(p => p.Id == id); if (runTask == null) { string msg = $"找不到任务,ID={id}"; logger.LogWarning(msg); return Error(msg); } } TaskTarCache.Instance.AddRange(id, dtos); return Success(); } catch (Exception ex) { string msg = $"添加两星一地目标信号异常.ID={id}"; logger.LogWarning(ex, msg); return Error(msg); } } } }