2024-11-22 17:52:15 +05:00
|
|
|
|
using Persistence.Models;
|
|
|
|
|
|
|
|
|
|
namespace Persistence.Repositories;
|
2024-11-25 09:41:11 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Репозиторий для хранения разных наборов данных временных рядов.
|
|
|
|
|
/// idDiscriminator - идентифицирует конкретный набор данных, прим.: циклы измерения АСИБР, или отчет о DrillTest.
|
|
|
|
|
/// idDiscriminator формируют клиенты и только им известно что они обозначают.
|
|
|
|
|
/// Так как данные приходят редко, то их прореживания для построения графиков не предусмотрено.
|
|
|
|
|
/// </summary>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
public interface ITimestampedSetRepository
|
|
|
|
|
{
|
2024-11-25 09:41:11 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Количество записей по указанному набору в БД. Для пагинации.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idDiscriminator"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
Task<int> Count(Guid idDiscriminator, CancellationToken token);
|
2024-11-25 09:41:11 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Получение данных с фильтрацией. Значение фильтра null - отключен
|
|
|
|
|
/// </summary>
|
2024-11-26 10:07:50 +05:00
|
|
|
|
/// <param name="idDiscriminator">Дискриминатор (идентификатор) набора</param>
|
2024-11-25 09:41:11 +05:00
|
|
|
|
/// <param name="geTimestamp">Фильтр позднее даты</param>
|
|
|
|
|
/// <param name="props">Фильтр свойств набора. Можно запросить только некоторые свойства из набора</param>
|
|
|
|
|
/// <param name="skip"></param>
|
|
|
|
|
/// <param name="take"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
Task<IEnumerable<TimestampedSetDto>> Get(Guid idDiscriminator, DateTimeOffset? geTimestamp, IEnumerable<string>? props, int skip, int take, CancellationToken token);
|
2024-11-25 09:41:11 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Диапазон дат за которые есть данные
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idDiscriminator"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
Task<DatesRangeDto?> GetDatesRange(Guid idDiscriminator, CancellationToken token);
|
2024-11-25 09:41:11 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Получить последние данные
|
|
|
|
|
/// </summary>
|
2024-11-26 10:07:50 +05:00
|
|
|
|
/// <param name="idDiscriminator">Дискриминатор (идентификатор) набора</param>
|
|
|
|
|
/// <param name="props">Фильтр свойств набора. Можно запросить только некоторые свойства из набора</param>
|
2024-11-25 09:41:11 +05:00
|
|
|
|
/// <param name="take"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
Task<IEnumerable<TimestampedSetDto>> GetLast(Guid idDiscriminator, IEnumerable<string>? props, int take, CancellationToken token);
|
2024-11-25 09:41:11 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Добавление новых данных
|
|
|
|
|
/// </summary>
|
2024-11-26 10:07:50 +05:00
|
|
|
|
/// <param name="idDiscriminator">Дискриминатор (идентификатор) набора</param>
|
2024-11-25 09:41:11 +05:00
|
|
|
|
/// <param name="sets"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2024-11-22 17:52:15 +05:00
|
|
|
|
Task<int> InsertRange(Guid idDiscriminator, IEnumerable<TimestampedSetDto> sets, CancellationToken token);
|
|
|
|
|
}
|