using DD.Persistence.Models; using DD.Persistence.Models.Common; using DD.Persistence.Services.Interfaces; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using System.Net; namespace DD.Persistence.API.Controllers; /// /// Хранение наборов данных с отметкой времени. /// [ApiController] [Authorize] [Route("api/[controller]/{discriminatorId}")] public class TimestampedValuesController : ControllerBase { private readonly ITimestampedValuesService timestampedValuesRepository; public TimestampedValuesController(ITimestampedValuesService repository) { this.timestampedValuesRepository = repository; } /// /// Записать новые данные. /// Предполагается что данные с одним дискриминатором имеют одинаковую структуру /// /// Дискриминатор (идентификатор) набора /// /// [HttpPost] [ProducesResponseType(typeof(int), (int)HttpStatusCode.Created)] public async Task AddRange([FromRoute] Guid discriminatorId, [FromBody] IEnumerable dtos, CancellationToken token) { var result = await timestampedValuesRepository.AddRange(discriminatorId, dtos, token); return CreatedAtAction(nameof(AddRange), result); } /// /// Получение данных с фильтрацией. Значение фильтра null - отключен /// /// Дискриминатор (идентификатор) набора /// Фильтр позднее даты /// Фильтр свойств набора /// /// /// [HttpGet] [ProducesResponseType(typeof(IEnumerable), (int)HttpStatusCode.OK)] [ProducesResponseType((int)HttpStatusCode.NoContent)] public async Task>> Get([FromRoute] Guid discriminatorId, DateTimeOffset? timestampBegin, [FromQuery] string[]? columnNames, int skip, int take, CancellationToken token) { var result = await timestampedValuesRepository.Get(discriminatorId, timestampBegin, columnNames, skip, take, token); return result.Any() ? Ok(result) : NoContent(); } /// /// Получить данные, начиная с заданной отметки времени /// /// Дискриминатор (идентификатор) набора /// Фильтр позднее даты /// [HttpGet("gtdate")] [ProducesResponseType(typeof(IEnumerable), (int)HttpStatusCode.OK)] [ProducesResponseType((int)HttpStatusCode.NoContent)] public async Task>> GetGtDate([FromRoute] Guid discriminatorId, DateTimeOffset timestampBegin, CancellationToken token) { var result = await timestampedValuesRepository.GetGtDate(discriminatorId, timestampBegin, token); return result.Any() ? Ok(result) : NoContent(); } /// /// Получить данные c начала /// /// Дискриминатор (идентификатор) набора /// /// [HttpGet("first")] [ProducesResponseType(typeof(IEnumerable), (int)HttpStatusCode.OK)] [ProducesResponseType((int)HttpStatusCode.NoContent)] public async Task>> GetFirst([FromRoute] Guid discriminatorId, int take, CancellationToken token) { var result = await timestampedValuesRepository.GetFirst(discriminatorId, take, token); return result.Any() ? Ok(result) : NoContent(); } /// /// Получить данные c конца /// /// Дискриминатор (идентификатор) набора /// /// [HttpGet("last")] [ProducesResponseType(typeof(IEnumerable), (int)HttpStatusCode.OK)] [ProducesResponseType((int)HttpStatusCode.NoContent)] public async Task>> GetLast([FromRoute] Guid discriminatorId, int take, CancellationToken token) { var result = await timestampedValuesRepository.GetLast(discriminatorId, take, token); return result.Any() ? Ok(result) : NoContent(); } /// /// Получить список объектов с прореживанием, удовлетворяющий диапазону дат /// /// Дискриминатор (идентификатор) набора /// Фильтр позднее даты /// /// /// [HttpGet("resampled")] [ProducesResponseType(typeof(IEnumerable), (int)HttpStatusCode.OK)] [ProducesResponseType((int)HttpStatusCode.NoContent)] public async Task>> GetResampledData([FromRoute] Guid discriminatorId, DateTimeOffset timestampBegin, double intervalSec = 600d, int approxPointsCount = 1024, CancellationToken token = default) { var result = await timestampedValuesRepository.GetResampledData(discriminatorId, timestampBegin, intervalSec, approxPointsCount, token); return result.Any() ? Ok(result) : NoContent(); } /// /// Получить количество записей по указанному набору в БД. Для пагинации /// /// Дискриминатор (идентификатор) набора /// [HttpGet("count")] public async Task> Count([FromRoute] Guid discriminatorId, CancellationToken token) { var result = await timestampedValuesRepository.Count(discriminatorId, token); return Ok(result); } /// /// Получить диапазон дат, в пределах которых хранятся даные /// /// /// [HttpGet("datesRange")] public async Task> GetDatesRange([FromRoute] Guid discriminatorId, CancellationToken token) { var result = await timestampedValuesRepository.GetDatesRange(discriminatorId, token); return Ok(result); } }