using AsbCloudApp.Data; using AsbCloudApp.Data.ProcessMap; using AsbCloudApp.Repositories; using AsbCloudApp.Requests; using AsbCloudApp.Services; using AsbCloudDb.Model; using DocumentFormat.OpenXml.Spreadsheet; using Mapster; using Microsoft.EntityFrameworkCore; using Org.BouncyCastle.Asn1.Ocsp; using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; using System.Threading; using System.Threading.Tasks; namespace AsbCloudInfrastructure.Repository { #nullable enable public class ProcessMapRepository : CrudWellRelatedRepositoryBase, IProcessMapRepository { private readonly IWellService wellService; public ProcessMapRepository(IAsbCloudDbContext context, IWellService wellService) : base(context, dbSet => dbSet.Include(x => x.Well) .Include(x => x.WellSectionType) ) { this.wellService = wellService; } public async Task> GetAllAsync(int idWell, DateTime? updateFrom, CancellationToken token) { var requests = new[] { new ProcessMapRequest { IdWell = idWell, UpdateFrom = updateFrom } }; var entities = await BuildQuery(requests) .OrderBy(e => e.DepthStart) .ThenBy(e => e.Id) .ToListAsync(token) .ConfigureAwait(false); var dtos = entities.Select(Convert); return dtos; } public async Task> GetProcessMapAsync(IEnumerable requests, CancellationToken token) { var entities = await BuildQuery(requests) .ToListAsync(token) .ConfigureAwait(false); var dtos = entities.Select(Convert).ToList(); return dtos; } public override async Task InsertAsync(ProcessMapDto dto, CancellationToken token) { dto.LastUpdate = DateTime.UtcNow; var result = await base.InsertAsync(dto, token); return result; } public override async Task UpdateAsync(ProcessMapDto dto, CancellationToken token) { dto.LastUpdate = DateTime.UtcNow; var result = await base.UpdateAsync(dto, token); return result; } private IQueryable BuildQuery(IEnumerable requests) { var query = GetQuery(); if (requests.Any()) { Expression> predicate = map => false; foreach (var request in requests) { Expression> predicate2 = map => map.IdWell == request.IdWell; if (request.IdWellSectionType is not null) predicate2 = predicate2.And(map => map.IdWellSectionType == request.IdWellSectionType); if (request.UpdateFrom is not null) { var timezone = wellService.GetTimezone(request.IdWell); var updateFromUtc = request.UpdateFrom?.ToUtcDateTimeOffset(timezone.Hours); predicate2 = predicate2.And(map => map.LastUpdate >= updateFromUtc); } predicate = predicate.Or(predicate2); } query = query.Where(predicate); } return query; } protected override ProcessMapDto Convert(ProcessMap entity) { var dto = entity.Adapt(); dto.LastUpdate = entity.LastUpdate.ToRemoteDateTime(entity.Well.Timezone.Hours); dto.AxialLoad = new PlanFactDto { Fact = entity.AxialLoadFact, Plan = entity.AxialLoadPlan }; dto.Flow = new PlanFactDto { Fact = entity.FlowFact, Plan = entity.FlowPlan }; dto.Pressure = new PlanFactDto { Fact = entity.PressureFact, Plan = entity.PressurePlan }; dto.TopDriveSpeed = new PlanFactDto { Fact = entity.TopDriveSpeedFact, Plan = entity.TopDriveSpeedPlan }; dto.TopDriveTorque = new PlanFactDto { Fact = entity.TopDriveTorqueFact, Plan = entity.TopDriveTorquePlan }; return dto; } protected override ProcessMap Convert(ProcessMapDto dto) { var entity = dto.Adapt(); entity.AxialLoadPlan = dto.AxialLoad.Plan; entity.AxialLoadFact = dto.AxialLoad.Fact; entity.FlowPlan = dto.Flow.Plan; entity.FlowFact = dto.Flow.Fact; entity.PressurePlan = dto.Pressure.Plan; entity.PressureFact = dto.Pressure.Fact; entity.TopDriveSpeedPlan = dto.TopDriveSpeed.Plan; entity.TopDriveSpeedFact = dto.TopDriveSpeed.Fact; entity.TopDriveTorquePlan = dto.TopDriveTorque.Plan; entity.TopDriveTorqueFact = dto.TopDriveTorque.Fact; return entity; } } #nullable disable }