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.

56 lines
2.2 KiB

2 years ago
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;
namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.EosAgent;
public class EosOutgoingBackgroundWorker : AsyncPeriodicBackgroundWorkerBase
{
10 months ago
private readonly string Outgoing = "EOS发送";
2 years ago
private readonly IOptions<EosOptions> _options;
public EosOutgoingBackgroundWorker(
AbpAsyncTimer timer
, IOptions<EosOptions> options
, IServiceScopeFactory serviceScopeFactory
) : base(timer, serviceScopeFactory)
{
_options = options;
Timer.Period = options.Value.OutgoingOptions.PeriodSeconds * 1000; //default 10 minutes
}
[UnitOfWork]
protected override async Task DoWorkAsync(PeriodicBackgroundWorkerContext workerContext)
{
10 months ago
Logger.LogInformation($"开始: 执行 {Outgoing}");
2 years ago
if (!_options.Value.IncomingOptions.Active)
{
Logger.LogInformation($"{Outgoing} 已关闭没有执行!");
2 years ago
return;
}
11 months ago
Logger.LogInformation($"传出 采购上架单");
2 years ago
var arriveConvert = workerContext.ServiceProvider.GetRequiredService<ArriveConverter>();
var arriveNoteList = await arriveConvert.ConvertAsync().ConfigureAwait(false);
var arriveWriter = workerContext.ServiceProvider.GetRequiredService<ArriveNoteWriter>();
await arriveWriter.WriteAsync(arriveNoteList).ConfigureAwait(false);
Logger.LogInformation($"处理采购上架单【{arriveNoteList.Count}】条数据");
2 years ago
11 months ago
Logger.LogInformation($"传出 采购退货单");
2 years ago
var returnConvert = workerContext.ServiceProvider.GetRequiredService<ReturnConverter>();
var returnNoteList = await returnConvert.ConvertAsync().ConfigureAwait(false);
var returnWriter = workerContext.ServiceProvider.GetRequiredService<ReturnNoteWriter>();
await returnWriter.WriteAsync(returnNoteList).ConfigureAwait(false);
Logger.LogInformation($"处理采购退货单【{returnNoteList.Count}】条数据");
2 years ago
10 months ago
Logger.LogInformation($"提交: 执行 {Outgoing}");
2 years ago
}
}