d_sms_service/APT.BaseData.Services/Services/FM/FMSyncLogService.cs
2024-10-28 13:45:58 +08:00

222 lines
7.7 KiB
C#

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)
{
}
/// <summary>
/// 获取日志单
/// </summary>
/// <returns></returns>
public T_FM_SYNC_LOG GetSyncLog(IDictionary<object, object?> 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;
}
/// <summary>
/// 获取日志明细
/// </summary>
/// <returns></returns>
public T_FM_SYNC_LOG_DETAIL GetSyncLogDetail(IDictionary<object, object?> 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;
}
/// <summary>
/// 插入跑批日志
/// </summary>
/// <param name="ORG_ID"></param>
/// <param name="API_NAME"></param>
/// <param name="SYNC_PARAM"></param>
/// <param name="DATA_COUNT"></param>
/// <returns></returns>
public bool InsertSyncLog(IDictionary<object, object?> 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;
}
/// <summary>
/// 插入信息
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public bool InsertSyncLog(T_FM_SYNC_LOG model)
{
model.END_TIME = DateTime.Now;
this.UnifiedCommit(() =>
{
UpdateEntityNoCommit(model);
});
return true;
}
/// <summary>
/// 插入跑批日志明细
/// </summary>
/// <param name="SNC_LOG_ID"></param>
/// <param name="ORG_ID"></param>
/// <param name="Count"></param>
/// <param name="REMARK"></param>
/// <returns></returns>
public bool InsertSyncLogDetail(IDictionary<object, object?> 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;
}
/// <summary>
/// 插入跑批日志信息
/// </summary>
/// <param name="API_NAME"></param>
/// <param name="TRACEIDENTIFIER"></param>
/// <param name="LogID"></param>
/// <param name="ORG_ID"></param>
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;
}
/// <summary>
/// 插入 API 耗时
/// </summary>
/// <param name="API_NAME"></param>
/// <param name="TRACEIDENTIFIER"></param>
/// <param name="TRACEIDENTIFIERED"></param>
/// <param name="ORG_ID"></param>
/// <param name="START_TIME"></param>
/// <param name="END_TIME"></param>
/// <returns></returns>
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;
}
}
}