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); }