DD.WellWorkover.Cloud/AsbCloudInfrastructure/Repository/PlannedTrajectoryRepository.cs

128 lines
4.8 KiB
C#
Raw Normal View History

using AsbCloudApp.Data;
using AsbCloudApp.Exceptions;
using AsbCloudApp.Repositories;
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 PlannedTrajectoryRepository : IPlannedTrajectoryRepository
{
private readonly IAsbCloudDbContext db;
private readonly IWellService wellService;
public PlannedTrajectoryRepository(IAsbCloudDbContext db, IWellService wellService)
{
this.db = db;
this.wellService = wellService;
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
public async Task<int> AddRangeAsync(IEnumerable<PlannedTrajectoryDto> plannedTrajectoryRows, CancellationToken token)
{
2023-01-11 14:59:54 +05:00
var idWell = plannedTrajectoryRows.First().IdWell;
2023-01-12 10:32:54 +05:00
if (!plannedTrajectoryRows.All(r => r.IdWell == idWell))
throw new ArgumentInvalidException("Все строки должны относиться к одной скважине", nameof(plannedTrajectoryRows));
2023-01-11 14:59:54 +05:00
var offsetHours = wellService.GetTimezone(idWell).Hours;
2023-01-12 12:07:31 +05:00
var entities = plannedTrajectoryRows
.Select(e =>
{
2023-01-12 12:07:31 +05:00
var entity = Convert(e, offsetHours);
entity.Id = 0;
return entity;
});
2023-01-12 12:07:31 +05:00
db.PlannedTrajectories.AddRange(entities);
return await db.SaveChangesAsync(token)
.ConfigureAwait(false);
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
public async Task<int> AddAsync(PlannedTrajectoryDto plannedTrajectoryRow, CancellationToken token)
2023-01-11 14:59:54 +05:00
{
var offsetHours = wellService.GetTimezone(plannedTrajectoryRow.IdWell).Hours;
var entity = Convert(plannedTrajectoryRow, offsetHours);
entity.Id = 0;
db.PlannedTrajectories.Add(entity);
2022-12-27 21:45:03 +05:00
return await db.SaveChangesAsync(token)
.ConfigureAwait(false);
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
2022-12-25 23:16:36 +05:00
public async Task<int> DeleteRangeAsync(IEnumerable<int> ids, CancellationToken token)
{
2023-01-11 14:59:54 +05:00
var query = db.PlannedTrajectories
2022-12-27 14:03:44 +05:00
.Where(e => ids.Contains(e.Id));
2023-01-11 14:59:54 +05:00
db.PlannedTrajectories.RemoveRange(query);
return await db.SaveChangesAsync(token)
.ConfigureAwait(false);
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
public async Task<int> DeleteByIdWellAsync(int idWell, CancellationToken token)
2022-12-27 00:02:49 +05:00
{
2023-01-11 14:59:54 +05:00
var query = db.PlannedTrajectories
2022-12-27 00:02:49 +05:00
.Where(e => e.IdWell == idWell);
2023-01-11 14:59:54 +05:00
db.PlannedTrajectories.RemoveRange(query);
return await db.SaveChangesAsync(token)
.ConfigureAwait(false);
2022-12-27 00:02:49 +05:00
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
public async Task<IEnumerable<PlannedTrajectoryDto>> GetAsync(int idWell, CancellationToken token)
{
var well = wellService.GetOrDefault(idWell);
if (well is null || well.Timezone is null)
throw new ArgumentInvalidException("idWell doesn`t exist", nameof(idWell));
var offsetHours = well.Timezone.Hours;
2023-01-11 14:59:54 +05:00
var query = db.PlannedTrajectories
2022-12-27 14:03:44 +05:00
.AsNoTracking()
.Where(x => x.IdWell == idWell);
var entities = await query
2023-01-12 12:07:31 +05:00
.OrderBy(e => e.WellboreDepth)
.ToListAsync(token);
var result = entities
2023-01-11 14:59:54 +05:00
.Select(r => Convert(r, offsetHours));
return result;
}
2023-01-11 14:59:54 +05:00
/// <inheritdoc/>
public async Task<int> UpdateAsync(PlannedTrajectoryDto row, CancellationToken token)
2023-01-12 10:32:54 +05:00
{
var offsetHours = wellService.GetTimezone(row.IdWell).Hours;
var entity = Convert(row, offsetHours);
2023-01-11 14:59:54 +05:00
db.PlannedTrajectories.Update(entity);
return await db.SaveChangesAsync(token)
.ConfigureAwait(false);
}
private PlannedTrajectoryDto Convert(PlannedTrajectory entity, double offsetHours)
{
var dto = entity.Adapt<PlannedTrajectoryDto>();
2023-01-11 14:59:54 +05:00
dto.UpdateDate = entity.UpdateDate.ToRemoteDateTime(offsetHours);
return dto;
2022-12-27 21:45:03 +05:00
}
private PlannedTrajectory Convert(PlannedTrajectoryDto dto, double offsetHours)
{
var entity = dto.Adapt<PlannedTrajectory>();
2023-01-11 14:59:54 +05:00
entity.UpdateDate = DateTime.Now.ToUtcDateTimeOffset(offsetHours);
2022-12-27 21:45:03 +05:00
return entity;
}
public async Task<TrajectoryDto[]> GetTrajectoryAsync(int idWell, CancellationToken token)
{
return (await GetAsync(idWell, token))
.Select(coord => new TrajectoryDto(coord.WellboreDepth, coord.ZenithAngle, coord.AzimuthGeo))
.ToArray();
}
}
}