@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.
- package/esm2022/libraries/services/password-strength.service.mjs +55 -35
- package/fesm2022/tiba-spark-client-shared-lib.mjs +54 -34
- package/fesm2022/tiba-spark-client-shared-lib.mjs.map +1 -1
- package/libraries/services/password-strength.service.d.ts +6 -0
- package/libraries/services/password-strength.service.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -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 (
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
-
|
|
28
|
+
lengthScore += 1;
|
|
19
29
|
if (password.length >= 12)
|
|
20
|
-
|
|
30
|
+
lengthScore += 1;
|
|
21
31
|
if (password.length >= 15)
|
|
22
|
-
|
|
32
|
+
lengthScore += 1;
|
|
23
33
|
if (password.length >= 18)
|
|
24
|
-
|
|
25
|
-
|
|
34
|
+
lengthScore += 1;
|
|
35
|
+
return lengthScore;
|
|
36
|
+
}
|
|
37
|
+
getCharacterVarietyScore(password) {
|
|
38
|
+
let varietyScore = 0;
|
|
26
39
|
if (/[A-Z]/.test(password))
|
|
27
|
-
|
|
40
|
+
varietyScore += 1;
|
|
28
41
|
if (/[a-z]/.test(password))
|
|
29
|
-
|
|
42
|
+
varietyScore += 1;
|
|
30
43
|
if (/\d/.test(password))
|
|
31
|
-
|
|
44
|
+
varietyScore += 1;
|
|
32
45
|
if (/[^A-Za-z0-9]/.test(password))
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
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
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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,
|
|
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 (
|
|
93371
|
-
|
|
93372
|
-
|
|
93373
|
-
|
|
93374
|
-
|
|
93375
|
-
|
|
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
|
-
|
|
93387
|
+
lengthScore += 1;
|
|
93378
93388
|
if (password.length >= 12)
|
|
93379
|
-
|
|
93389
|
+
lengthScore += 1;
|
|
93380
93390
|
if (password.length >= 15)
|
|
93381
|
-
|
|
93391
|
+
lengthScore += 1;
|
|
93382
93392
|
if (password.length >= 18)
|
|
93383
|
-
|
|
93384
|
-
|
|
93393
|
+
lengthScore += 1;
|
|
93394
|
+
return lengthScore;
|
|
93395
|
+
}
|
|
93396
|
+
getCharacterVarietyScore(password) {
|
|
93397
|
+
let varietyScore = 0;
|
|
93385
93398
|
if (/[A-Z]/.test(password))
|
|
93386
|
-
|
|
93399
|
+
varietyScore += 1;
|
|
93387
93400
|
if (/[a-z]/.test(password))
|
|
93388
|
-
|
|
93401
|
+
varietyScore += 1;
|
|
93389
93402
|
if (/\d/.test(password))
|
|
93390
|
-
|
|
93403
|
+
varietyScore += 1;
|
|
93391
93404
|
if (/[^A-Za-z0-9]/.test(password))
|
|
93392
|
-
|
|
93393
|
-
|
|
93394
|
-
|
|
93395
|
-
|
|
93396
|
-
|
|
93397
|
-
|
|
93398
|
-
|
|
93399
|
-
|
|
93400
|
-
|
|
93401
|
-
|
|
93402
|
-
|
|
93403
|
-
|
|
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
|
-
|
|
93414
|
-
|
|
93415
|
-
|
|
93416
|
-
|
|
93417
|
-
|
|
93418
|
-
|
|
93419
|
-
|
|
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;
|