This repository has been archived on 2025-05-14. You can view files and clone it, but cannot push or open issues or pull requests.
Pavel Vesely cf6643aef3 Client fixes
Client is partially done.
227 warnings left out of 1500
I like Rider
2020-03-15 15:19:35 +01:00

98 lines
3.0 KiB
C#

using Oqtane.Shared;
using Oqtane.Models;
using System.Net.Http;
using Microsoft.AspNetCore.Components;
using System.Threading.Tasks;
namespace Oqtane.Services
{
public class UserService : ServiceBase, IUserService
{
private readonly HttpClient _http;
private readonly SiteState _siteState;
private readonly NavigationManager _navigationManager;
public UserService(HttpClient http, SiteState siteState, NavigationManager navigationManager)
{
_http = http;
_siteState = siteState;
_navigationManager = navigationManager;
}
private string Apiurl
{
get { return CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "User"); }
}
public async Task<User> GetUserAsync(int userId, int siteId)
{
return await _http.GetJsonAsync<User>(Apiurl + "/" + userId.ToString() + "?siteid=" + siteId.ToString());
}
public async Task<User> GetUserAsync(string username, int siteId)
{
return await _http.GetJsonAsync<User>(Apiurl + "/name/" + username + "?siteid=" + siteId.ToString());
}
public async Task<User> AddUserAsync(User user)
{
try
{
return await _http.PostJsonAsync<User>(Apiurl, user);
}
catch
{
return null;
}
}
public async Task<User> AddUserAsync(User user, Alias alias)
{
try
{
return await _http.PostJsonAsync<User>(CreateCrossTenantUrl(Apiurl, alias), user);
}
catch
{
return null;
}
}
public async Task<User> UpdateUserAsync(User user)
{
return await _http.PutJsonAsync<User>(Apiurl + "/" + user.UserId.ToString(), user);
}
public async Task DeleteUserAsync(int userId)
{
await _http.DeleteAsync(Apiurl + "/" + userId.ToString());
}
public async Task<User> LoginUserAsync(User user, bool setCookie, bool isPersistent)
{
return await _http.PostJsonAsync<User>(Apiurl + "/login?setcookie=" + setCookie.ToString() + "&persistent=" + isPersistent.ToString(), user);
}
public async Task LogoutUserAsync(User user)
{
// best practices recommend post is preferrable to get for logout
await _http.PostJsonAsync(Apiurl + "/logout", user);
}
public async Task<User> VerifyEmailAsync(User user, string token)
{
return await _http.PostJsonAsync<User>(Apiurl + "/verify?token=" + token, user);
}
public async Task ForgotPasswordAsync(User user)
{
await _http.PostJsonAsync(Apiurl + "/forgot", user);
}
public async Task<User> ResetPasswordAsync(User user, string token)
{
return await _http.PostJsonAsync<User>(Apiurl + "/reset?token=" + token, user);
}
}
}