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.
53 lines
2.0 KiB
53 lines
2.0 KiB
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
|
|
{
|
|
private readonly string Outgoing = "EOS Outgoing";
|
|
|
|
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)
|
|
{
|
|
Logger.LogInformation($"Starting: Handling {Outgoing}");
|
|
if (!_options.Value.IncomingOptions.Active)
|
|
{
|
|
Logger.LogInformation($"{Outgoing} is not active!");
|
|
return;
|
|
}
|
|
|
|
Logger.LogInformation($"Write Arrive");
|
|
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($"Write Return");
|
|
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($"Completed: Handling {Outgoing}");
|
|
}
|
|
|
|
}
|
|
|