forked from ddrilling/AsbCloudServer
56 lines
1.9 KiB
C#
56 lines
1.9 KiB
C#
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);
|
||
} |