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.Reps();
                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.Reps();
                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);
            }
        }
    }
}