123 lines
6.0 KiB
C#
123 lines
6.0 KiB
C#
using DD.Persistence.Models;
|
||
using DD.Persistence.Models.Common;
|
||
using DD.Persistence.Repositories;
|
||
using Microsoft.AspNetCore.Mvc;
|
||
using System.Net;
|
||
|
||
namespace DD.Persistence.API.Controllers;
|
||
|
||
/// <summary>
|
||
/// Хранение наборов данных с отметкой времени.
|
||
/// Не оптимизировано под большие данные.
|
||
/// </summary>
|
||
[ApiController]
|
||
//[Authorize]
|
||
[Route("api/[controller]/{discriminatorId}")]
|
||
public class TimestampedSetController : ControllerBase
|
||
{
|
||
private readonly ITimestampedValuesRepository<TimestampedValuesDto> repository;
|
||
|
||
public TimestampedSetController(ITimestampedValuesRepository<TimestampedValuesDto> repository)
|
||
{
|
||
this.repository = repository;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Записать новые данные
|
||
/// Предполагается что данные с одним дискриминатором имеют одинаковую структуру
|
||
/// </summary>
|
||
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
||
/// <param name="sets"></param>
|
||
/// <param name="token"></param>
|
||
/// <returns>кол-во затронутых записей</returns>
|
||
[HttpPost]
|
||
[ProducesResponseType(typeof(int), (int)HttpStatusCode.OK)]
|
||
public async Task<IActionResult> AddRange([FromRoute] Guid discriminatorId, [FromBody] IEnumerable<TimestampedValuesDto> sets, CancellationToken token)
|
||
{
|
||
var result = await repository.AddRange(discriminatorId, sets, token);
|
||
return Ok(result);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Получение данных с фильтрацией. Значение фильтра null - отключен
|
||
/// </summary>
|
||
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
||
/// <param name="geTimestamp">Фильтр позднее даты</param>
|
||
/// <param name="columnNames">Фильтр свойств набора. Можно запросить только некоторые свойства из набора</param>
|
||
/// <param name="skip"></param>
|
||
/// <param name="take"></param>
|
||
/// <param name="token"></param>
|
||
/// <returns>Фильтрованный набор данных с сортировкой по отметке времени</returns>
|
||
[HttpGet]
|
||
[ProducesResponseType(typeof(IEnumerable<TimestampedValuesDto>), (int)HttpStatusCode.OK)]
|
||
public async Task<IActionResult> Get([FromRoute] Guid discriminatorId, DateTimeOffset? geTimestamp, [FromQuery] IEnumerable<string>? columnNames, int skip, int take, CancellationToken token)
|
||
{
|
||
var result = await repository.Get(discriminatorId, geTimestamp, columnNames, skip, take, token);
|
||
return Ok(result);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Получить последние данные
|
||
/// </summary>
|
||
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
||
/// <param name="columnNames">Фильтр свойств набора. Можно запросить только некоторые свойства из набора</param>
|
||
/// <param name="take"></param>
|
||
/// <param name="token"></param>
|
||
/// <returns>Фильтрованный набор данных с сортировкой по отметке времени</returns>
|
||
[HttpGet("last")]
|
||
[ProducesResponseType(typeof(IEnumerable<TimestampedValuesDto>), (int)HttpStatusCode.OK)]
|
||
public async Task<IActionResult> GetLast([FromRoute] Guid discriminatorId, [FromQuery] IEnumerable<string>? columnNames, int take, CancellationToken token)
|
||
{
|
||
var result = await repository.GetLast(discriminatorId, columnNames, take, token);
|
||
return Ok(result);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Диапазон дат за которые есть данные
|
||
/// </summary>
|
||
/// <param name="discriminatorId"></param>
|
||
/// <param name="token"></param>
|
||
/// <returns>Дата первой и последней записи</returns>
|
||
[HttpGet("datesRange")]
|
||
[ProducesResponseType(typeof(DatesRangeDto), (int)HttpStatusCode.OK)]
|
||
[ProducesResponseType((int)HttpStatusCode.NoContent)]
|
||
public async Task<IActionResult> GetDatesRange([FromRoute] Guid discriminatorId, CancellationToken token)
|
||
{
|
||
var result = await repository.GetDatesRange(discriminatorId, token);
|
||
return Ok(result);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Количество записей по указанному набору в БД. Для пагинации.
|
||
/// </summary>
|
||
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
|
||
/// <param name="token"></param>
|
||
/// <returns></returns>
|
||
[HttpGet("count")]
|
||
[ProducesResponseType(typeof(int), (int)HttpStatusCode.OK)]
|
||
[ProducesResponseType((int)HttpStatusCode.NoContent)]
|
||
public async Task<IActionResult> Count([FromRoute] Guid discriminatorId, CancellationToken token)
|
||
{
|
||
var result = await repository.Count(discriminatorId, token);
|
||
return Ok(result);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Получить список объектов с прореживанием, удовлетворяющий диапазону дат
|
||
/// </summary>
|
||
/// <param name="discriminatorId"></param>
|
||
/// <param name="dateBegin"></param>
|
||
/// <param name="intervalSec"></param>
|
||
/// <param name="approxPointsCount"></param>
|
||
/// <param name="token"></param>
|
||
/// <returns></returns>
|
||
[HttpGet("resampled")]
|
||
[ProducesResponseType(typeof(IEnumerable<TimestampedValuesDto>), (int)HttpStatusCode.OK)]
|
||
[ProducesResponseType((int)HttpStatusCode.NoContent)]
|
||
public async Task<IActionResult> GetResampledData([FromRoute] Guid discriminatorId, DateTimeOffset dateBegin, double intervalSec = 600d, int approxPointsCount = 1024, CancellationToken token = default)
|
||
{
|
||
var result = await repository.GetResampledData(discriminatorId, dateBegin, intervalSec, approxPointsCount, token);
|
||
return Ok(result);
|
||
}
|
||
}
|