119 lines
5.3 KiB
C#
119 lines
5.3 KiB
C#
using APT.BaseData.Domain.Entities.FM;
|
|
using APT.BaseData.Domain.Entities;
|
|
using APT.Infrastructure.Core;
|
|
using APT.Utility;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using System;
|
|
using System.Linq;
|
|
using APT.BaseData.Domain.IServices.FM;
|
|
using APT.MS.Domain.Enums;
|
|
using System.Collections.Generic;
|
|
using APT.BaseData.Domain.Enums.PF;
|
|
using APT.MS.Domain.Entities.OG;
|
|
using InfluxData.Net.InfluxDb.Models.Responses;
|
|
using Newtonsoft.Json.Schema;
|
|
using APT.MS.Domain.Entities.SC.SC;
|
|
using APT.MS.Domain.Entities.SC.PT;
|
|
using APT.BaseData.Domain.Enums;
|
|
using APT.BaseData.Services.Services.FM;
|
|
using APT.MS.Domain.Entities.SC;
|
|
using ICSharpCode.SharpZipLib.Core;
|
|
using APT.MS.Domain.Entities.SE;
|
|
using Google.Protobuf.WellKnownTypes;
|
|
using APT.WebApi.Models;
|
|
|
|
namespace APT.PP.WebApi.Controllers.Api.PP
|
|
{
|
|
/// <summary>
|
|
/// 组织保障后台任务
|
|
/// </summary>
|
|
[Route("api/PP/OGController")]
|
|
[TypeFilter(typeof(CustomActionFilterAttribute))]
|
|
public class OGController : AuthorizeApiController<T_FM_BASE_CONFIG>
|
|
{
|
|
IFMNotificationTaskService NotificationTaskService { get; set; }
|
|
|
|
public OGController(IFMNotificationTaskService notificationTaskService)
|
|
{
|
|
NotificationTaskService = notificationTaskService;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 安全教育模块所有跑批
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost, Route("OGTask")]
|
|
public JsonActionResult<bool> OGTask([FromBody] KeywordFilter filter)
|
|
{
|
|
return SafeExecute<bool>(() =>
|
|
{
|
|
//创建相关方提醒
|
|
CreateReleatedAlert(filter);
|
|
return true;
|
|
});
|
|
}
|
|
private void CreateReleatedAlert(KeywordFilter filter)
|
|
{
|
|
var baseFilter1 = new BaseFilter(filter.GetOrgId());
|
|
var baseFilter2 = new BaseFilter(filter.GetOrgId());
|
|
var baseFilter3 = new BaseFilter(filter.GetOrgId());
|
|
|
|
baseFilter1.Include = new string[] { "Nav_Related.Nav_User" };
|
|
baseFilter2.Include = new string[] { "Nav_Qualification.Nav_Related.Nav_User", "Nav_Item" };
|
|
baseFilter3.Include = new string[] { "Nav_Related.Nav_User" };
|
|
|
|
var compareDay = DateTime.Now.AddMonths(3);
|
|
var releated1 = GetEntities<T_OG_RELATED_AGREEMENT>(t => t.END_TIME.Value.Year == compareDay.Year && t.END_TIME.Value.Month == compareDay.Month && t.END_TIME.Value.Day == compareDay.Day, baseFilter1);
|
|
var releated2 = GetEntities<T_OG_RELATED_QUALIFICATION_DETAIL>(t => t.VALID_PERIOD.Value.Year == compareDay.Year && t.VALID_PERIOD.Value.Month == compareDay.Month && t.VALID_PERIOD.Value.Day == compareDay.Day, baseFilter2);
|
|
var releated3 = GetEntities<T_OG_RELATED_USER>(t => t.VALIDITY_TIME.Value.Year == compareDay.Year && t.VALIDITY_TIME.Value.Month == compareDay.Month && t.VALIDITY_TIME.Value.Day == compareDay.Day, baseFilter3);
|
|
|
|
|
|
|
|
var allSendUserTitles = new List<string>();
|
|
var allSendDataIds = new List<Guid>();
|
|
var allSendUserIds = new List<Guid>();
|
|
var allSendUserNames = new List<string>();
|
|
if (releated1.Any())
|
|
{
|
|
foreach (var item in releated1)
|
|
{
|
|
allSendUserTitles.Add("相关方《"+item.Nav_Related.NAME + "》合同/协议表中的" +item.NAME+"将于"+item.END_TIME.Value.ToShortDateString()+ "到期,请及时处理!");
|
|
allSendDataIds.Add(item.ID);
|
|
allSendUserIds.Add((Guid)item.Nav_Related.USER_ID);
|
|
allSendUserNames.Add(item.Nav_Related.Nav_User.NAME);
|
|
|
|
}
|
|
}
|
|
if (releated2.Any())
|
|
{
|
|
foreach (var item in releated2)
|
|
{
|
|
allSendUserTitles.Add("相关方《" + item.Nav_Qualification.Nav_Related.NAME+"》资质情况表中的" + item.Nav_Item.NAME+ "将于" + item.VALID_PERIOD.Value.ToShortDateString() + "到期,请及时处理!");
|
|
allSendDataIds.Add(item.ID);
|
|
allSendUserIds.Add((Guid)item.Nav_Qualification.Nav_Related.USER_ID);
|
|
allSendUserNames.Add(item.Nav_Qualification.Nav_Related.Nav_User.NAME);
|
|
}
|
|
}
|
|
if (releated3.Any())
|
|
{
|
|
foreach (var item in releated3)
|
|
{
|
|
allSendUserTitles.Add("相关方《" + item.Nav_Related.NAME + "》人员信息表中" + item.NAME+"的" + item.CERTIFICATE_NAME +"证书将于"+ item.VALIDITY_TIME.Value.ToShortDateString() + "到期,请及时处理!");
|
|
allSendDataIds.Add(item.ID);
|
|
allSendUserIds.Add((Guid)item.Nav_Related.USER_ID);
|
|
allSendUserNames.Add(item.Nav_Related.Nav_User.NAME);
|
|
}
|
|
}
|
|
if (allSendDataIds.Any())
|
|
{
|
|
var sendNotices = NotificationTaskService.InsertUserNoticeTaskModels(allSendUserTitles, allSendDataIds, filter.GetOrgId(), allSendUserIds, allSendUserNames, DateTime.Now, DateTime.Now.AddDays(1).Date, (int)FMNoticeTypeEnum.今日提醒, "PF135");
|
|
UnifiedCommit(() =>
|
|
{
|
|
if (sendNotices.Any())
|
|
BantchAddEntityNoCommit(sendNotices);
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|