move password requirement localization back to Client project
This commit is contained in:
@ -14,10 +14,7 @@ using Oqtane.Repository;
|
||||
using Oqtane.Security;
|
||||
using Oqtane.Extensions;
|
||||
using Oqtane.Managers;
|
||||
using Oqtane.Services;
|
||||
using static System.Runtime.InteropServices.JavaScript.JSType;
|
||||
using Microsoft.Extensions.Localization;
|
||||
using Oqtane.Modules.Admin.Roles;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Oqtane.Controllers
|
||||
{
|
||||
@ -31,9 +28,8 @@ namespace Oqtane.Controllers
|
||||
private readonly IUserPermissions _userPermissions;
|
||||
private readonly IJwtManager _jwtManager;
|
||||
private readonly ILogManager _logger;
|
||||
private readonly IStringLocalizer<UserController> _localizer;
|
||||
|
||||
public UserController(IUserRepository users, ITenantManager tenantManager, IUserManager userManager, ISiteRepository sites, IUserPermissions userPermissions, IJwtManager jwtManager, ILogManager logger, IStringLocalizer<UserController> localizer)
|
||||
public UserController(IUserRepository users, ITenantManager tenantManager, IUserManager userManager, ISiteRepository sites, IUserPermissions userPermissions, IJwtManager jwtManager, ILogManager logger)
|
||||
{
|
||||
_users = users;
|
||||
_tenantManager = tenantManager;
|
||||
@ -42,7 +38,6 @@ namespace Oqtane.Controllers
|
||||
_userPermissions = userPermissions;
|
||||
_jwtManager = jwtManager;
|
||||
_logger = logger;
|
||||
_localizer = localizer;
|
||||
}
|
||||
|
||||
// GET api/<controller>/5?siteid=x
|
||||
@ -345,31 +340,17 @@ namespace Oqtane.Controllers
|
||||
|
||||
// GET api/<controller>/passwordrequirements/5
|
||||
[HttpGet("passwordrequirements/{siteid}")]
|
||||
public string PasswordRequirements(int siteid)
|
||||
public Dictionary<string, string> PasswordRequirements(int siteid)
|
||||
{
|
||||
var requirements = "";
|
||||
var requirements = new Dictionary<string, string>();
|
||||
|
||||
var site = _sites.GetSite(siteid);
|
||||
if (site != null && (site.AllowRegistration || User.IsInRole(RoleNames.Registered)))
|
||||
{
|
||||
// get settings
|
||||
// get password settings
|
||||
var sitesettings = HttpContext.GetSiteSettings();
|
||||
var minimumlength = sitesettings.GetValue("IdentityOptions:Password:RequiredLength", "6");
|
||||
var uniquecharacters = sitesettings.GetValue("IdentityOptions:Password:RequiredUniqueChars", "1");
|
||||
var requiredigit = bool.Parse(sitesettings.GetValue("IdentityOptions:Password:RequireDigit", "true"));
|
||||
var requireupper = bool.Parse(sitesettings.GetValue("IdentityOptions:Password:RequireUppercase", "true"));
|
||||
var requirelower = bool.Parse(sitesettings.GetValue("IdentityOptions:Password:RequireLowercase", "true"));
|
||||
var requirepunctuation = bool.Parse(sitesettings.GetValue("IdentityOptions:Password:RequireNonAlphanumeric", "true"));
|
||||
|
||||
// replace the placeholders with the setting values
|
||||
string digitRequirement = requiredigit ? _localizer["Password.DigitRequirement"] + ", " : "";
|
||||
string uppercaseRequirement = requireupper ? _localizer["Password.UppercaseRequirement"] + ", " : "";
|
||||
string lowercaseRequirement = requirelower ? _localizer["Password.LowercaseRequirement"] + ", " : "";
|
||||
string punctuationRequirement = requirepunctuation ? _localizer["Password.PunctuationRequirement"] + ", " : "";
|
||||
string passwordValidationCriteriaTemplate = _localizer["Password.ValidationCriteria"];
|
||||
|
||||
// format requirements
|
||||
requirements = string.Format(passwordValidationCriteriaTemplate, minimumlength, uniquecharacters, digitRequirement, uppercaseRequirement, lowercaseRequirement, punctuationRequirement);
|
||||
requirements = sitesettings.Where(item => item.Key.StartsWith("IdentityOptions:Password:"))
|
||||
.ToDictionary(item => item.Key, item => item.Value);
|
||||
}
|
||||
|
||||
return requirements;
|
||||
|
Reference in New Issue
Block a user