@namespace Oqtane.Modules.Admin.Login @inherits ModuleBase @inject NavigationManager NavigationManager @inject IUserService UserService @inject IServiceProvider ServiceProvider @inject SiteState SiteState @inject IStringLocalizer Localizer @inject IStringLocalizer SharedLocalizer @if (_message != string.Empty) { } ...
@Localizer["Info.SignedIn"]
@code { private string _returnUrl = string.Empty; private string _message = string.Empty; private MessageType _type = MessageType.Info; private string _username = string.Empty; private string _password = string.Empty; private bool _remember = false; private bool validated = false; private ElementReference login; private ElementReference username; public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Anonymous; public override List Resources => new List() { new Resource { ResourceType = ResourceType.Stylesheet, Url = ModulePath() + "Module.css" } }; protected override async Task OnInitializedAsync() { if (PageState.QueryString.ContainsKey("returnurl")) { _returnUrl = PageState.QueryString["returnurl"]; } if (PageState.QueryString.ContainsKey("name")) { _username = PageState.QueryString["name"]; } if (PageState.QueryString.ContainsKey("token")) { var user = new User(); user.SiteId = PageState.Site.SiteId; user.Username = _username; user = await UserService.VerifyEmailAsync(user, PageState.QueryString["token"]); if (user != null) { await logger.LogInformation(LogFunction.Security, "Email Verified For For Username {Username}", _username); _message = Localizer["Success.Account.Verified"]; } else { await logger.LogError(LogFunction.Security, "Email Verification Failed For Username {Username}", _username); _message = Localizer["Message.Account.NotVerfied"]; _type = MessageType.Warning; } } } protected override async Task OnAfterRenderAsync(bool firstRender) { if (firstRender) { if(PageState.User == null) { await username.FocusAsync(); } } } private async Task Login() { validated = true; var interop = new Interop(JSRuntime); if (await interop.FormValid(login)) { if (PageState.Runtime == Oqtane.Shared.Runtime.Server) { var user = new User(); user.SiteId = PageState.Site.SiteId; user.Username = _username; user.Password = _password; user = await UserService.LoginUserAsync(user, false, false); if (user.IsAuthenticated) { await logger.LogInformation(LogFunction.Security, "Login Successful For Username {Username}", _username); // server-side Blazor needs to post to the Login page so that the cookies are set correctly var fields = new { __RequestVerificationToken = SiteState.AntiForgeryToken, username = _username, password = _password, remember = _remember, returnurl = _returnUrl }; string url = Utilities.TenantUrl(PageState.Alias, "/pages/login/"); await interop.SubmitForm(url, fields); } else { await logger.LogError(LogFunction.Security, "Login Failed For Username {Username}", _username); AddModuleMessage(Localizer["Error.Login.Fail"], MessageType.Error); } } else { // client-side Blazor var user = new User(); user.SiteId = PageState.Site.SiteId; user.Username = _username; user.Password = _password; user = await UserService.LoginUserAsync(user, true, _remember); if (user.IsAuthenticated) { await logger.LogInformation(LogFunction.Security, "Login Successful For Username {Username}", _username); var authstateprovider = (IdentityAuthenticationStateProvider)ServiceProvider.GetService(typeof(IdentityAuthenticationStateProvider)); authstateprovider.NotifyAuthenticationChanged(); NavigationManager.NavigateTo(NavigateUrl(_returnUrl, true)); } else { await logger.LogError(LogFunction.Security, "Login Failed For Username {Username}", _username); AddModuleMessage(Localizer["Error.Login.Fail"], MessageType.Error); } } } else { AddModuleMessage(Localizer["Message.Required.UserInfo"], MessageType.Warning); } } private void Cancel() { NavigationManager.NavigateTo(_returnUrl); } private async Task Forgot() { if (_username != string.Empty) { var user = await UserService.GetUserAsync(_username, PageState.Site.SiteId); if (user != null) { await UserService.ForgotPasswordAsync(user); await logger.LogInformation(LogFunction.Security, "Password Reset Notification Sent For Username {Username}", _username); _message = Localizer["Message.ForgotUser"]; } else { _message = Localizer["Message.UserDoesNotExist"]; _type = MessageType.Warning; } } else { _message = Localizer["Message.ForgotPassword"]; } StateHasChanged(); } private async Task KeyPressed(KeyboardEventArgs e) { if (e.Code == "Enter" || e.Code == "NumpadEnter") { await Login(); } } }