2025-01-14 17:56:59 +05:00
|
|
|
|
using DD.Persistence.Models;
|
|
|
|
|
using DD.Persistence.Models.Common;
|
2024-12-16 15:38:46 +05:00
|
|
|
|
using DD.Persistence.Repositories;
|
2025-01-14 17:56:59 +05:00
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2024-11-22 17:52:15 +05:00
|
|
|
|
using System.Net;
|
|
|
|
|
|
2024-12-16 15:38:46 +05:00
|
|
|
|
namespace DD.Persistence.API.Controllers;
|
2024-11-22 17:52:15 +05:00
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Хранение наборов данных с отметкой времени.
|
|
|
|
|
/// </summary>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
[ApiController]
|
2025-01-14 17:56:59 +05:00
|
|
|
|
//[Authorize]
|
|
|
|
|
[Route("api/[controller]/{discriminatorId}")]
|
2025-01-15 17:37:48 +05:00
|
|
|
|
public class TimestampedValuesController : ControllerBase
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
private readonly ITimestampedValuesRepository timestampedValuesRepository;
|
2024-11-22 17:52:15 +05:00
|
|
|
|
|
2025-01-16 17:19:27 +05:00
|
|
|
|
public TimestampedValuesController(ITimestampedValuesRepository repository)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
this.timestampedValuesRepository = repository;
|
2024-11-22 17:52:15 +05:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// Записать новые данные.
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// Предполагается что данные с одним дискриминатором имеют одинаковую структуру
|
|
|
|
|
/// </summary>
|
2025-01-14 17:56:59 +05:00
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// <param name="dtos"></param>
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <param name="token"></param>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
[HttpPost]
|
2025-01-17 17:21:54 +05:00
|
|
|
|
[ProducesResponseType(typeof(int), (int)HttpStatusCode.Created)]
|
|
|
|
|
public async Task<IActionResult> AddRange([FromRoute] Guid discriminatorId, [FromBody] IEnumerable<TimestampedValuesDto> dtos, CancellationToken token)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.AddRange(discriminatorId, dtos, token);
|
|
|
|
|
|
2024-11-22 17:52:15 +05:00
|
|
|
|
return Ok(result);
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Получение данных с фильтрацией. Значение фильтра null - отключен
|
|
|
|
|
/// </summary>
|
2025-01-14 17:56:59 +05:00
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// <param name="timestampBegin">Фильтр позднее даты</param>
|
|
|
|
|
/// <param name="columnNames">Фильтр свойств набора</param>
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <param name="skip"></param>
|
|
|
|
|
/// <param name="take"></param>
|
|
|
|
|
/// <param name="token"></param>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
[HttpGet]
|
2025-01-17 17:21:54 +05:00
|
|
|
|
public async Task<ActionResult<IEnumerable<TimestampedValuesDto>>> Get([FromRoute] Guid discriminatorId, DateTimeOffset? timestampBegin, [FromQuery] string[]? columnNames, int skip, int take, CancellationToken token)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.Get(discriminatorId, timestampBegin, columnNames, skip, take, token);
|
|
|
|
|
|
|
|
|
|
return result.Any() ? Ok(result) : NoContent();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Получить данные, начиная с заданной отметки времени
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
|
|
|
|
/// <param name="timestampBegin">Фильтр позднее даты</param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
[HttpGet("gtdate")]
|
|
|
|
|
public async Task<ActionResult<IEnumerable<TimestampedValuesDto>>> GetGtDate([FromRoute] Guid discriminatorId, DateTimeOffset timestampBegin, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var result = await timestampedValuesRepository.GetGtDate(discriminatorId, timestampBegin, token);
|
|
|
|
|
|
|
|
|
|
return result.Any() ? Ok(result) : NoContent();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Получить данные c начала
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
|
|
|
|
/// <param name="take"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
[HttpGet("first")]
|
|
|
|
|
public async Task<ActionResult<IEnumerable<TimestampedValuesDto>>> GetFirst([FromRoute] Guid discriminatorId, int take, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var result = await timestampedValuesRepository.GetFirst(discriminatorId, take, token);
|
|
|
|
|
|
|
|
|
|
return result.Any() ? Ok(result) : NoContent();
|
2024-11-22 17:52:15 +05:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// Получить данные c конца
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// </summary>
|
2025-01-14 17:56:59 +05:00
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <param name="take"></param>
|
|
|
|
|
/// <param name="token"></param>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
[HttpGet("last")]
|
2025-01-17 17:21:54 +05:00
|
|
|
|
public async Task<ActionResult<IEnumerable<TimestampedValuesDto>>> GetLast([FromRoute] Guid discriminatorId, int take, CancellationToken token)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.GetLast(discriminatorId, take, token);
|
|
|
|
|
|
|
|
|
|
return result.Any() ? Ok(result) : NoContent();
|
2024-11-22 17:52:15 +05:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// Получить список объектов с прореживанием, удовлетворяющий диапазону дат
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// </summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
|
|
|
|
/// <param name="timestampBegin">Фильтр позднее даты</param>
|
|
|
|
|
/// <param name="intervalSec"></param>
|
|
|
|
|
/// <param name="approxPointsCount"></param>
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <param name="token"></param>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
[HttpGet("resampled")]
|
|
|
|
|
public async Task<ActionResult<IEnumerable<TimestampedValuesDto>>> GetResampledData([FromRoute] Guid discriminatorId, DateTimeOffset timestampBegin, double intervalSec = 600d, int approxPointsCount = 1024, CancellationToken token = default)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.GetResampledData(discriminatorId, timestampBegin, intervalSec, approxPointsCount, token);
|
|
|
|
|
|
|
|
|
|
return result.Any() ? Ok(result) : NoContent();
|
2024-11-22 17:52:15 +05:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// Получить количество записей по указанному набору в БД. Для пагинации
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// </summary>
|
2025-01-14 17:56:59 +05:00
|
|
|
|
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
2024-11-26 11:24:31 +05:00
|
|
|
|
/// <param name="token"></param>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
[HttpGet("count")]
|
2025-01-17 17:21:54 +05:00
|
|
|
|
public async Task<ActionResult<int>> Count([FromRoute] Guid discriminatorId, CancellationToken token)
|
2025-01-14 17:56:59 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.Count(discriminatorId, token);
|
|
|
|
|
|
2025-01-14 17:56:59 +05:00
|
|
|
|
return Ok(result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
/// Получить диапазон дат, в пределах которых хранятся даные
|
2025-01-14 17:56:59 +05:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="discriminatorId"></param>
|
|
|
|
|
/// <param name="token"></param>
|
2025-01-17 17:21:54 +05:00
|
|
|
|
[HttpGet("datesRange")]
|
|
|
|
|
public async Task<ActionResult<DatesRangeDto>> GetDatesRange([FromRoute] Guid discriminatorId, CancellationToken token)
|
2024-11-22 17:52:15 +05:00
|
|
|
|
{
|
2025-01-17 17:21:54 +05:00
|
|
|
|
var result = await timestampedValuesRepository.GetDatesRange(discriminatorId, token);
|
|
|
|
|
|
2024-11-22 17:52:15 +05:00
|
|
|
|
return Ok(result);
|
|
|
|
|
}
|
|
|
|
|
}
|