using APT.Infrastructure.Core;
using APT.BaseData.Domain.ApiModel;
using APT.BaseData.Domain.Entities.FM;
using APT.BaseData.Domain.IServices.FM;
using APT.Utility;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Collections.Immutable;
using APT.BaseData.Domain.Entities;
using APT.BaseData.Domain.Enums;
using APT.Infrastructure.Api;
using APT.MS.Domain.Entities.PF;
using APT.BaseData.Domain.Dtos;
using Castle.Core.Internal;
namespace APT.BaseData.Services.Services.FM
{
    public partial class FMSyncLogDetailService : CommonService, IFMSyncLogDetailService
    {
        public FMSyncLogDetailService(IRepository repository)
            : base(repository)
        {
        }
        /// 
        /// 获取日志单
        ///  
        ///  
        public T_FM_SYNC_LOG GetSyncLog(IDictionary Items, Guid? ORG_ID, string API_NAME, string SYNC_PARAM, SyncLogType? SyncLogType, int DATA_COUNT = 0)
        {
            Guid SNC_LOG_ID = (Guid)Items["syncID"];
            T_FM_SYNC_LOG model = new T_FM_SYNC_LOG();
            model.ID = SNC_LOG_ID;
            model.START_TIME = DateTime.Now;
            model.LOGTYPE = SyncLogType;
            model.API_NAME = API_NAME;
            model.DATA_COUNT = DATA_COUNT;
            model.IS_DELETED = false;
            model.ORG_ID = ORG_ID;
            model.SYNC_PARAM = SYNC_PARAM;
            model.CREATE_TIME = DateTime.Now;
            model.MODIFY_TIME = DateTime.Now;
            return model;
        }
        /// 
        /// 获取日志明细
        ///  
        ///  
        public T_FM_SYNC_LOG_DETAIL GetSyncLogDetail(IDictionary Items, string TRACEIDENTIFIER, Guid? ORG_ID, int Count, string REMARK, SyncLogType? SyncLogType = null, Guid? SNC_LOG_ID = null)
        {
            if (SNC_LOG_ID == null && Items != null && Items.ContainsKey("syncID"))
            {
                try
                {
                    SNC_LOG_ID = (Guid)Items["syncID"];
                }
                catch { }
            }
            if (SNC_LOG_ID == null)
            {
                SNC_LOG_ID = Guid.Empty;
            }
            T_FM_SYNC_LOG_DETAIL model = new T_FM_SYNC_LOG_DETAIL();
            model.ID = Guid.NewGuid();
            model.SNC_LOG_ID = SNC_LOG_ID.Value;
            model.LOGTYPE = SyncLogType;
            model.COUNT = Count;
            model.REMARK = REMARK;
            model.IS_DELETED = false;
            model.ORG_ID = ORG_ID;
            model.CREATE_TIME = DateTime.Now;
            model.MODIFY_TIME = DateTime.Now;
            model.TRACEIDENTIFIER = TRACEIDENTIFIER;
            return model;
        }
        /// 
        /// 插入跑批日志
        ///  
        ///  
        ///  
        ///  
        ///  
        ///  
        public bool InsertSyncLog(IDictionary Items, Guid? ORG_ID, string API_NAME, string SYNC_PARAM, SyncLogType? SyncLogType, int DATA_COUNT = 0)
        {
            T_FM_SYNC_LOG model = GetSyncLog(Items, ORG_ID, API_NAME, SYNC_PARAM, SyncLogType, DATA_COUNT);
            this.UnifiedCommit(() =>
            {
                UpdateEntityNoCommit(model);
            });
            return true;
        }
        /// 
        /// 插入信息
        ///  
        ///  
        ///  
        public bool InsertSyncLog(T_FM_SYNC_LOG model)
        {
            model.END_TIME = DateTime.Now;
            this.UnifiedCommit(() =>
            {
                UpdateEntityNoCommit(model);
            });
            return true;
        }
        /// 
        /// 插入跑批日志明细
        ///  
        ///  
        ///  
        ///  
        ///  
        ///  
        public bool InsertSyncLogDetail(IDictionary Items, string TRACEIDENTIFIER, Guid? ORG_ID, int Count, string REMARK, SyncLogType? SyncLogType = null, Guid? SNC_LOG_ID = null)
        {
            T_FM_SYNC_LOG_DETAIL model = GetSyncLogDetail(Items, TRACEIDENTIFIER, ORG_ID, Count, REMARK, SyncLogType, SNC_LOG_ID);
            this.UnifiedCommit(() =>
            {
                UpdateEntityNoCommit(model);
            });
            return true;
        }
        /// 
        /// 插入跑批日志信息
        ///  
        ///  
        ///  
        ///  
        ///  
        public T_FM_SYNC_LOG InsertSyncLog(string API_NAME, string TRACEIDENTIFIER, Guid LogID, Guid? ORG_ID, string SYNC_PARAM)
        {
            T_FM_SYNC_LOG log = new T_FM_SYNC_LOG()
            {
                ID = LogID,
                START_TIME = DateTime.Now,
                END_TIME = DateTime.Now,
                API_NAME = API_NAME,
                DATA_COUNT = 0,
                IS_SUCCESS = true,
                IS_DELETED = false,
                ORG_ID = ORG_ID,
                ENTITY_ORG_TPYE = 0,
                FLOW_STATUS = 0,
                FLOW_SEND_STATUS = 0,
                CREATE_TIME = DateTime.Now,
                MODIFY_TIME = DateTime.Now,
                TRACEIDENTIFIER = TRACEIDENTIFIER,
                ISINSERT = false,
                //FLOW_ID = ID,
                //FORM_ID = ID,
                //CREATER_ID = ID,
                //MODIFIER_ID = ID,
                SYNC_PARAM = SYNC_PARAM,
                //LOGTYPE = ID,
            };
            this.UnifiedCommit(() =>
            {
                UpdateEntityNoCommit(log);
            });
            return log;
        }
        /// 
        /// 插入 API 耗时
        ///  
        ///  
        ///  
        ///  
        ///  
        ///  
        ///  
        ///  
        public T_FM_SYNC_LOG InsertAPISyncLog(string API_NAME, string TRACEIDENTIFIER, string TRACEIDENTIFIERED, Guid? ORG_ID, DateTime START_TIME, DateTime END_TIME)
        {
            T_FM_SYNC_LOG log = new T_FM_SYNC_LOG()
            {
                ID = Guid.NewGuid(),
                START_TIME = START_TIME,
                END_TIME = END_TIME,
                API_NAME = API_NAME,
                DATA_COUNT = 0,
                IS_SUCCESS = true,
                IS_DELETED = false,
                ORG_ID = ORG_ID,
                ENTITY_ORG_TPYE = 0,
                FLOW_STATUS = 0,
                FLOW_SEND_STATUS = 0,
                CREATE_TIME = DateTime.Now,
                //MODIFY_TIME = DateTime.Now,
                TRACEIDENTIFIER = TRACEIDENTIFIER,
                TRACEIDENTIFIERED = TRACEIDENTIFIERED,
                ISINSERT = false,
                LOGTYPE = SyncLogType.APITimeResponsen,
                //FLOW_ID = ID,
                //FORM_ID = ID,
                CREATER_ID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID,
                //MODIFIER_ID = ID,
                //SYNC_PARAM = SYNC_PARAM,
                //LOGTYPE = ID,
                SYNC_PARAM = (END_TIME - START_TIME).TotalSeconds.ToString()
            };
            this.UnifiedCommit(() =>
            {
                UpdateEntityNoCommit(log);
            });
            return log;
        }
    }
}