From 0bde3233186177662f03e7a2a55236e8d2b2fa69 Mon Sep 17 00:00:00 2001 From: mehmet-erim Date: Thu, 24 Oct 2019 16:23:11 +0300 Subject: [PATCH] feat(account): implement dynamic password rules --- .../change-password.component.ts | 42 +++++++++++++++++-- 1 file changed, 38 insertions(+), 4 deletions(-) diff --git a/npm/ng-packs/packages/account/src/lib/components/change-password/change-password.component.ts b/npm/ng-packs/packages/account/src/lib/components/change-password/change-password.component.ts index afef2ccf95..850e4e37a1 100644 --- a/npm/ng-packs/packages/account/src/lib/components/change-password/change-password.component.ts +++ b/npm/ng-packs/packages/account/src/lib/components/change-password/change-password.component.ts @@ -1,8 +1,8 @@ -import { ChangePassword } from '@abp/ng.core'; +import { ChangePassword, ConfigState, ABP } from '@abp/ng.core'; import { ToasterService } from '@abp/ng.theme.shared'; import { Component, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; -import { comparePasswords, Validation } from '@ngx-validate/core'; +import { comparePasswords, Validation, PasswordRules, validatePassword } from '@ngx-validate/core'; import { Store } from '@ngxs/store'; import snq from 'snq'; import { finalize } from 'rxjs/operators'; @@ -29,11 +29,45 @@ export class ChangePasswordComponent implements OnInit { constructor(private fb: FormBuilder, private store: Store, private toasterService: ToasterService) {} ngOnInit(): void { + const passwordRules: ABP.Dictionary = this.store.selectSnapshot( + ConfigState.getSettings('Identity.Password'), + ); + const passwordRulesArr = [] as PasswordRules; + let requiredLength = 1; + + if ((passwordRules['Abp.Identity.Password.RequireDigit'] || '').toLowerCase() === 'true') { + passwordRulesArr.push('number'); + } + + if ((passwordRules['Abp.Identity.Password.RequireLowercase'] || '').toLowerCase() === 'true') { + passwordRulesArr.push('small'); + } + + if ((passwordRules['Abp.Identity.Password.RequireUppercase'] || '').toLowerCase() === 'true') { + passwordRulesArr.push('capital'); + } + + if (+(passwordRules['Abp.Identity.Password.RequiredUniqueChars'] || 0) > 0) { + passwordRulesArr.push('special'); + } + + if (Number.isInteger(+passwordRules['Abp.Identity.Password.RequiredLength'])) { + requiredLength = +passwordRules['Abp.Identity.Password.RequiredLength']; + } + this.form = this.fb.group( { password: ['', required], - newPassword: ['', required], - repeatNewPassword: ['', required], + newPassword: [ + '', + { + validators: [required, validatePassword(passwordRulesArr), minLength(requiredLength)], + }, + ], + repeatNewPassword: [ + '', + { validators: [required, validatePassword(passwordRulesArr), minLength(requiredLength)] }, + ], }, { validators: [comparePasswords(PASSWORD_FIELDS)],