Удаление части телеметрии по параметрам: ключ телеметрии и интервал дат

This commit is contained in:
Olga Nemt 2024-07-17 15:49:53 +05:00
parent e29b2be423
commit 6c516e983e
5 changed files with 72 additions and 2 deletions

View File

@ -3,6 +3,7 @@ using AsbCloudApp.Requests;
using System.Collections.Generic;
using System.Threading.Tasks;
using System.Threading;
using System;
namespace AsbCloudApp.Repositories
{
@ -29,5 +30,17 @@ namespace AsbCloudApp.Repositories
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<LimitingParameterDataDto>> GetLimitingParametersAsync(LimitingParameterRequest request, int idTelemetry, double timezoneHours, CancellationToken token);
/// <summary>
/// Удаление ограничивающих параметров по ключу телеметрии и интервалу дат
/// </summary>
/// <param name="telemetryId"></param>
/// <param name="gDate"></param>
/// <param name="lDate"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> DeleteAsync(int telemetryId, DateTimeOffset? gDate, DateTimeOffset? lDate, CancellationToken token);
}
}

View File

@ -78,5 +78,15 @@ namespace AsbCloudApp.Services
/// <param name="token"></param>
/// <returns></returns>
Task<Stream> GetTelemetriesInfoByLastData(DateTimeOffset from, CancellationToken token);
/// <summary>
/// Удаление части телеметрии
/// </summary>
/// <param name="telemetryId">ключ телеметрии</param>
/// <param name="gDate">начало временного диапазона</param>
/// <param name="lDate">конец временного диапазона</param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> DeleteAsync(int telemetryId, DateTimeOffset? gDate, DateTimeOffset? lDate, CancellationToken token);
}
}

View File

@ -17,10 +17,25 @@ namespace AsbCloudInfrastructure.Repository
private readonly IAsbCloudDbContext context;
public LimitingParameterRepository(IAsbCloudDbContext context)
{
{
this.context = context;
}
public async Task<int> DeleteAsync(int telemetryId, DateTimeOffset? gDate, DateTimeOffset? lDate, CancellationToken token)
{
var query = context.Set<LimitingParameter>()
.Where(o => o.IdTelemetry == telemetryId);
if (gDate.HasValue)
query = query.Where(o => o.DateStart > gDate.Value.ToUniversalTime());
if (lDate.HasValue)
query = query.Where(o => o.DateStart < lDate.Value.ToUniversalTime());
context.Set<LimitingParameter>().RemoveRange(query);
return await context.SaveChangesAsync(token);
}
public async Task<IEnumerable<LimitingParameterDataDto>> GetLimitingParametersAsync(LimitingParameterRequest request, WellDto wellDto, CancellationToken token)
{
var timezoneOffset = wellDto.Timezone.Hours;

View File

@ -24,6 +24,8 @@ namespace AsbCloudInfrastructure.Services.SAUB
//TODO: методы использующие ITelemetryDataCache, скорее всего, тут не нужны
private readonly ITelemetryDataCache<TelemetryDataSaubDto> dataSaubCache;
private readonly ITimezoneService timezoneService;
private readonly ITelemetryDataSaubService dataSaubService;
private readonly ILimitingParameterRepository limitingParameterRepository;
public ITimezoneService TimeZoneService => timezoneService;
@ -31,12 +33,17 @@ namespace AsbCloudInfrastructure.Services.SAUB
IAsbCloudDbContext db,
IMemoryCache memoryCache,
ITelemetryDataCache<TelemetryDataSaubDto> dataSaubCache,
ITimezoneService timezoneService)
ITimezoneService timezoneService,
ITelemetryDataSaubService dataSaubService,
ILimitingParameterRepository limitingParameterRepository)
{
this.db = db;
this.memoryCache = memoryCache;
this.dataSaubCache = dataSaubCache;
this.timezoneService = timezoneService;
this.dataSaubService = dataSaubService;
this.limitingParameterRepository = limitingParameterRepository;
}
private IEnumerable<Telemetry> GetTelemetryCache()
@ -352,5 +359,10 @@ namespace AsbCloudInfrastructure.Services.SAUB
return affected;
}
public async Task<int> DeleteAsync(int telemetryId, DateTimeOffset? gDate, DateTimeOffset? lDate, CancellationToken token)
{
return await limitingParameterRepository.DeleteAsync(telemetryId, gDate, lDate, token);
}
}
}

View File

@ -2,6 +2,7 @@ using AsbCloudApp.Data;
using AsbCloudApp.Services;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Threading;
using System.Threading.Tasks;
@ -36,5 +37,24 @@ namespace AsbCloudWebApi.Controllers
.ConfigureAwait(false);
return Ok(count);
}
/// <summary>
/// Удаление куска телеметрии
/// </summary>
/// <param name="telemetryId">ключ телеметрии</param>
/// <param name="gDate">начало интервала удаления</param>
/// <param name="lDate">конец интервала удаления</param>
/// <param name="token"></param>
/// <returns></returns>
[HttpDelete("{telemetryId}")]
[Permission]
public async Task<IActionResult> DeleteAsync(int telemetryId,
DateTimeOffset? gDate,
DateTimeOffset? lDate,
CancellationToken token)
{
await telemetryService.DeleteAsync(telemetryId, gDate, lDate, token);
return Ok();
}
}
}