using System.Threading;
using System.Threading.Tasks;

namespace AsbCloudApp.Services
{
    /// <summary>
    /// репозиторий для личных настроек пользователя
    /// </summary>
    public interface IUserSettingsRepository
    {
        /// <summary>
        /// код ошибки: ключ не найден
        /// </summary>
        public const int ErrorKeyNotFound = -1;
        
        /// <summary>
        /// код ошибки: ключ уже занят
        /// </summary>
        public const int ErrorKeyIsUsed = -2;

        /// <summary>
        /// Получить настройки по ключу для пользователя
        /// </summary>
        /// <param name="userId"></param>
        /// <param name="key"></param>
        /// <param name="token"></param>
        /// <returns></returns>
        Task<System.Text.Json.JsonDocument?> GetOrDefaultAsync(int userId, string key, CancellationToken token);

        /// <summary>
        /// Добавить или изменить настройки с ключем для пользователя
        /// </summary>
        /// <param name="userId"></param>
        /// <param name="key"></param>
        /// <param name="value"></param>
        /// <param name="token"></param>
        /// <returns></returns>
        Task<int> UpsertAsync(int userId, string key, System.Text.Json.JsonDocument value, CancellationToken token);

        /// <summary>
        /// Удалить настройки с ключем для пользователя
        /// </summary>
        /// <param name="userId"></param>
        /// <param name="key"></param>
        /// <param name="token"></param>
        /// <returns></returns>
        Task<int> DeleteAsync(int userId, string key, CancellationToken token);

        /// <summary>
        /// Удалить ВСЕ настройки пользователя
        /// </summary>
        /// <param name="userId"></param>
        /// <param name="token"></param>
        /// <returns></returns>
        Task<int> DeleteAsync(int userId, CancellationToken token);
    }
}