persistence/DD.Persistence/Repositories/IChangeLogRepository.cs

88 lines
4.0 KiB
C#
Raw Permalink Normal View History

using DD.Persistence.Models;
using DD.Persistence.Models.Requests;
namespace DD.Persistence.Repositories;
2024-10-31 15:01:12 +05:00
/// <summary>
2024-11-02 12:05:12 +05:00
/// Интерфейс для работы с историческими данными
2024-10-31 15:01:12 +05:00
/// </summary>
/// <typeparam name="TDto"></typeparam>
public interface IChangeLogRepository : ISyncWithDiscriminatorRepository<DataWithWellDepthAndSectionDto>
2024-10-31 15:01:12 +05:00
{
/// <summary>
/// Добавление записей
/// </summary>
/// <param name="idAuthor">пользователь, который добавляет</param>
/// <param name="idDiscriminator">ключ справочника</param>
2024-10-31 15:01:12 +05:00
/// <param name="dtos"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> AddRange(Guid idAuthor, Guid idDiscriminator, IEnumerable<DataWithWellDepthAndSectionDto> dtos, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Пометить записи как удаленные
2024-10-31 15:01:12 +05:00
/// </summary>
/// <param name="idEditor"></param>
/// <param name="ids">ключи записей</param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<int> MarkAsDeleted(Guid idEditor, IEnumerable<Guid> ids, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Пометить записи как удаленные
2024-10-31 15:01:12 +05:00
/// </summary>
/// <param name="idEditor"></param>
/// <param name="idDiscriminator">дискриминатор таблицы</param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<int> MarkAsDeleted(Guid idEditor, Guid idDiscriminator, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Очистить и добавить новые
/// </summary>
/// <param name="idAuthor"></param>
2024-11-27 17:59:37 +05:00
/// <param name="idDiscriminator"></param>
2024-10-31 15:01:12 +05:00
/// <param name="dtos"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> ClearAndAddRange(Guid idAuthor, Guid idDiscriminator, IEnumerable<DataWithWellDepthAndSectionDto> dtos, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Редактирование записей
2024-10-31 15:01:12 +05:00
/// </summary>
/// <param name="idEditor">пользователь, который редактирует</param>
/// <param name="dtos"></param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<int> UpdateRange(Guid idEditor, IEnumerable<DataWithWellDepthAndSectionDto> dtos, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Получение актуальных записей на определенный момент времени (с пагинацией)
2024-10-31 15:01:12 +05:00
/// </summary>
/// <param name="idDiscriminator"></param>
/// <param name="moment">текущий момент времени</param>
/// <param name="filterRequest">параметры запроса фильтрации</param>
/// <param name="paginationRequest">параметры запроса пагинации</param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<PaginationContainer<DataWithWellDepthAndSectionDto>> GetByDate(Guid idDiscriminator, DateTimeOffset moment, SectionPartRequest filterRequest, PaginationRequest paginationRequest, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
2024-11-27 17:59:37 +05:00
/// Получение измененных записей за период времени
2024-10-31 15:01:12 +05:00
/// </summary>
2024-11-27 17:59:37 +05:00
/// <param name="idDiscriminator"></param>
/// <param name="dateBegin"></param>
/// <param name="dateEnd"></param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<ChangeLogDto>> GetChangeLogForInterval(Guid idDiscriminator, DateTimeOffset dateBegin, DateTimeOffset dateEnd, CancellationToken token);
2024-10-31 15:01:12 +05:00
/// <summary>
/// Получение списка дат, в которые происходили изменения (день, месяц, год, без времени)
2024-10-31 15:01:12 +05:00
/// </summary>
2024-11-27 17:59:37 +05:00
/// <param name="idDiscriminator"></param>
2024-10-31 15:01:12 +05:00
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<DateOnly>> GetDatesChange(Guid idDiscriminator, CancellationToken token);
2024-10-31 15:01:12 +05:00
}