2024-12-16 15:38:46 +05:00
|
|
|
|
using DD.Persistence.Models;
|
2025-01-13 17:45:49 +05:00
|
|
|
|
using DD.Persistence.Models.Common;
|
2024-12-16 15:38:46 +05:00
|
|
|
|
using DD.Persistence.Models.Requests;
|
2025-02-11 17:58:52 +05:00
|
|
|
|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion.Internal;
|
2024-10-31 17:02:48 +05:00
|
|
|
|
|
2024-12-16 15:38:46 +05:00
|
|
|
|
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>
|
2025-01-24 17:24:18 +05:00
|
|
|
|
public interface IChangeLogRepository : ISyncWithDiscriminatorRepository<ChangeLogValuesDto>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Добавление записей
|
|
|
|
|
/// </summary>
|
2024-11-26 11:47:42 +05:00
|
|
|
|
/// <param name="idDiscriminator">ключ справочника</param>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
/// <param name="dto">коммит с изменениями</param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
Task<int> AddRange(Guid idDiscriminator, ChangeLogCommitDto dto, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// Пометить записи как удаленные
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// </summary>
|
2025-02-17 08:44:48 +05:00
|
|
|
|
/// <param name="idCommit"></param>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// <param name="ids">ключи записей</param>
|
2025-02-17 08:44:48 +05:00
|
|
|
|
/// <param name="updateTime"></param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-02-17 08:44:48 +05:00
|
|
|
|
Task<int> MarkAsDeleted(Guid idCommit, IEnumerable<Guid> ids, DateTimeOffset updateTime, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// Пометить записи как удаленные
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// </summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// <param name="idDiscriminator">дискриминатор таблицы</param>
|
2025-02-17 08:44:48 +05:00
|
|
|
|
/// <param name="idCommit"></param>
|
|
|
|
|
/// <param name="updateTime"></param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-02-17 08:44:48 +05:00
|
|
|
|
Task<int> MarkAsDeleted(Guid idDiscriminator, Guid idCommit, DateTimeOffset updateTime, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Очистить и добавить новые
|
|
|
|
|
/// </summary>
|
2024-11-27 17:59:37 +05:00
|
|
|
|
/// <param name="idDiscriminator"></param>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
/// <param name="commitDto">коммит с изменениями</param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
Task<int> ClearAndAddRange(Guid idDiscriminator, ChangeLogCommitDto commitDto, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// Редактирование записей
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// </summary>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
/// <param name="commitDto">коммит с изменениями</param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-02-11 17:58:52 +05:00
|
|
|
|
Task<int> UpdateRange(ChangeLogCommitDto commitDto, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// Получение актуальных записей на определенный момент времени (с пагинацией)
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// </summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// <param name="idDiscriminator"></param>
|
|
|
|
|
/// <param name="moment">текущий момент времени</param>
|
2024-12-05 11:01:00 +05:00
|
|
|
|
/// <param name="paginationRequest">параметры запроса пагинации</param>
|
2024-10-31 15:01:12 +05:00
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
2025-01-24 17:24:18 +05:00
|
|
|
|
Task<PaginationContainer<ChangeLogValuesDto>> GetByDate(Guid idDiscriminator, DateTimeOffset moment, 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>
|
2024-12-03 17:36:41 +05:00
|
|
|
|
Task<IEnumerable<ChangeLogDto>> GetChangeLogForInterval(Guid idDiscriminator, DateTimeOffset dateBegin, DateTimeOffset dateEnd, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
/// Получение списка дат, в которые происходили изменения (день, месяц, год, без времени)
|
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>
|
2024-11-28 16:29:00 +05:00
|
|
|
|
Task<IEnumerable<DateOnly>> GetDatesChange(Guid idDiscriminator, CancellationToken token);
|
2024-10-31 15:01:12 +05:00
|
|
|
|
}
|