@tiba-spark/client-shared-lib 25.1.0-648 → 25.1.0-649

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,41 +7,61 @@ const commonPasswords = [
7
7
  ];
8
8
  export class PasswordStrengthService {
9
9
  evaluatePasswordStrength(password) {
10
+ let score = !password ? 0 : this.calculatePasswordScore(password);
11
+ return this.getPasswordScoreResult(score);
12
+ }
13
+ calculatePasswordScore(password) {
10
14
  let score = 0;
11
- if (!password)
12
- return null;
13
- // Common Passwords
14
- if (this.isCommonPassword(password))
15
- return PasswordScore.Weak;
16
- // Length
15
+ if (this.isCommonPassword(password)) {
16
+ score = 2; // Assign a weak score if the password is commonly used
17
+ }
18
+ else {
19
+ score += this.getLengthScore(password);
20
+ score += this.getCharacterVarietyScore(password);
21
+ score += this.getPenaltyForWeakPatterns(password);
22
+ }
23
+ return score;
24
+ }
25
+ getLengthScore(password) {
26
+ let lengthScore = 0;
17
27
  if (password.length >= 8)
18
- score += 1;
28
+ lengthScore += 1;
19
29
  if (password.length >= 12)
20
- score += 1;
30
+ lengthScore += 1;
21
31
  if (password.length >= 15)
22
- score += 1;
32
+ lengthScore += 1;
23
33
  if (password.length >= 18)
24
- score += 1;
25
- // Character Variety
34
+ lengthScore += 1;
35
+ return lengthScore;
36
+ }
37
+ getCharacterVarietyScore(password) {
38
+ let varietyScore = 0;
26
39
  if (/[A-Z]/.test(password))
27
- score += 1;
40
+ varietyScore += 1;
28
41
  if (/[a-z]/.test(password))
29
- score += 1;
42
+ varietyScore += 1;
30
43
  if (/\d/.test(password))
31
- score += 1;
44
+ varietyScore += 1;
32
45
  if (/[^A-Za-z0-9]/.test(password))
33
- score += 1;
34
- // Sequential or Repeated Characters
35
- if (this.hasSequentialChars(password) || this.hasRepeatedChars(password))
36
- score -= 1;
37
- // Final Score Evaluation
38
- if (score <= 1)
39
- return PasswordScore.Insecure;
40
- if (score <= 3)
41
- return PasswordScore.Weak;
42
- if (score <= 5)
43
- return PasswordScore.Medium;
44
- return PasswordScore.Strong;
46
+ varietyScore += 1;
47
+ return varietyScore;
48
+ }
49
+ getPenaltyForWeakPatterns(password) {
50
+ return (this.hasSequentialChars(password) || this.hasRepeatedChars(password)) ? -1 : 0;
51
+ }
52
+ getPasswordScoreResult(score) {
53
+ let passwordScore;
54
+ if (score <= 0)
55
+ passwordScore = null;
56
+ else if (score <= 1)
57
+ passwordScore = PasswordScore.Insecure;
58
+ else if (score <= 3)
59
+ passwordScore = PasswordScore.Weak;
60
+ else if (score <= 5)
61
+ passwordScore = PasswordScore.Medium;
62
+ else
63
+ passwordScore = PasswordScore.Strong;
64
+ return passwordScore;
45
65
  }
46
66
  hasSequentialChars(password) {
47
67
  const sequences = [
@@ -51,14 +71,14 @@ export class PasswordStrengthService {
51
71
  'qwertyuiopasdfghjklzxcvbnm',
52
72
  'QWERTYUIOPASDFGHJKLZXCVBNM'
53
73
  ];
54
- for (const seq of sequences) {
55
- for (let i = 0; i < seq.length - 3; i++) {
56
- const forwardSeq = seq.substring(i, i + 4);
57
- const backwardSeq = forwardSeq.split('').reverse().join('');
58
- if (password.toLowerCase().includes(forwardSeq.toLowerCase()) ||
59
- password.toLowerCase().includes(backwardSeq.toLowerCase())) {
60
- return true;
61
- }
74
+ return sequences.some(seq => this.containsSequence(password.toLowerCase(), seq.toLowerCase()));
75
+ }
76
+ containsSequence(password, sequence) {
77
+ for (let i = 0; i < sequence.length - 3; i++) {
78
+ const forwardSeq = sequence.substring(i, i + 4);
79
+ const backwardSeq = forwardSeq.split('').reverse().join('');
80
+ if (password.includes(forwardSeq) || password.includes(backwardSeq)) {
81
+ return true;
62
82
  }
63
83
  }
64
84
  return false;
@@ -78,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
78
98
  providedIn: 'root',
79
99
  }]
80
100
  }] });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQtc3RyZW5ndGguc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC1zaGFyZWQtbGliL3NyYy9saWJyYXJpZXMvc2VydmljZXMvcGFzc3dvcmQtc3RyZW5ndGguc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFFN0QsTUFBTSxlQUFlLEdBQUc7SUFDdEIsVUFBVSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLFFBQVE7SUFDckQsV0FBVyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFVBQVU7Q0FDdkQsQ0FBQztBQUtGLE1BQU0sT0FBTyx1QkFBdUI7SUFFbEMsd0JBQXdCLENBQUMsUUFBZ0I7UUFDdkMsSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2QsSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPLElBQUksQ0FBQztRQUUzQixtQkFBbUI7UUFDbkIsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDO1lBQUUsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDO1FBRS9ELFNBQVM7UUFDVCxJQUFJLFFBQVEsQ0FBQyxNQUFNLElBQUksQ0FBQztZQUFFLEtBQUssSUFBSSxDQUFDLENBQUM7UUFDckMsSUFBSSxRQUFRLENBQUMsTUFBTSxJQUFJLEVBQUU7WUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO1FBQ3RDLElBQUksUUFBUSxDQUFDLE1BQU0sSUFBSSxFQUFFO1lBQUUsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUN0QyxJQUFJLFFBQVEsQ0FBQyxNQUFNLElBQUksRUFBRTtZQUFFLEtBQUssSUFBSSxDQUFDLENBQUM7UUFFdEMsb0JBQW9CO1FBQ3BCLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO1FBQ3ZDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO1FBQ3ZDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO1FBQ3BDLElBQUksY0FBYyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO1FBRTlDLG9DQUFvQztRQUNwQyxJQUFJLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDO1lBQUUsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUVyRix5QkFBeUI7UUFDekIsSUFBSSxLQUFLLElBQUksQ0FBQztZQUFFLE9BQU8sYUFBYSxDQUFDLFFBQVEsQ0FBQztRQUM5QyxJQUFJLEtBQUssSUFBSSxDQUFDO1lBQUUsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDO1FBQzFDLElBQUksS0FBSyxJQUFJLENBQUM7WUFBRSxPQUFPLGFBQWEsQ0FBQyxNQUFNLENBQUM7UUFDNUMsT0FBTyxhQUFhLENBQUMsTUFBTSxDQUFDO0lBQzlCLENBQUM7SUFFTyxrQkFBa0IsQ0FBQyxRQUFnQjtRQUN6QyxNQUFNLFNBQVMsR0FBRztZQUNoQiw0QkFBNEI7WUFDNUIsNEJBQTRCO1lBQzVCLFlBQVk7WUFDWiw0QkFBNEI7WUFDNUIsNEJBQTRCO1NBQzdCLENBQUM7UUFFRixLQUFLLE1BQU0sR0FBRyxJQUFJLFNBQVMsRUFBRTtZQUMzQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQ3ZDLE1BQU0sVUFBVSxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztnQkFDM0MsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBRTVELElBQUksUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsV0FBVyxFQUFFLENBQUM7b0JBQzNELFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUU7b0JBQzVELE9BQU8sSUFBSSxDQUFDO2lCQUNiO2FBQ0Y7U0FDRjtRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVPLGdCQUFnQixDQUFDLFFBQWdCO1FBQ3ZDLE9BQU8sV0FBVyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsUUFBZ0I7UUFDdkMsT0FBTyxlQUFlLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxLQUFLLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQy9GLENBQUM7K0dBNURVLHVCQUF1QjttSEFBdkIsdUJBQXVCLGNBRnRCLE1BQU07OzRGQUVQLHVCQUF1QjtrQkFIbkMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQYXNzd29yZFNjb3JlIH0gZnJvbSAnLi4vZW51bXMvcGFzc3dvcmQtc2NvcmUuZW51bSc7XG5cbmNvbnN0IGNvbW1vblBhc3N3b3JkcyA9IFtcbiAgXCJwYXNzd29yZFwiLCBcIjEyMzQ1NlwiLCBcIjEyMzQ1Njc4OVwiLCBcInF3ZXJ0eVwiLCBcImFiYzEyM1wiLFxuICBcInBhc3N3b3JkMVwiLCBcImFkbWluXCIsIFwibGV0bWVpblwiLCBcIndlbGNvbWVcIiwgXCJpbG92ZXlvdVwiXG5dO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgUGFzc3dvcmRTdHJlbmd0aFNlcnZpY2Uge1xuXG4gIGV2YWx1YXRlUGFzc3dvcmRTdHJlbmd0aChwYXNzd29yZDogc3RyaW5nKTogUGFzc3dvcmRTY29yZSB7XG4gICAgbGV0IHNjb3JlID0gMDtcbiAgICBpZiAoIXBhc3N3b3JkKSByZXR1cm4gbnVsbDtcblxuICAgIC8vIENvbW1vbiBQYXNzd29yZHNcbiAgICBpZiAodGhpcy5pc0NvbW1vblBhc3N3b3JkKHBhc3N3b3JkKSkgcmV0dXJuIFBhc3N3b3JkU2NvcmUuV2VhaztcblxuICAgIC8vIExlbmd0aFxuICAgIGlmIChwYXNzd29yZC5sZW5ndGggPj0gOCkgc2NvcmUgKz0gMTtcbiAgICBpZiAocGFzc3dvcmQubGVuZ3RoID49IDEyKSBzY29yZSArPSAxO1xuICAgIGlmIChwYXNzd29yZC5sZW5ndGggPj0gMTUpIHNjb3JlICs9IDE7XG4gICAgaWYgKHBhc3N3b3JkLmxlbmd0aCA+PSAxOCkgc2NvcmUgKz0gMTtcblxuICAgIC8vIENoYXJhY3RlciBWYXJpZXR5XG4gICAgaWYgKC9bQS1aXS8udGVzdChwYXNzd29yZCkpIHNjb3JlICs9IDE7XG4gICAgaWYgKC9bYS16XS8udGVzdChwYXNzd29yZCkpIHNjb3JlICs9IDE7XG4gICAgaWYgKC9cXGQvLnRlc3QocGFzc3dvcmQpKSBzY29yZSArPSAxO1xuICAgIGlmICgvW15BLVphLXowLTldLy50ZXN0KHBhc3N3b3JkKSkgc2NvcmUgKz0gMTtcblxuICAgIC8vIFNlcXVlbnRpYWwgb3IgUmVwZWF0ZWQgQ2hhcmFjdGVyc1xuICAgIGlmICh0aGlzLmhhc1NlcXVlbnRpYWxDaGFycyhwYXNzd29yZCkgfHwgdGhpcy5oYXNSZXBlYXRlZENoYXJzKHBhc3N3b3JkKSkgc2NvcmUgLT0gMTtcblxuICAgIC8vIEZpbmFsIFNjb3JlIEV2YWx1YXRpb25cbiAgICBpZiAoc2NvcmUgPD0gMSkgcmV0dXJuIFBhc3N3b3JkU2NvcmUuSW5zZWN1cmU7XG4gICAgaWYgKHNjb3JlIDw9IDMpIHJldHVybiBQYXNzd29yZFNjb3JlLldlYWs7XG4gICAgaWYgKHNjb3JlIDw9IDUpIHJldHVybiBQYXNzd29yZFNjb3JlLk1lZGl1bTtcbiAgICByZXR1cm4gUGFzc3dvcmRTY29yZS5TdHJvbmc7XG4gIH1cblxuICBwcml2YXRlIGhhc1NlcXVlbnRpYWxDaGFycyhwYXNzd29yZDogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgY29uc3Qgc2VxdWVuY2VzID0gW1xuICAgICAgJ2FiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6JyxcbiAgICAgICdBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWicsXG4gICAgICAnMDEyMzQ1Njc4OScsXG4gICAgICAncXdlcnR5dWlvcGFzZGZnaGprbHp4Y3Zibm0nLFxuICAgICAgJ1FXRVJUWVVJT1BBU0RGR0hKS0xaWENWQk5NJ1xuICAgIF07XG5cbiAgICBmb3IgKGNvbnN0IHNlcSBvZiBzZXF1ZW5jZXMpIHtcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2VxLmxlbmd0aCAtIDM7IGkrKykge1xuICAgICAgICBjb25zdCBmb3J3YXJkU2VxID0gc2VxLnN1YnN0cmluZyhpLCBpICsgNCk7XG4gICAgICAgIGNvbnN0IGJhY2t3YXJkU2VxID0gZm9yd2FyZFNlcS5zcGxpdCgnJykucmV2ZXJzZSgpLmpvaW4oJycpO1xuXG4gICAgICAgIGlmIChwYXNzd29yZC50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKGZvcndhcmRTZXEudG9Mb3dlckNhc2UoKSkgfHxcbiAgICAgICAgICBwYXNzd29yZC50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKGJhY2t3YXJkU2VxLnRvTG93ZXJDYXNlKCkpKSB7XG4gICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcHJpdmF0ZSBoYXNSZXBlYXRlZENoYXJzKHBhc3N3b3JkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gLyguKVxcMXsyLH0vLnRlc3QocGFzc3dvcmQpO1xuICB9XG5cbiAgcHJpdmF0ZSBpc0NvbW1vblBhc3N3b3JkKHBhc3N3b3JkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gY29tbW9uUGFzc3dvcmRzLnNvbWUoY29tbW9uUHdkID0+IGNvbW1vblB3ZC50b0xvd2VyQ2FzZSgpID09PSBwYXNzd29yZC50b0xvd2VyQ2FzZSgpKTtcbiAgfVxufVxuIl19
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-strength.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/password-strength.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { PasswordScore } from '../enums/password-score.enum';\n\nconst commonPasswords = [\n  \"password\", \"123456\", \"123456789\", \"qwerty\", \"abc123\",\n  \"password1\", \"admin\", \"letmein\", \"welcome\", \"iloveyou\"\n];\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class PasswordStrengthService {\n\n  evaluatePasswordStrength(password: string): PasswordScore {\n    let score = !password ? 0 : this.calculatePasswordScore(password);\n    return this.getPasswordScoreResult(score);\n  }\n\n  private calculatePasswordScore(password: string): number {\n    let score = 0;\n\n    if (this.isCommonPassword(password)) {\n      score = 2; // Assign a weak score if the password is commonly used\n    } else {\n      score += this.getLengthScore(password);\n      score += this.getCharacterVarietyScore(password);\n      score += this.getPenaltyForWeakPatterns(password);\n    }\n\n    return score;\n  }\n\n  private getLengthScore(password: string): number {\n    let lengthScore = 0;\n    if (password.length >= 8) lengthScore += 1;\n    if (password.length >= 12) lengthScore += 1;\n    if (password.length >= 15) lengthScore += 1;\n    if (password.length >= 18) lengthScore += 1;\n    return lengthScore;\n  }\n\n  private getCharacterVarietyScore(password: string): number {\n    let varietyScore = 0;\n    if (/[A-Z]/.test(password)) varietyScore += 1;\n    if (/[a-z]/.test(password)) varietyScore += 1;\n    if (/\\d/.test(password)) varietyScore += 1;\n    if (/[^A-Za-z0-9]/.test(password)) varietyScore += 1;\n    return varietyScore;\n  }\n\n  private getPenaltyForWeakPatterns(password: string): number {\n    return (this.hasSequentialChars(password) || this.hasRepeatedChars(password)) ? -1 : 0;\n  }\n\n  private getPasswordScoreResult(score: number): PasswordScore {\n    let passwordScore: PasswordScore;\n    if (score <= 0) passwordScore = null;\n    else if (score <= 1) passwordScore = PasswordScore.Insecure;\n    else if (score <= 3) passwordScore = PasswordScore.Weak;\n    else if (score <= 5) passwordScore = PasswordScore.Medium;\n    else passwordScore = PasswordScore.Strong;\n    return passwordScore;\n  }\n\n  private hasSequentialChars(password: string): boolean {\n    const sequences = [\n      'abcdefghijklmnopqrstuvwxyz',\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZ',\n      '0123456789',\n      'qwertyuiopasdfghjklzxcvbnm',\n      'QWERTYUIOPASDFGHJKLZXCVBNM'\n    ];\n\n    return sequences.some(seq =>\n      this.containsSequence(password.toLowerCase(), seq.toLowerCase())\n    );\n  }\n\n  private containsSequence(password: string, sequence: string): boolean {\n    for (let i = 0; i < sequence.length - 3; i++) {\n      const forwardSeq = sequence.substring(i, i + 4);\n      const backwardSeq = forwardSeq.split('').reverse().join('');\n      if (password.includes(forwardSeq) || password.includes(backwardSeq)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private hasRepeatedChars(password: string): boolean {\n    return /(.)\\1{2,}/.test(password);\n  }\n\n  private isCommonPassword(password: string): boolean {\n    return commonPasswords.some(commonPwd => commonPwd.toLowerCase() === password.toLowerCase());\n  }\n}\n"]}
@@ -93366,41 +93366,61 @@ const commonPasswords = [
93366
93366
  ];
