2021-07-21 15:29:19 +05:00
|
|
|
|
using AsbCloudApp.Data;
|
|
|
|
|
using AsbCloudApp.Services;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
using AsbCloudDb.Model;
|
2022-09-28 10:46:12 +05:00
|
|
|
|
using AsbCloudInfrastructure.Repository;
|
2021-07-21 15:29:19 +05:00
|
|
|
|
using AsbSaubReport;
|
2021-09-23 10:52:10 +05:00
|
|
|
|
using Mapster;
|
2021-07-21 15:29:19 +05:00
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using Microsoft.Extensions.Configuration;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
using System;
|
2021-05-31 12:33:17 +05:00
|
|
|
|
using System.Collections.Generic;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
using System.IO;
|
2021-07-21 15:29:19 +05:00
|
|
|
|
using System.Linq;
|
2021-08-11 16:54:42 +05:00
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Threading.Tasks;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
|
|
|
|
namespace AsbCloudInfrastructure.Services
|
|
|
|
|
{
|
|
|
|
|
public class ReportService : IReportService
|
|
|
|
|
{
|
|
|
|
|
private readonly IAsbCloudDbContext db;
|
2021-11-17 10:50:57 +05:00
|
|
|
|
private readonly string connectionString;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
private readonly ITelemetryService telemetryService;
|
2022-01-05 17:50:45 +05:00
|
|
|
|
private readonly IWellService wellService;
|
2022-02-17 15:37:27 +05:00
|
|
|
|
private readonly IBackgroundWorkerService backgroundWorkerService;
|
2022-09-28 10:46:12 +05:00
|
|
|
|
private readonly IFileRepository fileRepository;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
2021-07-28 09:47:13 +05:00
|
|
|
|
public ReportService(IAsbCloudDbContext db, IConfiguration configuration,
|
2022-09-28 10:46:12 +05:00
|
|
|
|
ITelemetryService telemetryService, IWellService wellService, IBackgroundWorkerService backgroundWorkerService, IFileRepository fileRepository)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
|
|
|
|
this.db = db;
|
2021-11-17 10:50:57 +05:00
|
|
|
|
this.connectionString = configuration.GetConnectionString("DefaultConnection");
|
2022-01-05 17:50:45 +05:00
|
|
|
|
this.wellService = wellService;
|
2022-02-17 15:37:27 +05:00
|
|
|
|
this.backgroundWorkerService = backgroundWorkerService;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
this.telemetryService = telemetryService;
|
2022-09-28 10:46:12 +05:00
|
|
|
|
this.fileRepository = fileRepository;
|
2021-08-11 10:16:01 +05:00
|
|
|
|
ReportCategoryId = db.FileCategories.AsNoTracking()
|
|
|
|
|
.FirstOrDefault(c =>
|
2021-07-27 16:55:32 +05:00
|
|
|
|
c.Name.Equals("Рапорт")).Id;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
}
|
|
|
|
|
|
2021-07-27 16:55:32 +05:00
|
|
|
|
public int ReportCategoryId { get; private set; }
|
2021-05-19 14:41:27 +05:00
|
|
|
|
|
2022-02-17 15:37:27 +05:00
|
|
|
|
public string CreateReport(int idWell, int idUser, int stepSeconds, int format, DateTime begin,
|
|
|
|
|
DateTime end, Action<object, string> progressHandler)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
2022-01-05 17:50:45 +05:00
|
|
|
|
var timezoneOffset = wellService.GetTimezone(idWell).Hours;
|
|
|
|
|
var beginUtc = begin.ToUtcDateTimeOffset(timezoneOffset);
|
|
|
|
|
var endUtc = end.ToUtcDateTimeOffset(timezoneOffset);
|
|
|
|
|
var beginRemote = begin.ToTimeZoneOffsetHours(timezoneOffset);
|
|
|
|
|
var endRemote = end.ToTimeZoneOffsetHours(timezoneOffset);
|
|
|
|
|
|
2022-02-17 15:37:27 +05:00
|
|
|
|
var newReportId = backgroundWorkerService.Enqueue(async (id, token) =>
|
2021-05-19 14:41:27 +05:00
|
|
|
|
{
|
2022-02-17 15:37:27 +05:00
|
|
|
|
var contextOptions = new DbContextOptionsBuilder<AsbCloudDbContext>()
|
|
|
|
|
.UseNpgsql(connectionString)
|
|
|
|
|
.Options;
|
|
|
|
|
using var context = new AsbCloudDbContext(contextOptions);
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
2022-02-17 15:37:27 +05:00
|
|
|
|
var tempDir = Path.Combine(Path.GetTempPath(), "report");
|
2021-09-23 10:52:10 +05:00
|
|
|
|
|
2022-01-05 17:50:45 +05:00
|
|
|
|
var generator = GetReportGenerator(idWell, beginRemote, endRemote, stepSeconds, format, context);
|
2021-09-23 10:52:10 +05:00
|
|
|
|
var reportFileName = Path.Combine(tempDir, generator.GetReportDefaultFileName());
|
|
|
|
|
var totalPages = generator.GetPagesCount();
|
|
|
|
|
|
|
|
|
|
generator.OnProgress += (s, e) =>
|
|
|
|
|
{
|
|
|
|
|
progressHandler.Invoke(e.Adapt<ReportProgressDto>(), id);
|
|
|
|
|
};
|
|
|
|
|
generator.Make(reportFileName);
|
2022-04-11 18:00:34 +05:00
|
|
|
|
|
2022-09-28 10:46:12 +05:00
|
|
|
|
var fileService = new FileService(fileRepository);
|
2022-02-17 15:37:27 +05:00
|
|
|
|
var fileInfo = await fileService.MoveAsync(idWell, idUser, ReportCategoryId, reportFileName, reportFileName, token);
|
2022-04-11 18:00:34 +05:00
|
|
|
|
|
2021-09-23 10:52:10 +05:00
|
|
|
|
progressHandler.Invoke(new
|
|
|
|
|
{
|
|
|
|
|
Operation = "done",
|
|
|
|
|
Progress = 100f,
|
|
|
|
|
TotalPages = totalPages,
|
|
|
|
|
CurrentPage = totalPages,
|
|
|
|
|
file = fileInfo,
|
|
|
|
|
}, id);
|
|
|
|
|
|
|
|
|
|
var newReportProperties = new ReportProperty
|
2021-05-19 14:41:27 +05:00
|
|
|
|
{
|
2021-09-23 10:52:10 +05:00
|
|
|
|
IdWell = idWell,
|
|
|
|
|
IdFile = fileInfo.Id,
|
2022-01-05 17:50:45 +05:00
|
|
|
|
Begin = beginUtc,
|
|
|
|
|
End = endUtc,
|
2021-09-23 10:52:10 +05:00
|
|
|
|
Step = stepSeconds,
|
|
|
|
|
Format = format
|
|
|
|
|
};
|
|
|
|
|
context.ReportProperties.Add(newReportProperties);
|
|
|
|
|
context.SaveChanges();
|
2021-05-19 14:41:27 +05:00
|
|
|
|
});
|
2021-09-23 10:52:10 +05:00
|
|
|
|
progressHandler.Invoke(new ReportProgressDto
|
|
|
|
|
{
|
|
|
|
|
Operation = "Ожидает начала в очереди.",
|
|
|
|
|
Progress = 0f,
|
|
|
|
|
}, newReportId);
|
2021-05-19 14:41:27 +05:00
|
|
|
|
return newReportId;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
}
|
|
|
|
|
|
2021-07-27 14:43:30 +05:00
|
|
|
|
public int GetReportPagesCount(int idWell, DateTime begin, DateTime end, int stepSeconds, int format)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
2022-01-05 17:50:45 +05:00
|
|
|
|
var timezoneOffset = wellService.GetTimezone(idWell).Hours;
|
|
|
|
|
var beginRemote = begin.ToTimeZoneOffsetHours(timezoneOffset);
|
|
|
|
|
var endRemote = end.ToTimeZoneOffsetHours(timezoneOffset);
|
|
|
|
|
|
|
|
|
|
var generator = GetReportGenerator(idWell, beginRemote, endRemote, stepSeconds, format, (AsbCloudDbContext)db);
|
|
|
|
|
var pagesCount = generator.GetPagesCount();
|
|
|
|
|
return pagesCount;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
}
|
|
|
|
|
|
2022-01-05 17:50:45 +05:00
|
|
|
|
public DatesRangeDto GetDatesRangeOrDefault(int idWell)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
2022-01-05 17:50:45 +05:00
|
|
|
|
var idTelemetry = telemetryService.GetIdTelemetryByIdWell(idWell);
|
2022-04-11 18:00:34 +05:00
|
|
|
|
if (idTelemetry is null)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
return null;
|
2022-01-05 17:50:45 +05:00
|
|
|
|
var range = telemetryService.GetDatesRange((int)idTelemetry);
|
|
|
|
|
return range;
|
2021-05-31 12:33:17 +05:00
|
|
|
|
}
|
|
|
|
|
|
2022-01-05 17:50:45 +05:00
|
|
|
|
public async Task<IEnumerable<ReportPropertiesDto>> GetAllReportsByWellAsync(int idWell, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var timezoneOffset = wellService.GetTimezone(idWell).Hours;
|
|
|
|
|
var propertiesQuery = db.ReportProperties.Include(r => r.File)
|
|
|
|
|
.Where(p => p.IdWell == idWell)
|
|
|
|
|
.OrderBy(o => o.File.UploadDate)
|
2021-09-23 10:52:10 +05:00
|
|
|
|
.AsNoTracking()
|
2022-01-05 17:50:45 +05:00
|
|
|
|
.Take(1024);
|
|
|
|
|
var properties = await propertiesQuery.ToListAsync(token);
|
|
|
|
|
return properties.Select(p => new ReportPropertiesDto
|
|
|
|
|
{
|
|
|
|
|
Id = p.Id,
|
|
|
|
|
Name = p.File.Name,
|
|
|
|
|
File = new FileInfoDto
|
|
|
|
|
{
|
|
|
|
|
Id = p.File.Id,
|
|
|
|
|
Author = null,
|
|
|
|
|
IdAuthor = p.File.IdAuthor ?? 0,
|
|
|
|
|
IdCategory = p.File.IdCategory,
|
|
|
|
|
IdWell = p.File.IdWell,
|
|
|
|
|
Name = p.File.Name,
|
|
|
|
|
Size = p.File.Size,
|
|
|
|
|
UploadDate = p.File.UploadDate.ToRemoteDateTime(timezoneOffset),
|
|
|
|
|
},
|
|
|
|
|
IdWell = p.IdWell,
|
|
|
|
|
Date = p.File.UploadDate.ToRemoteDateTime(timezoneOffset),
|
|
|
|
|
Begin = p.Begin.ToRemoteDateTime(timezoneOffset),
|
|
|
|
|
End = p.End.ToRemoteDateTime(timezoneOffset),
|
|
|
|
|
Step = p.Step,
|
|
|
|
|
Format = p.Format == 0 ? ".pdf" : ".las"
|
|
|
|
|
});
|
|
|
|
|
}
|
2021-09-23 10:52:10 +05:00
|
|
|
|
|
|
|
|
|
private static IReportGenerator GetReportGenerator(int idWell, DateTime begin,
|
2021-08-11 16:54:42 +05:00
|
|
|
|
DateTime end, int stepSeconds, int format, AsbCloudDbContext context)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
2021-07-27 14:43:30 +05:00
|
|
|
|
var dataSource = new ReportDataSourcePgCloud(context, idWell);
|
2021-09-23 11:56:12 +05:00
|
|
|
|
IReportGenerator generator = format switch
|
2021-05-19 15:50:09 +05:00
|
|
|
|
{
|
2021-09-23 11:56:12 +05:00
|
|
|
|
//LAS
|
|
|
|
|
1 => new AsbSaubReportLas.ReprotGeneratorLas(dataSource),
|
|
|
|
|
//PDF
|
|
|
|
|
_ => new AsbSaubReportPdf.ReprotGeneratorPdf(dataSource),
|
|
|
|
|
};
|
2021-07-23 14:55:31 +05:00
|
|
|
|
generator.Begin = begin;
|
|
|
|
|
generator.End = end;
|
|
|
|
|
generator.Step = TimeSpan.FromSeconds(stepSeconds);
|
|
|
|
|
generator.WithCharts = true;
|
|
|
|
|
generator.WithEvents = true;
|
2021-07-28 09:47:13 +05:00
|
|
|
|
|
2021-07-23 14:55:31 +05:00
|
|
|
|
return generator;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|