This commit is contained in:
ngfrolov 2023-01-11 16:00:11 +05:00
parent 60a80745a9
commit 5948a762ba
Signed by: ng.frolov
GPG Key ID: E99907A0357B29A7
6 changed files with 39 additions and 25 deletions

View File

@ -11,7 +11,7 @@ namespace AsbCloudApp.Data.SAUB
/// <summary> /// <summary>
/// отметка времени /// отметка времени
/// </summary> /// </summary>
public DateTimeOffset DateTime { get; set; } public DateTime DateTime { get; set; }
/// <summary> /// <summary>
/// Наработка талевого каната с момента перетяжки каната, т*км /// Наработка талевого каната с момента перетяжки каната, т*км

View File

@ -28,7 +28,7 @@ namespace AsbCloudApp.Repositories
/// <param name="token"></param> /// <param name="token"></param>
/// <param name="wellInfo"></param> /// <param name="wellInfo"></param>
/// <returns></returns> /// <returns></returns>
Task<TelemetryWirelineRunOutDto?> GetValueOrDefaultAsync(int idWell, CancellationToken token); Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(int idWell, CancellationToken token);
/// <summary> /// <summary>
/// Возвращает данные по всем скважинам /// Возвращает данные по всем скважинам

View File

@ -13,7 +13,7 @@ namespace AsbCloudDb.Model
public int IdTelemetry { get; set; } public int IdTelemetry { get; set; }
[Column("date_time"), Comment("Отметка времени")] [Column("date_time"), Comment("Отметка времени")]
public DateTime DateTime { get; set; } public DateTimeOffset DateTime { get; set; }
[Column("hauling"), Comment("Наработка талевого каната с момента перетяжки каната, т*км")] [Column("hauling"), Comment("Наработка талевого каната с момента перетяжки каната, т*км")]
public float Hauling { get; set; } public float Hauling { get; set; }

View File

