if site login is disabled redirect Login to external identity provider
This commit is contained in:
		| @ -3,6 +3,7 @@ | ||||
| @inherits ModuleBase | ||||
| @inject NavigationManager NavigationManager | ||||
| @inject IUserService UserService | ||||
| @inject ISettingService SettingService | ||||
| @inject IServiceProvider ServiceProvider | ||||
| @inject IStringLocalizer<Index> Localizer | ||||
| @inject IStringLocalizer<SharedResources> SharedLocalizer | ||||
| @ -94,15 +95,8 @@ | ||||
|         { | ||||
|             _togglepassword = SharedLocalizer["ShowPassword"]; | ||||
|  | ||||
|             if (PageState.Site.Settings.ContainsKey("LoginOptions:AllowSiteLogin") && !string.IsNullOrEmpty(PageState.Site.Settings["LoginOptions:AllowSiteLogin"])) | ||||
|             { | ||||
|                 _allowsitelogin = bool.Parse(PageState.Site.Settings["LoginOptions:AllowSiteLogin"]); | ||||
|             } | ||||
|  | ||||
|             if (PageState.Site.Settings.ContainsKey("ExternalLogin:ProviderType") && !string.IsNullOrEmpty(PageState.Site.Settings["ExternalLogin:ProviderType"])) | ||||
|             { | ||||
|                 _allowexternallogin = true; | ||||
|             } | ||||
|             _allowsitelogin = bool.Parse(SettingService.GetSetting(PageState.Site.Settings, "LoginOptions:AllowSiteLogin", "true")); | ||||
|             _allowexternallogin = (SettingService.GetSetting(PageState.Site.Settings, "ExternalLogin:ProviderType", "") != "") ? true : false; | ||||
|  | ||||
|             if (PageState.QueryString.ContainsKey("returnurl")) | ||||
|             { | ||||
| @ -220,7 +214,7 @@ | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     if ((PageState.Site.Settings.ContainsKey("LoginOptions:TwoFactor") && PageState.Site.Settings["LoginOptions:TwoFactor"] == "required") || user.TwoFactorRequired) | ||||
|                     if (SettingService.GetSetting(PageState.Site.Settings, "LoginOptions:TwoFactor", "false") == "required" || user.TwoFactorRequired) | ||||
|                     { | ||||
|                         twofactor = true; | ||||
|                         validated = false; | ||||
|  | ||||
| @ -299,10 +299,7 @@ else | ||||
|  | ||||
|             _togglepassword = SharedLocalizer["ShowPassword"]; | ||||
|  | ||||
|             if (PageState.Site.Settings.ContainsKey("LoginOptions:TwoFactor") && !string.IsNullOrEmpty(PageState.Site.Settings["LoginOptions:TwoFactor"])) | ||||
|             { | ||||
|                 allowtwofactor = (PageState.Site.Settings["LoginOptions:TwoFactor"] == "true"); | ||||
|             } | ||||
|             allowtwofactor = (SettingService.GetSetting(PageState.Site.Settings, "LoginOptions:TwoFactor", "false") == "true"); | ||||
|  | ||||
|             if (PageState.User != null) | ||||
|             { | ||||
|  | ||||
| @ -17,13 +17,23 @@ namespace Oqtane.Themes.Controls | ||||
|     { | ||||
|         [Inject] public NavigationManager NavigationManager { get; set; } | ||||
|         [Inject] public IUserService UserService { get; set; } | ||||
|         [Inject] public ISettingService SettingService { get; set; } | ||||
|         [Inject] public IJSRuntime jsRuntime { get; set; } | ||||
|         [Inject] public IServiceProvider ServiceProvider { get; set; } | ||||
|  | ||||
|         private bool _allowsitelogin = true; | ||||
|  | ||||
|         protected void LoginUser() | ||||
|         { | ||||
|             Route route = new Route(PageState.Uri.AbsoluteUri, PageState.Alias.Path); | ||||
|             NavigationManager.NavigateTo(NavigateUrl("login", "?returnurl=" + WebUtility.UrlEncode(route.PathAndQuery))); | ||||
|             if (bool.Parse(SettingService.GetSetting(PageState.Site.Settings, "LoginOptions:AllowSiteLogin", "true"))) | ||||
|             { | ||||
|                 NavigationManager.NavigateTo(NavigateUrl("login", "?returnurl=" + WebUtility.UrlEncode(route.PathAndQuery))); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 NavigationManager.NavigateTo(Utilities.TenantUrl(PageState.Alias, "/pages/external?returnurl=" + WebUtility.UrlEncode(route.PathAndQuery)), true); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         protected async Task LogoutUser() | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 sbwalker
					sbwalker