93367
93367
  class PasswordStrengthService {
93368
93368
  evaluatePasswordStrength(password) {
93369
+ let score = !password ? 0 : this.calculatePasswordScore(password);
93370
+ return this.getPasswordScoreResult(score);
93371
+ }
93372
+ calculatePasswordScore(password) {
93369
93373
  let score = 0;
93370
- if (!password)
93371
- return null;
93372
- // Common Passwords
93373
- if (this.isCommonPassword(password))
93374
- return PasswordScore.Weak;
93375
- // Length
93374
+ if (this.isCommonPassword(password)) {
93375
+ score = 2; // Assign a weak score if the password is commonly used
93376
+ }
93377
+ else {
93378
+ score += this.getLengthScore(password);
93379
+ score += this.getCharacterVarietyScore(password);
93380
+ score += this.getPenaltyForWeakPatterns(password);
93381
+ }
93382
+ return score;
93383
+ }
93384
+ getLengthScore(password) {
93385
+ let lengthScore = 0;
93376
93386
  if (password.length >= 8)
93377
- score += 1;
93387
+ lengthScore += 1;
93378
93388
  if (password.length >= 12)
93379
- score += 1;
93389
+ lengthScore += 1;
93380
93390
  if (password.length >= 15)
93381
- score += 1;
93391
+ lengthScore += 1;
93382
93392
  if (password.length >= 18)
93383
- score += 1;
93384
- // Character Variety
93393
+ lengthScore += 1;
93394
+ return lengthScore;
93395
+ }
93396
+ getCharacterVarietyScore(password) {
93397
+ let varietyScore = 0;
93385
93398
  if (/[A-Z]/.test(password))
93386
- score += 1;
93399
+ varietyScore += 1;
93387
93400
  if (/[a-z]/.test(password))
93388
- score += 1;
93401
+ varietyScore += 1;
93389
93402
  if (/\d/.test(password))
93390
- score += 1;
93403
+ varietyScore += 1;
93391
93404
  if (/[^A-Za-z0-9]/.test(password))
93392
- score += 1;
93393
- // Sequential or Repeated Characters
93394
- if (this.hasSequentialChars(password) || this.hasRepeatedChars(password))
93395
- score -= 1;
93396
- // Final Score Evaluation
93397
- if (score <= 1)
93398
- return PasswordScore.Insecure;
93399
- if (score <= 3)
93400
- return PasswordScore.Weak;
93401
- if (score <= 5)
93402
- return PasswordScore.Medium;
93403
- return PasswordScore.Strong;
93405
+ varietyScore += 1;
93406
+ return varietyScore;
93407
+ }
93408
+ getPenaltyForWeakPatterns(password) {
93409
+ return (this.hasSequentialChars(password) || this.hasRepeatedChars(password)) ? -1 : 0;
93410
+ }
93411
+ getPasswordScoreResult(score) {
93412
+ let passwordScore;
93413
+ if (score <= 0)
93414
+ passwordScore = null;
93415
+ else if (score <= 1)
93416
+ passwordScore = PasswordScore.Insecure;
93417
+ else if (score <= 3)
93418
+ passwordScore = PasswordScore.Weak;
93419
+ else if (score <= 5)
93420
+ passwordScore = PasswordScore.Medium;
93421
+ else
93422
+ passwordScore = PasswordScore.Strong;
93423
+ return passwordScore;
93404
93424
  }
93405
93425
  hasSequentialChars(password) {
93406
93426
  const sequences = [
@@ -93410,14 +93430,14 @@ class PasswordStrengthService {
93410
93430
  'qwertyuiopasdfghjklzxcvbnm',
93411
93431
  'QWERTYUIOPASDFGHJKLZXCVBNM'
93412
93432
  ];
93413
- for (const seq of sequences) {
93414
- for (let i = 0; i < seq.length - 3; i++) {
93415
- const forwardSeq = seq.substring(i, i + 4);
93416
- const backwardSeq = forwardSeq.split('').reverse().join('');
93417
- if (password.toLowerCase().includes(forwardSeq.toLowerCase()) ||
93418
- password.toLowerCase().includes(backwardSeq.toLowerCase())) {
93419
- return true;
93420
- }
93433
+ return sequences.some(seq => this.containsSequence(password.toLowerCase(), seq.toLowerCase()));
93434
+ }
93435
+ containsSequence(password, sequence) {
93436
+ for (let i = 0; i < sequence.length - 3; i++) {
93437
+ const forwardSeq = sequence.substring(i, i + 4);
93438
+ const backwardSeq = forwardSeq.split('').reverse().join('');
93439
+ if (password.includes(forwardSeq) || password.includes(backwardSeq)) {
93440
+ return true;
93421
93441
  }
93422
93442
  }
93423
93443
  return false;