@ -4,6 +4,12 @@ namespace AsbCloudInfrastructure
{ {
public static class DateTimeExtentions public static class DateTimeExtentions
{ {
/// <summary>
/// Приветсти к UTC из времени куста
/// </summary>
/// <param name="date"></param>
/// <param name="remoteTimezoneOffsetHours"></param>
/// <returns></returns>
public static DateTimeOffset ToUtcDateTimeOffset(this DateTime date, double remoteTimezoneOffsetHours) public static DateTimeOffset ToUtcDateTimeOffset(this DateTime date, double remoteTimezoneOffsetHours)
{ {
if (date == default) if (date == default)
@ -18,6 +24,12 @@ namespace AsbCloudInfrastructure
return new DateTimeOffset(dateUtc); return new DateTimeOffset(dateUtc);
} }
/// <summary>
/// Привести ко времени куста из utc
/// </summary>
/// <param name="date"></param>
/// <param name="remoteTimezoneOffsetHours"></param>
/// <returns></returns>
public static DateTime ToRemoteDateTime(this DateTimeOffset date, double remoteTimezoneOffsetHours) public static DateTime ToRemoteDateTime(this DateTimeOffset date, double remoteTimezoneOffsetHours)
{ {
if (date == default) if (date == default)

View File

@ -4,7 +4,7 @@ using AsbCloudApp.Repositories;
using AsbCloudApp.Services; using AsbCloudApp.Services;
using AsbCloudDb; using AsbCloudDb;
using AsbCloudDb.Model; using AsbCloudDb.Model;
using DocumentFormat.OpenXml.Spreadsheet; using AsbCloudInfrastructure.Services.SAUB;
using Mapster; using Mapster;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using System.Collections.Generic; using System.Collections.Generic;
@ -34,29 +34,34 @@ namespace AsbCloudInfrastructure.Repository
public async Task<int> AddOrUpdateAsync(string uid, TelemetryWirelineRunOutDto dto, CancellationToken token) public async Task<int> AddOrUpdateAsync(string uid, TelemetryWirelineRunOutDto dto, CancellationToken token)
{ {
var idTelemetry = telemetryService.GetOrCreateTelemetryIdByUid(uid); var idTelemetry = telemetryService.GetOrCreateTelemetryIdByUid(uid);
var entity = Convert(idTelemetry, dto); var timezoneOffset = telemetryService.GetTimezone(idTelemetry).Hours;
var entity = Convert(idTelemetry, dto, timezoneOffset);
var updatingItem = context.TelemetryWirelineRunOut var updatingItem = context.TelemetryWirelineRunOut
.Where(x => x.IdTelemetry == idTelemetry) .Where(x => x.IdTelemetry == idTelemetry)
.AsNoTracking()
.FirstOrDefault(); .FirstOrDefault();
if (updatingItem is null) if (updatingItem is null)
context.TelemetryWirelineRunOut.Add(entity); context.TelemetryWirelineRunOut.Add(entity);
else else
context.TelemetryWirelineRunOut.Upsert(entity); context.TelemetryWirelineRunOut.Update(entity);
return await context.SaveChangesAsync(token); return await context.SaveChangesAsync(token);
} }
/// <inheritdoc/> /// <inheritdoc/>
public async Task<TelemetryWirelineRunOutDto?> GetValueOrDefaultAsync(int idWell, CancellationToken token) public async Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(int idWell, CancellationToken token)
{ {
var well = await wellService.GetOrDefaultAsync(idWell, token).ConfigureAwait(false); var well = await wellService.GetOrDefaultAsync(idWell, token).ConfigureAwait(false);
if (well is null) if (well is null)
return null; return null;
var idTelemetry = telemetryService.GetOrDefaultIdTelemetryByIdWell(idWell); return await GetOrDefaultAsync(well, token);
}
private async Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(WellDto well, CancellationToken token)
{
var idTelemetry = telemetryService.GetOrDefaultIdTelemetryByIdWell(well.Id);
if (idTelemetry is null) if (idTelemetry is null)
return null; return null;
@ -69,26 +74,20 @@ namespace AsbCloudInfrastructure.Repository
if (entity is null) if (entity is null)
return null; return null;
var timezone = telemetryService.GetTimezone((int)idTelemetry); var timezoneHours = well.Timezone.Hours;
return Convert(entity, well, timezone.Hours); return Convert(entity, well, timezoneHours);
} }
/// <inheritdoc/> /// <inheritdoc/>
public async Task<IEnumerable<TelemetryWirelineRunOutDto>> GetAllAsync(int idCompany, CancellationToken token) public async Task<IEnumerable<TelemetryWirelineRunOutDto>> GetAllAsync(int idCompany, CancellationToken token)
{ {
var result = new List<TelemetryWirelineRunOutDto>(); var wells = await wellService.GetWellsByCompanyAsync(idCompany, token)
var wells = await wellService.GetAllAsync(token)
.ConfigureAwait(false); .ConfigureAwait(false);
var result = new List<TelemetryWirelineRunOutDto>(wells.Count());
foreach (var well in wells) foreach (var well in wells)
{ {
bool isCompanyOwnsWell = await wellService.IsCompanyInvolvedInWellAsync(idCompany, well.Id, token) var dto = await GetOrDefaultAsync(well, token);
.ConfigureAwait(false);
if (!isCompanyOwnsWell)
continue;
var dto = await GetValueOrDefaultAsync(well.Id, token);
if (dto is not null) if (dto is not null)
result.Add(dto); result.Add(dto);
} }
@ -96,17 +95,18 @@ namespace AsbCloudInfrastructure.Repository
return result; return result;
} }
private static TelemetryWirelineRunOut Convert(int idTelemetry, TelemetryWirelineRunOutDto dto) private static TelemetryWirelineRunOut Convert(int idTelemetry, TelemetryWirelineRunOutDto dto, double timezoneOffset)
{ {
var entity = dto.Adapt<TelemetryWirelineRunOut>(); var entity = dto.Adapt<TelemetryWirelineRunOut>();
entity.IdTelemetry = idTelemetry; entity.IdTelemetry = idTelemetry;
entity.DateTime = entity.DateTime.ToUniversalTime(); entity.DateTime = dto.DateTime.ToUtcDateTimeOffset(timezoneOffset);
return entity; return entity;
} }
private static TelemetryWirelineRunOutDto Convert(TelemetryWirelineRunOut entity, WellDto well, double timezoneOffset) private static TelemetryWirelineRunOutDto Convert(TelemetryWirelineRunOut entity, WellDto well, double timezoneOffset)
{ {
var dto = entity.Adapt<TelemetryWirelineRunOutDto>(); var dto = entity.Adapt<TelemetryWirelineRunOutDto>();
dto.DateTime = entity.DateTime.ToUtcDateTimeOffset(timezoneOffset); dto.DateTime = entity.DateTime.ToRemoteDateTime(timezoneOffset);
dto.WellInfo = well; dto.WellInfo = well;
return dto; return dto;
} }

View File

@ -11,6 +11,7 @@ using AsbCloudApp.Repositories;
namespace AsbCloudWebApi.Controllers.SAUB namespace AsbCloudWebApi.Controllers.SAUB
{ {
#nullable enable
/// <summary> /// <summary>
/// Наработка талевого каната /// Наработка талевого каната
/// </summary> /// </summary>
@ -86,7 +87,7 @@ namespace AsbCloudWebApi.Controllers.SAUB
if (!isCompanyOwnsWell) if (!isCompanyOwnsWell)
return Forbid(); return Forbid();
var dto = await repository.GetValueOrDefaultAsync(idWell, token); var dto = await repository.GetOrDefaultAsync(idWell, token);
if (dto is null) if (dto is null)
return NoContent(); return NoContent();
@ -103,6 +104,7 @@ namespace AsbCloudWebApi.Controllers.SAUB
var dtos = await repository.GetAllAsync((int)idCompany, token); var dtos = await repository.GetAllAsync((int)idCompany, token);
return Ok(dtos); return Ok(dtos);
} }
}
} #nullable disable
} }