using Persistence.Models;

namespace Persistence.Repositories;

/// <summary>
/// Интерфейс для работы с историческими данными
/// </summary>
/// <typeparam name="TDto"></typeparam>
public interface IChangeLogRepository<TDto, TChangeLogDto> : ISyncRepository<TDto>
    where TDto : class, ITimeSeriesAbstractDto, new()
    where TChangeLogDto : ChangeLogDto<TDto>
{
    /// <summary>
    /// Добавление записей
    /// </summary>
    /// <param name="idUser">пользователь, который добавляет</param>
    /// <param name="dtos"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> InsertRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token);

    /// <summary>
    /// Редактирование записей
    /// </summary>
    /// <param name="idUser">пользователь, который редактирует</param>
    /// <param name="dtos"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> UpdateRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token);

    /// <summary>
    /// Добавляет Dto у которых id == 0, изменяет dto у которых id != 0
    /// </summary>
    /// <param name="idUser">пользователь, который редактирует или добавляет</param>
    /// <param name="dtos"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> UpdateOrInsertRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token);

    /// <summary>
    /// Помечает записи как удаленные
    /// </summary>
    /// <param name="idUser">пользователь, который чистит</param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> Clear(int idUser, CancellationToken token);

    /// <summary>
    /// Очистить и добавить новые
    /// </summary>
    /// <param name="idUser"></param>
    /// <param name="dtos"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> ClearAndInsertRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token);

    /// <summary>
    /// Пометить записи как удаленные
    /// </summary>
    /// <param name="idUser"></param>
    /// <param name="ids"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<int> MarkAsDeleted(int idUser, IEnumerable<int> ids, CancellationToken token);

    /// <summary>
    /// Получение дат изменений записей
    /// </summary>
    /// <param name="request"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<IEnumerable<DateOnly>> GetDatesChange(CancellationToken token);

    /// <summary>
    /// Получение измененных записей за определенную дату
    /// </summary>
    /// <param name="updateFrom"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<IEnumerable<TChangeLogDto>> GetChangeLogForDate(DateTimeOffset? updateFrom, CancellationToken token);

    /// <summary>
    /// Получение текущих сейчас записей по параметрам
    /// </summary>
    /// <param name="request"></param>
    /// <param name="token"></param>
    /// <returns></returns>
    Task<IEnumerable<TDto>> GetCurrent(DateTimeOffset moment, CancellationToken token);
}