You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

74 lines
2.5 KiB

1 year ago
using System;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using Volo.Abp.BackgroundWorkers;
using Volo.Abp.Threading;
using Volo.Abp.Uow;
10 months ago
using Win_in.Sfs.Wms.DataExchange.Domain;
using Win_in.Sfs.Wms.DataExchange.Fawtyg.InjectionMoldingTaskAgent.Incoming;
1 year ago
using Win_in.Sfs.Wms.Store.Application.Contracts;
namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.InjectionMoldingTaskAgent;
1 year ago
public class InjectionMoldingTaskIncomingBackgroundWorker : AsyncPeriodicBackgroundWorkerBase
{
10 months ago
private readonly string Incoming = "视觉接收";
1 year ago
private readonly IOptions<InjectionMoldingTaskOptions> _options;
public InjectionMoldingTaskIncomingBackgroundWorker(
AbpAsyncTimer timer,
IOptions<InjectionMoldingTaskOptions> options,
IServiceScopeFactory serviceScopeFactory
) : base(timer, serviceScopeFactory)
{
12 months ago
1 year ago
_options = options;
12 months ago
#if DEBUG
_options.Value.AutoRemote.TimeCycle = 1;
_options.Value.AutoRemote.Interval = 2;
#endif
12 months ago
Timer.Period = options.Value.AutoRemote.TimeCycle * 60 * 1000; //default 10 minutes
1 year ago
}
[UnitOfWork]
protected override async Task DoWorkAsync(PeriodicBackgroundWorkerContext workerContext)
{
10 months ago
Logger.LogInformation($"开始: 执行 {Incoming}");
var configManager = workerContext.ServiceProvider.GetRequiredService<IInterfaceConfigManager>();
var confitem = await configManager.GetInterfaceConfig("SJ-IN").ConfigureAwait(false);
if (confitem == null)
1 year ago
{
10 months ago
if (!_options.Value.IncomingOptions.Active)
{
Logger.LogInformation($"{Incoming} 已关闭没有执行!");
return;
}
1 year ago
}
10 months ago
else
1 year ago
{
10 months ago
if (!confitem.Active)
{
Logger.LogInformation($"{Incoming} 已关闭没有执行!");
10 months ago
if (confitem.Status == 0)
{
await configManager.UpsertStatusAsync("SJ-IN").ConfigureAwait(false);
Logger.LogInformation($"{Incoming} 运行已结束,更新接口运行状态!");
}
10 months ago
return;
}
1 year ago
}
10 months ago
1 year ago
Logger.LogInformation($"注塑任务");//缴库
var reader = workerContext.ServiceProvider.GetService<InjectionMoldingRequestReader>();
await reader.ReadAsync().ConfigureAwait(false);
10 months ago
Logger.LogInformation($"提交: 执行 {Incoming}");
1 year ago
}
}