79 lines
3.5 KiB
C#
79 lines
3.5 KiB
C#
// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
|
||
//
|
||
// 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
|
||
//
|
||
// 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
|
||
|
||
using Admin.NET.Core;
|
||
using Admin.NET.Core.Service;
|
||
using Furion.Schedule;
|
||
using Microsoft.Extensions.DependencyInjection;
|
||
using Newtonsoft.Json;
|
||
using SqlSugar;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Linq;
|
||
using System.Text;
|
||
using System.Threading.Tasks;
|
||
using Vistar.Application.Entity;
|
||
using Vistar.Application.Service.ProjectManagement;
|
||
|
||
namespace Vistar.Application.Job.ProjectManagement;
|
||
|
||
[JobDetail("job_SyncProjectManagementProcessRouteToSap", Description = "项目管理同步工艺路线到SAP", GroupName = "default", Concurrent = false)]
|
||
[PeriodMinutes(5, TriggerId = "trigger_SyncProjectManagementProcessRouteToSap", Description = "项目管理同步工艺路线到SAP", RunOnStart = false)]
|
||
public class SyncProjectManagementProcessRouteToSap : IJob
|
||
{
|
||
private readonly IServiceScopeFactory _scopeFactory;
|
||
public ProjectManagementService _projectManagement;
|
||
public SyncProjectManagementProcessRouteToSap(IServiceScopeFactory scopeFactory, ProjectManagementService projectManagement)
|
||
{
|
||
_scopeFactory = scopeFactory;
|
||
_projectManagement = projectManagement;
|
||
}
|
||
|
||
public async Task ExecuteAsync(JobExecutingContext context, CancellationToken stoppingToken)
|
||
{
|
||
|
||
DateTime startTime = DateTime.Now;
|
||
using var serviceScope = _scopeFactory.CreateScope();
|
||
var dbMain = serviceScope.ServiceProvider.GetRequiredService<ISqlSugarClient>().AsTenant().GetConnectionScope("1300000000001").CopyNew();
|
||
|
||
|
||
var sapOutputs = await _projectManagement.TimingSyncToSAPProcessRoute();
|
||
var json = JsonConvert.SerializeObject(sapOutputs);
|
||
|
||
string output = json;
|
||
if (sapOutputs.Count == 0 || sapOutputs == null)
|
||
{
|
||
output = "未查询到符合条件的记录";
|
||
}
|
||
|
||
var elapsedMilliseconds = (DateTime.Now - startTime).TotalMilliseconds;
|
||
|
||
dbMain.CopyNew().Insertable<ScheduledTaskLog>(new
|
||
{
|
||
TaskName = "项目管理同步工艺路线到SAP",
|
||
LogDateTime = DateTime.Now,
|
||
ReturnResult = output,
|
||
Elapsed = elapsedMilliseconds.ToLong()
|
||
}).ExecuteCommand();
|
||
|
||
string FailureMessage = "<p>以下编码在" + DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss") + "同步失败,请到Manage系统中,查看详细信息。</p>";
|
||
|
||
var sapOutputsFailur = sapOutputs.Where(x => x.code != "成功").ToList();
|
||
|
||
for (int i = 0; i < sapOutputsFailur.Count; i++)
|
||
{
|
||
if (sapOutputsFailur[i].code != "成功")
|
||
{
|
||
FailureMessage = FailureMessage + sapOutputsFailur[i].materialCode + " ";
|
||
}
|
||
}
|
||
if (sapOutputsFailur.Count > 0)
|
||
{
|
||
await _scopeFactory.CreateScope().ServiceProvider.GetRequiredService<SysEmailService>().SapSyncFailureSendEmail(FailureMessage, "启威星PLM平台-项目管理同步工艺路线到SAP");
|
||
}
|
||
}
|
||
}
|