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 SiteState _siteState; private readonly NavigationManager _navigationManager; private readonly ISiteService _siteService; public UserService(HttpClient http, SiteState siteState, NavigationManager navigationManager, ISiteService siteService) : base(http) { _siteState = siteState; _navigationManager = navigationManager; _siteService = siteService; } private string Apiurl { get { return CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "User"); } } public async Task GetUserAsync(int userId, int siteId) { return await GetJsonAsync($"{Apiurl}/{userId.ToString()}?siteid={siteId.ToString()}"); } public async Task GetUserAsync(string username, int siteId) { return await GetJsonAsync($"{Apiurl}/name/{username}?siteid={siteId.ToString()}"); } public async Task AddUserAsync(User user) { // On initial site creation alias is null and we always want to create host user if (user.Username != Constants.HostUser && _siteState.Alias != null) { Site site = await _siteService.GetSiteAsync(_siteState.Alias.SiteId, _siteState.Alias); if (!site.AllowRegistration) { return null; } } return await PostJsonAsync(Apiurl, user); } public async Task AddUserAsync(User user, Alias alias) { return await PostJsonAsync(CreateCrossTenantUrl(Apiurl, alias), user); } public async Task UpdateUserAsync(User user) { return await PutJsonAsync($"{Apiurl}/{user.UserId.ToString()}", user); } public async Task DeleteUserAsync(int userId) { await DeleteAsync($"{Apiurl}/{userId.ToString()}"); } public async Task LoginUserAsync(User user, bool setCookie, bool isPersistent) { return await PostJsonAsync($"{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 PostJsonAsync($"{Apiurl}/logout", user); } public async Task VerifyEmailAsync(User user, string token) { return await PostJsonAsync($"{Apiurl}/verify?token={token}", user); } public async Task ForgotPasswordAsync(User user) { await PostJsonAsync($"{Apiurl}/forgot", user); } public async Task ResetPasswordAsync(User user, string token) { return await PostJsonAsync($"{Apiurl}/reset?token={token}", user); } } }