Fixed: Don't Error to New Page on Failed Login

This commit is contained in:
Qstick 2019-04-06 22:18:45 -04:00
parent d81b063388
commit 9d27fff825
1 changed files with 15 additions and 5 deletions

View File

@ -4,6 +4,7 @@ using Nancy.Authentication.Forms;
using Nancy.Extensions;
using Nancy.ModelBinding;
using NzbDrone.Common.EnsureThat;
using NzbDrone.Common.Extensions;
using NzbDrone.Core.Authentication;
using NzbDrone.Core.Configuration;
@ -24,16 +25,19 @@ namespace Lidarr.Http.Authentication
private Response Login(LoginResource resource)
{
Ensure.That(resource.Username, () => resource.Username).IsNotNullOrWhiteSpace();
var username = resource.Username;
var password = resource.Password;
Ensure.That(resource.Password, () => resource.Password).IsNotNullOrWhiteSpace();
if (username.IsNullOrWhiteSpace() || password.IsNullOrWhiteSpace())
{
return LoginFailed();
}
var user = _userService.FindUser(resource.Username, resource.Password);
var user = _userService.FindUser(username, password);
if (user == null)
{
var returnUrl = (string)Request.Query.returnUrl;
return Context.GetRedirect($"~/login?returnUrl={returnUrl}&loginFailed=true");
return LoginFailed();
}
DateTime? expiry = null;
@ -50,5 +54,11 @@ namespace Lidarr.Http.Authentication
{
return this.LogoutAndRedirect(_configFileProvider.UrlBase + "/");
}
private Response LoginFailed()
{
var returnUrl = (string)Request.Query.returnUrl;
return Context.GetRedirect($"~/login?returnUrl={returnUrl}&loginFailed=true");
}
}
}