using AsbCloudApp.Data; using AsbCloudApp.Services; using AsbCloudDb.Model; using Mapster; using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace AsbCloudInfrastructure.Repository { public class ProcessMapRepository : CrudWellRelatedServiceBase, 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 = default) { var timezone = wellService.GetTimezone(idWell); var updateFromUtc = updateFrom?.ToUtcDateTimeOffset(timezone.Hours); var entities = await GetQuery() .Where(e => e.IdWell == idWell) .Where(e => e.LastUpdate >= updateFromUtc) .OrderBy(e => e.DepthStart) .ThenBy(e => e.Id) .ToListAsync(token) .ConfigureAwait(false); var dtos = entities.Select(entity => { var dto = entity.Adapt(); dto.LastUpdate = entity.LastUpdate.ToRemoteDateTime(timezone.Hours); return dto; }); return dtos; } public override async Task InsertAsync(ProcessMapDto dto, CancellationToken token = default) { dto.LastUpdate = DateTime.UtcNow; var result = await base.InsertAsync(dto, token); return result; } public override async Task UpdateAsync(ProcessMapDto dto, CancellationToken token = default) { dto.LastUpdate = DateTime.UtcNow; var result = await base.UpdateAsync(dto, token); return result; } 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.FlowFact, Plan = entity.FlowPlan }; dto.TopDriveSpeed = new PlanFactDto { Fact = entity.TopDriveSpeedFact, Plan = entity.TopDriveSpeedPlan }; dto.TopDriveTorque = new PlanFactDto { Fact = entity.TopDriveTorqueFact, Plan = entity.TopDriveTorquePlan }; return dto; } } }